Microsoft MVP성태의 닷넷 이야기
.NET Framework: 571. C# - 스레드 선호도(Thread Affinity) 지정하는 방법 [링크 복사], [링크+제목 복사],
조회: 34002
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 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에서 찾아 제대로 설정되었는지 확인할 수 있습니다.

cs_thread_affinity_1.png

(첨부한 코드는 이 글의 예제를 포함합니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 11/24/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 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분

정성태

... 106  107  108  109  110  111  [112]  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11216정성태6/1/201721205오류 유형: 396. Activation context generation failed
11215정성태6/1/201724051오류 유형: 395. 관리 콘솔을 실행하면 "This app has been blocked for your protection" 오류 발생 [1]
11214정성태6/1/201720836오류 유형: 394. MSDTC 서비스 시작 시 -1073737712(0xC0001010) 오류와 함께 종료되는 문제 [1]
11213정성태5/26/201727056오류 유형: 393. TFS - The underlying connection was closed: Could not establish trust relationship for the SSL/TLS secure channel.
11212정성태5/26/201726432오류 유형: 392. Windows Server 2016에 KB4019472 업데이트가 실패하는 경우
11211정성태5/26/201724769오류 유형: 391. BeginInvoke에 전달한 람다 함수에 CS1660 에러가 발생하는 경우
11210정성태5/25/201724977기타: 65. ActiveX 없는 전자 메일에 사용된 "개인정보 보호를 위해 암호화된 보안메일"의 암호화 방법
11209정성태5/25/201774062Windows: 143. Windows 10의 Recovery 파티션을 삭제 및 새로 생성하는 방법 [16]
11208정성태5/25/201730969오류 유형: 390. diskpart의 set id 명령어에서 "The specified type is not in the correct format." 오류 발생
11207정성태5/24/201732947Windows: 142. Windows 10의 복구 콘솔로 부팅하는 방법
11206정성태5/24/201725811오류 유형: 389. DISM.exe - The specified image in the specified wim is already mounted for read/write access.
11205정성태5/24/201725184.NET Framework: 658. C#의 tail call 구현은? [1]
11204정성태5/22/201734701개발 환경 구성: 316. 간단하게 살펴보는 Docker for Windows [7]
11203정성태5/19/201721870오류 유형: 388. docker - Host does not exist: "default"
11202정성태5/19/201722914오류 유형: 387. WPF - There is no registered CultureInfo with the IetfLanguageTag 'ug'.
11201정성태5/16/201727508오류 유형: 386. WPF - .NET 3.5 이하에서 TextBox에 한글 입력 시 TextChanged 이벤트의 비정상 종료 문제 [1]파일 다운로드1
11200정성태5/16/201724054오류 유형: 385. WPF - 폰트가 없어 System.IO.FileNotFoundException 예외가 발생하는 경우
11199정성태5/16/201724076.NET Framework: 657. CultureInfo.GetCultures가 반환하는 값
11198정성태5/10/201727336.NET Framework: 656. Windows Forms의 오류(Exception) 처리 방법에 대한 차이점 설명
11197정성태5/8/201722428개발 환경 구성: 315. VHD 파일의 최소 크기파일 다운로드1
11196정성태5/4/201724131오류 유형: 384. Msvm_ImageManagementService WMI 객체를 사용할 때 오류 상황 정리 [1]
11195정성태5/3/201725487.NET Framework: 655. .NET Framework 4.7 릴리스
11194정성태5/3/201726213오류 유형: 383. net use 명령어로 네트워크 드라이브 연결 시 "System error 67 has occurred." 오류 발생
11193정성태5/3/201723829Windows: 141. 설치된 Windows로부터 설치 이미지를 만드는 방법
11192정성태5/2/201726120Windows: 140. unattended.xml/autounattend.xml 파일을 마련하는 방법
11191정성태5/2/201727006Windows: 139. Dell Venue 8 Pro 태블릿에 USB를 이용한 윈도우 운영체제 설치 방법
... 106  107  108  109  110  111  [112]  113  114  115  116  117  118  119  120  ...