부모글 보이기/감추기 AD BLOCK 해제 요청 이 글에는 광고가 많이 들어가 있지 않습니다. adblock을 해제하셔도 글을 읽는데 그다지 부담이 없으니 해제를 부탁드립니다. (연관된 글이 6개 있습니다.) C# - 스레드 선호도(Thread Affinity) 지정하는 방법 다음의 질문이 있군요. ^^ 멀티코어 스레드 문의 ; https://www.sysnet.pe.kr/3/0/4712 C#에서 Thread에 대해 CPU 선호도를 지정하는 방법은 간단하게 관련 Win32 API에 대한 PInvoke를 사용할 수도 있습니다. SetThreadAffinityMask function ; https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-setthreadaffinitymask SetThreadIdealProcessor function ; https://learn.microsoft.com/en-us/windows/win32/api/processthreadsapi/nf-processthreadsapi-setthreadidealprocessor 하지만, 가능하다면 닷넷 BCL 레벨에서 끝내는 것이 더 좋겠죠? ^^ 그래서 다음과 같이 코딩을 해줄 수 있습니다. using System; using System.Diagnostics; using System.Threading; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { Thread t1 = new Thread((e) => { SetIdealProcessor(3); Console.WriteLine(AppDomain.GetCurrentThreadId()); Console.ReadLine(); }); t1.Start(); } // 이 코드는 닷넷 프레임워크 환경에서 테스트한 것입니다. (참고: 닷넷 런타임에 따라 달라지는 AppDomain.GetCurrentThreadId의 반환값) static void SetIdealProcessor(int cpuNumber) { if (cpuNumber >= Environment.ProcessorCount) { cpuNumber = 0; } foreach (ProcessThread pthread in Process.GetCurrentProcess().Threads) { if (pthread.Id == AppDomain.GetCurrentThreadId()) { // Ideal 설정만 필요하다면? // pthread.IdealProcessor = cpuNumber; // Affinity 설정까지 필요하다면? pthread.ProcessorAffinity = new IntPtr(1 << (cpuNumber)); break; } } } } } 위의 코드를 수행하고, 화면에 출력된 스레드 ID를 Process Explorer에서 찾아 제대로 설정되었는지 확인할 수 있습니다. (첨부한 코드는 이 글의 예제를 포함합니다.) [이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.] [다음 글] 디버깅 기술: 77. windbg의 콜스택 함수 인자를 쉽게 확인하는 방법[이전 글] VC++: 96. C/C++ 식 평가 - printf("%d %d %d\n", a, a++, a); [연관 글] 멀티코어 스레드 문의.NET Framework: 825. (번역글) .NET Internals Cookbook Part 10 - Threads, Tasks, asynchronous code and othersSetThreadAffinityMask를 이용한 쓰레드 지정하는 방법에 대해 궁금합니다..NET Framework: 1162. C# - 인텔 CPU의 P-Core와 E-Core를 구분하는 방법.NET Framework: 1194. C# - IdealProcessor와 ProcessorAffinity의 차이점.NET Framework: 1195. C# - Thread.Yield와 Thread.Sleep(0)의 차이점(?) [최초 등록일: 4/5/2016] [최종 수정일: 11/24/2022] 이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다. by SeongTae Jeong, mailto:techsharer at outlook.com 비밀번호 댓글 작성자 2016-04-06 04시31분 [차가워] 안녕하세요스레드스타트 하기 전에 프로세스를 먼저 지정해야 하는건가요? [guest] 2016-04-06 04시41분 [차가워] AppDomain.GetCurrentThreadId() <-- 이거는 사용되지 않습니다라는 오류 문구가 나오는데 그냥 무시하면 되는건가요?닷넷 4.5에서 위 코드를 사용해 볼가해서요감사합니다 [guest] 2016-04-06 08시46분 [차가워] AppDomain.GetCurrentThreadId() <-- 대신에 Process.GetCurrentProcess().Threads[0].Id <-- 이거를 사용하면 될거 같네요 [guest] 2016-04-06 10시41분 스레드 구분이 가능하다면 Process.GetCurrentProcess().Threads[...n...].Id 를 쓰는 것이 더 좋습니다. AppDomain.GetCurrentThreadId의 경우 4.5에서도 지원됩니다. (단지 obsolete 경고가 뜨는데 현재까지는 무시할 수 있습니다.) 정성태 2016-04-06 10시43분 "스레드스타트 하기 전에 프로세스를 먼저 지정해야 하는건가요?" 질문에 대한 해답은 이미 코드에 있습니다. 정성태 2016-04-06 04시50분 [차가워] 정말 감사합니다 구벅 [guest] 2019-03-12 04시50분 [ㅇㅇ] IdealProcessor라는 것이 CPU에 코어와 대응되는 개념인가요? CPU가 4코어짜리면, IdealProcessor를 3으로 설정하면 4번쨰코어에 스레드가 할당이 되는 것인가요? [guest] 2019-03-12 07시24분 넵 정성태 ... 76 77 78 79 80 81 82 83 84 [85] 86 87 88 89 90 ... NoWriterDateCnt.TitleFile(s) 11811정성태2/11/201920941오류 유형: 510. 서버 운영체제에 NVIDIA GeForce Experience 실행 시 wlanapi.dll 누락 문제11810정성태2/11/201918537.NET Framework: 808. .NET Profiler - GAC 모듈에서 GAC 비-등록 모듈을 참조하는 경우의 문제11809정성태2/11/201920757.NET Framework: 807. ClrMD를 이용해 메모리 덤프 파일로부터 특정 인스턴스를 참조하고 있는 소유자 확인11808정성태2/8/201922072디버깅 기술: 123. windbg - 닷넷 응용 프로그램의 메모리 누수 분석11807정성태1/29/201919975Windows: 156. 가상 디스크의 용량을 복구 파티션으로 인해 늘리지 못하는 경우 [4]11806정성태1/29/201919606디버깅 기술: 122. windbg - 덤프 파일로부터 PID와 환경 변수 등의 정보를 구하는 방법11805정성태1/28/201921780.NET Framework: 806. C# - int []와 object []의 차이로 이해하는 제네릭의 필요성 [4]111804정성태1/24/201919636Windows: 155. diskpart - remove letter 이후 재부팅 시 다시 드라이브 문자가 할당되는 경우11803정성태1/10/201918499디버깅 기술: 121. windbg - 닷넷 Finalizer 스레드가 멈춰있는 현상11802정성태1/7/201920213.NET Framework: 805. 두 개의 윈도우를 각각 실행하는 방법(Windows Forms, WPF)111801정성태1/1/201921478개발 환경 구성: 427. Netsh의 네트워크 모니터링 기능 [3]11800정성태12/28/201820599오류 유형: 509. WCF 호출 오류 메시지 - System.ServiceModel.CommunicationException: Internal Server Error11799정성태12/19/201822352.NET Framework: 804. WPF(또는 WinForm)에서 UWP UI 구성 요소 사용하는 방법 [3]111798정성태12/19/201821204개발 환경 구성: 426. vcpkg - "Building vcpkg.exe failed. Please ensure you have installed Visual Studio with the Desktop C++ workload and the Windows SDK for Desktop C++" 11797정성태12/19/201817181개발 환경 구성: 425. vcpkg - CMake Error: Problem with archive_write_header(): Can't create '' 빌드 오류11796정성태12/19/201817522개발 환경 구성: 424. vcpkg - "File does not have expected hash" 오류를 무시하는 방법11795정성태12/19/201820739Windows: 154. PowerShell - Zone 별로 DNS 레코드 유형 정보 조회 [1]11794정성태12/16/201816862오류 유형: 508. Get-AzureWebsite : Request to a downlevel service failed.11793정성태12/16/201819373개발 환경 구성: 423. NuGet 패키지 제작 - Native와 Managed DLL을 분리하는 방법 [1]11792정성태12/11/201819175Graphics: 34. .NET으로 구현하는 OpenGL (11) - Per-Pixel Lighting111791정성태12/11/201819178VS.NET IDE: 130. C/C++ 프로젝트의 시작 프로그램으로 .NET Core EXE를 지정하는 경우 닷넷 디버깅이 안 되는 문제 [1]11790정성태12/11/201817642오류 유형: 507. Could not save daemon configuration to C:\ProgramData\Docker\config\daemon.json: Access to the path 'C:\ProgramData\Docker\config' is denied.11789정성태12/10/201831273Windows: 153. C# - USB 장치의 연결 및 해제 알림을 위한 WM_DEVICECHANGE 메시지 처리 [2]211788정성태12/4/201817545오류 유형: 506. SqlClient - Value was either too large or too small for an Int32.Couldn't store <2151292191> in ... Column11787정성태11/29/201821710Graphics: 33. .NET으로 구현하는 OpenGL (9), (10) - OBJ File Format, Loading 3D Models111786정성태11/29/201818682오류 유형: 505. OpenGL.NET 예제 실행 시 "Managed Debugging Assistant 'CallbackOnCollectedDelegate'" 예외 발생 ... 76 77 78 79 80 81 82 83 84 [85] 86 87 88 89 90 ...