부모글 보이기/감추기 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분 넵 정성태 ... 31 [32] 33 34 35 36 37 38 39 40 41 42 43 44 45 ... NoWriterDateCnt.TitleFile(s) 13139정성태10/9/202213667.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법113138정성태10/8/202216265.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]13137정성태10/8/202214214.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법13136정성태10/7/202214542.NET Framework: 2054. .NET Core/5+ SDK 설치 없이 dotnet-dump 사용하는 방법13135정성태10/5/202215063.NET Framework: 2053. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프를 분석하는 방법 - 두 번째 이야기 [1]13134정성태10/4/202212259오류 유형: 820. There is a problem with AMD Radeon RX 5600 XT device. For more information, search for 'graphics device driver error code 31'13133정성태10/4/202213394Windows: 211. Windows - (commit이 아닌) reserved 메모리 사용량 확인 방법 [1]13132정성태10/3/202213429스크립트: 42. 파이썬 - latexify-py 패키지 소개 - 함수를 mathjax 식으로 표현13131정성태10/3/202217237.NET Framework: 2052. C# - Windows Forms의 데이터 바인딩 지원(DataBinding, DataSource) [2]113130정성태9/28/202213048.NET Framework: 2051. .NET Core/5+ - 에러 로깅을 위한 Middleware가 동작하지 않는 경우113129정성태9/27/202213673.NET Framework: 2050. .NET Core를 IIS에서 호스팅하는 경우 .NET Framework CLR이 함께 로드되는 환경13128정성태9/23/202216601C/C++: 158. Visual C++ - IDL 구문 중 "unsigned long"을 인식하지 못하는 #import [1]113127정성태9/22/202214859Windows: 210. WSL에 systemd 도입13126정성태9/15/202215385.NET Framework: 2049. C# 11 - 정적 메서드에 대한 delegate 처리 시 cache 적용13125정성태9/14/202215793.NET Framework: 2048. C# 11 - 구조체 필드의 자동 초기화(auto-default structs)13124정성태9/13/202215586.NET Framework: 2047. Golang, Python, C#에서의 CRC32 사용13123정성태9/8/202215634.NET Framework: 2046. C# 11 - 멤버(속성/필드)에 지정할 수 있는 required 예약어 추가13122정성태8/26/202216043.NET Framework: 2045. C# 11 - 메서드 매개 변수에 대한 nameof 지원13121정성태8/23/202212454C/C++: 157. Golang - 구조체의 slice 필드를 Reflection을 이용해 변경하는 방법13120정성태8/19/202216062Windows: 209. Windows NT Service에서 UI를 다루는 방법 [3]13119정성태8/18/202215176.NET Framework: 2044. .NET Core/5+ 프로젝트에서 참조 DLL이 보관된 공통 디렉터리를 지정하는 방법13118정성태8/18/202212712.NET Framework: 2043. WPF Color의 기본 색 영역은 (sRGB가 아닌) scRGB [2]13117정성태8/17/202216392.NET Framework: 2042. C# 11 - 파일 범위 내에서 유효한 타입 정의 (File-local types)113116정성태8/4/202216845.NET Framework: 2041. C# - Socket.Close 시 Socket.Receive 메서드에서 예외가 발생하는 문제113115정성태8/3/202217437.NET Framework: 2040. C# - ValueTask와 Task의 성능 비교 [1]113114정성태8/2/202217293.NET Framework: 2039. C# - Task와 비교해 본 ValueTask 사용법1 ... 31 [32] 33 34 35 36 37 38 39 40 41 42 43 44 45 ...