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
정성태

... 76  77  78  79  80  81  82  83  84  85  [86]  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
326권인성2/23/200611262    답변글 [답변]: 한가지만 더 질문할게요.... [1]
323정보문2/21/200611668메일 내용에서 한글이 깨집니다. [1]파일 다운로드1
321셈토2/18/200611525SPOOL --> EMF --> TEXTOUT [1]
320정보문2/18/200611250파일의 최대 크기2 [1]
318정보문2/18/200612384파일의 최대 크기
319정성태2/18/200612471    답변글 [답변]: 파일의 최대 크기 [1]
317narc...2/17/200611561[IE embeded SmartClient]에서 닷넷 리모팅 프록시 사용시 처음 2분간 딜레이현상이 발생합니다. [1]
322narc...2/20/200612397    답변글 [답변]: 다시한번 부탁드리겠습니다..
316이경찬2/15/200613827MSDN 매거진 정기구독 신청은 어디서 할수있나요? [1]
315정준명2/15/200617245[DxFramework Lite] 분산 트랜잭션에 참여하는 동안 오류가 발생했습니다. [2]
314이윤희2/14/200611461엑셀변환시....그림을 넣을려면. [1]
313장강현2/14/200611663SmartClient 디버그 문제 [1]
312정보문2/13/200611686방법2006 [1]
309정보문2/10/200612816edit & continue [3]
308김용국2/11/200611277스마트클라이언트 관련질문 [ Client 에서 WebPage의 JavaScript 호출방법이 있을까요? 있다고는 한것 같은데..부탁드림^^
310정성태2/11/200610759    답변글 [답변]: 스마트클라이언트 관련질문 [ Client 에서 WebPage의 JavaScript 호출방법이 있을까요? 있다고는 한것 같은데..부탁드림^^
307narc...2/10/200612532IE Embeded 스마트클라이언트는 UserControl만 가능한가요? [2]
305정보문2/10/200612631웹 컨트롤
306정성태2/10/200612218    답변글 [답변]: 웹 컨트롤
303정보문2/10/200613154회원가입성공을 기념으로 질문 한 가지 던집니다.
304정성태2/10/200611555    답변글 [답변]: 회원가입성공을 기념으로 질문 한 가지 던집니다.
302김성2/7/200612775C#이나 VB.NET 으로 만든 것을 SETUP 해서 배포하려고 하는데요.. [1]
301참깨2/3/200617028개체가 이 속성 또는 메소드를 지원하지 않습니다. [1]
300김종욱2/2/200611391안녕하세요 [2]
299꼬부기1/19/200610553스마트클라이언트 관련 질문입니다... [2]
298정말초짜1/12/200610815smart client 질문입니다. [1]
... 76  77  78  79  80  81  82  83  84  85  [86]  87  88  89  90  ...