부모글 보이기/감추기 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) 12331정성태9/18/20208882오류 유형: 651. repadmin /syncall - 0x80090322 The target principal name is incorrect.12330정성태9/18/20209883.NET Framework: 939. C# - 전위/후위 증감 연산자에 대한 오버로딩 구현 [2]112329정성태9/16/202011816오류 유형: 650. ASUS 메인보드 관련 소프트웨어 설치 후 ArmouryCrate.UserSessionHelper.exe 프로세스 무한 종료 현상12328정성태9/16/202012011VS.NET IDE: 150. TFS의 이력에서 "Get This Version"과 같은 기능을 Git으로 처리한다면?12327정성태9/12/20209599.NET Framework: 938. C# - ICS(Internet Connection Sharing) 제어112326정성태9/12/20209133개발 환경 구성: 516. Azure VM의 Network Adapter를 실수로 비활성화한 경우12325정성태9/12/20208697개발 환경 구성: 515. OpenVPN - 재부팅 후 ICS(Internet Connection Sharing) 기능이 동작 안하는 문제12324정성태9/11/20209836개발 환경 구성: 514. smigdeploy.exe를 이용한 Windows Server 2016에서 2019로 마이그레이션 방법12323정성태9/11/20208777오류 유형: 649. Copy Database Wizard - The job failed. Check the event log on the destination server for details.12322정성태9/11/20209534개발 환경 구성: 513. Azure VM의 RDP 접속 위치 제한 [1]12321정성태9/11/20208278오류 유형: 648. netsh http add urlacl - Error: 183 Cannot create a file when that file already exists.12320정성태9/11/20209445개발 환경 구성: 512. RDP(원격 데스크톱) 접속 시 비밀 번호를 한 번 더 입력해야 하는 경우12319정성태9/10/20209087오류 유형: 647. smigdeploy.exe를 Windows Server 2016에서 실행할 때 .NET Framework 미설치 오류 발생12318정성태9/9/20208722오류 유형: 646. OpenVPN - "TAP-Windows Adapter V9" 어댑터의 "Network cable unplugged" 현상12317정성태9/9/202010908개발 환경 구성: 511. Beats용 Kibana 기본 대시 보드 구성 방법12316정성태9/8/20209389디버깅 기술: 170. WinDbg Preview 버전부터 닷넷 코어 3.0 이후의 메모리 덤프에 대해 sos.dll 자동 로드12315정성태9/7/202011614개발 환경 구성: 510. Logstash - FileBeat을 이용한 IIS 로그 처리 [2]12314정성태9/7/20209864오류 유형: 645. IIS HTTPERR - Timer_MinBytesPerSecond, Timer_ConnectionIdle 로그12313정성태9/6/202011323개발 환경 구성: 509. Logstash - 사용자 정의 grok 패턴 추가를 이용한 IIS 로그 처리12312정성태9/5/202015198개발 환경 구성: 508. Logstash 기본 사용법 [2]12311정성태9/4/202010474.NET Framework: 937. C# - 간단하게 만들어 보는 리눅스의 nc(netcat), json_pp 프로그램 [1]12310정성태9/3/20209699오류 유형: 644. Windows could not start the Elasticsearch 7.9.0 (elasticsearch-service-x64) service on Local Computer.12309정성태9/3/20209461개발 환경 구성: 507. Elasticsearch 6.6부터 기본 추가된 한글 형태소 분석기 노리(nori) 사용법12308정성태9/2/202010730개발 환경 구성: 506. Windows - 단일 머신에서 단일 바이너리로 여러 개의 ElasticSearch 노드를 실행하는 방법12307정성태9/2/202011527오류 유형: 643. curl - json_parse_exception / Invalid UTF-8 start byte12306정성태9/1/20209653오류 유형: 642. SQL Server 시작 오류 - error code 10013 ... 46 47 48 49 50 [51] 52 53 54 55 56 57 58 59 60 ...