부모글 보이기/감추기 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분 넵 정성태 ... 46 47 48 49 50 51 52 53 54 55 56 57 58 59 [60] ... NoWriterDateCnt.TitleFile(s) 12437정성태12/1/202017987VS.NET IDE: 155. pfx의 암호 키 파일을 Visual Studio 없이 등록하는 방법12436정성태12/1/202018146오류 유형: 687. .NET Core 2.2 빌드 - error MSB4018: The "RazorTagHelper" task failed unexpectedly.12435정성태12/1/202025224Windows: 181. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 (4) - ReuseUnicastPort를 이용한 포트 고갈 문제 해결 [1]112434정성태11/30/202019059Windows: 180. C# - dynamicport 값의 범위를 알아내는 방법12433정성태11/29/202017773Windows: 179. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 (3) - SO_PORT_SCALABILITY112432정성태11/29/202019284Windows: 178. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 (2) - SO_REUSEADDR [1]112431정성태11/27/202016119.NET Framework: 976. UnmanagedCallersOnly + C# 9.0 함수 포인터 사용 시 x86 빌드에서 오동작하는 문제112430정성태11/27/202018547오류 유형: 686. Ubuntu - E: The repository 'cdrom://...' does not have a Release file.12429정성태11/25/202018631디버깅 기술: 175. windbg - 특정 Win32 API에서 BP가 안 걸리는 경우12428정성태11/25/202016762VS.NET IDE: 154. Visual Studio - .NET Core App 실행 시 dotnet.exe 실행 화면만 나오는 문제12427정성태11/24/202017622.NET Framework: 975. .NET Core를 직접 호스팅해 (runtimeconfig.json 없이) EXE만 배포해 실행112426정성태11/24/202016006오류 유형: 685. WinDbg Preview - error InitTypeRead12425정성태11/24/202017655VC++: 141. Visual C++ - "Treat Warnings As Errors" 옵션이 꺼져 있는데도 일부 경고가 에러 처리되는 경우12424정성태11/24/202017968VC++: 140. C++의 연산자 동의어(operator synonyms), 대체 토큰 [1]12423정성태11/22/202018603.NET Framework: 974. C# 9.0 - (16) 제약 조건이 없는 형식 매개변수 주석(Unconstrained type parameter annotations)112422정성태11/21/202016016.NET Framework: 973. .NET 5, .NET Framework에서만 허용하는 UnmanagedCallersOnly 사용예112421정성태11/19/202015305.NET Framework: 972. DNNE가 출력한 NE DLL을 직접 생성하는 방법112420정성태11/19/202015246오류 유형: 684. Visual C++ - MSIL .netmodule or module compiled with /GL found; restarting link with /LTCG; add /LTCG to the link command line to improve linker performance12419정성태11/19/202016119VC++: 139. Visual C++ - .NET Core의 nethost.lib와 정적 링크112418정성태11/19/202018368오류 유형: 683. Visual C++ - error LNK2038: mismatch detected for 'RuntimeLibrary': value 'MT_StaticRelease' doesn't match value 'MDd_DynamicDebug'112417정성태11/19/202016094오류 유형: 682. Visual C++ - warning LNK4099: PDB '...pdb' was not found with '...lib(pch.obj)' or at '...pdb'; linking object as if no debug info12416정성태11/19/202017190오류 유형: 681. Visual C++ - error LNK2001: unresolved external symbol _CrtDbgReport12415정성태11/18/202017422.NET Framework: 971. UnmanagedCallersOnly 특성과 DNNE 사용112414정성태11/18/202019556VC++: 138. x64 빌드에서 extern "C"가 아닌 경우 ___cdecl name mangling 적용 [4]112413정성태11/17/202018525.NET Framework: 970. .NET 5 / .NET Core - UnmanagedCallersOnly 특성을 사용한 함수 내보내기112412정성태11/16/202020685.NET Framework: 969. .NET Framework 및 .NET 5 - UnmanagedCallersOnly 특성 사용1 ... 46 47 48 49 50 51 52 53 54 55 56 57 58 59 [60] ...