Microsoft MVP성태의 닷넷 이야기
글쓴 사람
궁금맨
홈페이지
첨부 파일
 

정성태님 C# 10 책에 681쪽 맨 밑에 예제를 보면 스레드 ID를 출력하잖아요.


예제)

 Console.WriteLine("Before ReadAsync: " + Environment.CurrentManagedThreadId);

 await fs.ReadAsync(buf, 0, buf.Length);

 Console.WriteLine("After ReadAsync: " + Environment.CurrentManagedThreadId);

 당연히 성태님 말씀대로 스레드 ID가 무조건 다를 줄 알았는데 화면에

Before ReadAsync: 1
After ReadAsync: 1

 이렇게 계속 나와서

 이상해서
 여러 번 계속 반복 적으로 실행시켜야 그때 ID가 다르게 출력 되었습니다.

  await 키워드의 비동기 호출은 무조건 별도의 스레드 할당을 하는 게 아닌 건가요?
 컴퓨터의 상태에 따라 다른건지...
 궁금합니다.











[최초 등록일: ]
[최종 수정일: 1/28/2023]


비밀번호

댓글 작성자
 



2023-01-28 08시20분
질문해 주셔서 감사합니다. ^^

우선 예제를 바꿔야겠습니다. ^^; Windows의 ReadFile은 해당 파일을 빠르게 읽을 수 있는 상황이면 그냥 동기적으로 파일을 읽어 반환합니다. 그렇지 않은 경우에만 비동기로 실행을 합니다.

아무래도 해당 예제 코드로 지정한 HOSTS 파일의 크기가 (근래의 PC 성능으로는) 너무 작은 듯합니다. 일단 해당 파일명을 다음과 같이 바꿔주시면,

    "C:\windows\system32\drivers\etc\HOSTS"
    ==> "C:\windows\system32\drivers\etc\services"

정상적으로 동작할 것입니다.

--------------------------

그리고, 해당 예제는 "동기" 모드로 파일을 연 것을 "비동기"로 읽기 실행을 한 것입니다. 이 부분은 제가 실수한 것인데 정오표에 추가했으니 참고해 주세요.

도서: 시작하세요! C# 10 프로그래밍 - 정오표
; https://www.sysnet.pe.kr/2/0/13101#errata

이유는 자세하게 쓰진 못했지만 다음의 글을 통해 심도 있게 설명했으니 가볍게 읽어보시길 권장합니다.

C# - 닷넷에서의 진정한 비동기 호출을 가능케 하는 I/O 스레드 사용법
; https://www.sysnet.pe.kr/2/0/12250

C# - 파일의 비동기 처리 유무에 따른 스레드 상황
; https://www.sysnet.pe.kr/2/0/12251

---------------------------

참고로, await 이후의 코드가 비동기/동기로 실행되는 것은 100% 확정지을 수는 없습니다. 이에 대해서도 다음의 글을 통해 자세하게 설명했으니 역시 가볍게 읽어보시길 권장합니다.

C# - async/await 그리고 스레드 (1) MyTask로 재현
; https://www.sysnet.pe.kr/2/0/13055

C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용
; https://www.sysnet.pe.kr/2/0/13138
정성태

... 16  17  18  19  20  21  22  23  [24]  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5360진우7/28/202017315엑셀에서 발생하는 모든 이벤트를 감지 할수 있는지 궁금합니다. [6]파일 다운로드1
5358홍길동7/22/202015560개체에서 open 속성이나 매서드가 지원 되지 않읍니다.라고 오류창이 뜨는데. [1]
5357손동섭7/22/202016445책 예제코드... [3]
5355neska7/21/202015541안녕하세요 문의 드립니다 [1]
5354민성7/15/202018574안녕하세요 db연결 문자 보안 [2]
5353형성재7/14/202017264Visual Studio Setup Project에서 VC++2010재배포패키지설치 [4]
5352윤식7/10/202017929닷넷코어 빌드 시 runtimeconfig 파일을 없앨 수 있는지.. [4]
5351runr...7/2/202017655C# 에서 C++ dll 병렬 사용 [1]
5350홍성호6/29/202018901C++에서 정의된 구조체(공유메모리)를 C#으로 공유메모리에서 구조체 변환시 에러가 발생 합니다. [1]파일 다운로드1
5349jero...6/24/202015517logon credential provider 관련 문의드립니다. [1]
5348776/19/202015436시작하세요 C# 8.0프로그래밍 책에 대한 질문입니다. [8]
5347민성6/19/202015374안녕하세요 WPF Binding에서요 [1]
5346dimo...6/18/202016593Task.WhenAll() 메소드를 이용한 코드를 좀더 짧게 사용하고 싶은데 다른 표현이 있을까요? [3]
5345질문요6/12/202015330idc vs 집 속도 [2]
5344하태6/2/202016686c++ .ilb에서 c# dll 호출 질문 드리겠습니다 (콜백함수 전달) [4]
5343하태6/2/202020327안녕하십니까! c# dll을 c++ .lib에서 호출 질문 드립니다. [6]
5342진우5/30/202020837c++ 에서 C# DLL 사용 문의 [2]
5341미나리5/28/202016630스레드 lock키워드 관련 질문드립니다 [3]
5339민성5/27/202015597WPF cmd을 실행을 할때 파라미터 넘기는 방법 [1]
5338서영준5/26/202017115.Net Core Blazor 서버에 Xing API를 이용한 통신 요청 [5]파일 다운로드1
5337ogos...5/26/202017969C# DB connection string 보호 방법에 대하여 [2]
5336saki5/21/202018088이벤트 뷰어 .NET Runtime 오류 [3]
5335민성5/21/202015201안녕하세요 C#으로 컴퓨터 시작프로그램 목록을 가져와서 사용안함으로 바꿀려면 [1]
5334민성5/19/202016425안녕하세요 WPF 콘솔창을 띠우면서 Ping이라는 명령어가 콘솔에 Write되게 할려면 어떻게 해야 하나요?? [1]
5333초보5/18/202015467공유 메모리 관련 문의 [2]
5332질문요5/15/202015638TcpListener TcpClient 문의 [4]
... 16  17  18  19  20  21  22  23  [24]  25  26  27  28  29  30  ...