Microsoft MVP성태의 닷넷 이야기
출력창에 '스레드가 종료되었습니다' 문구 문의 [링크 복사], [링크+제목 복사]
조회: 13454
글쓴 사람
이상준 (greatz613 at gmail.com)
홈페이지
첨부 파일

안녕하세요.

Task 궁금증이 생겨서 테스트 해봤는데 결과가 예상대로 나오지 않아서 문의드립니다.

제가 테스트한 예제 프로그램을 첨부합니다. WinForm이고 .NET Framework 4.8로 작성되었습니다.

버튼을 누르면 코드에 보시는 바와같이 Task 1개를 실행합니다.

제가 아는 Task는...

프로세스 당 단 1개의 ThreadPool이 생성되며, Task를 호출하게되면 ThreadPool에서 Thread를 할당받아 사용한 뒤 작업이 끝나면 ThreadPool에 반환되어,

다음 Task 작업 시 재사용한다고 알고 있습니다.

예제프로그램에서 버튼을 눌러 Task를 실행한 뒤, 작업이 끝나면

Visual Studio의 출력창에 조금 뒤...'스레드가 종료되었습니다' 문구가 여러 번 발생됩니다.

이 출력문구가 출력되는 횟수가 버튼을 누를때마다 다릅니다.

'스레드가 종료되었습니다'문구는 실제로 디버깅 중인 프로세스의 Thread가 종료되면 나오는 문구인가요?

만약 그렇다면 제가 1개를 사용하면 1개만 종료문구가 출력되어야하는데 왜 많이 출력될까요?








[최초 등록일: ]
[최종 수정일: 1/15/2020]


비밀번호

댓글 작성자
 



2020-01-15 08시07분
'스레드가 종료되었습니다' 문구는 실제로 스레드 종료를 알리는 것이 맞습니다. 1개의 스레드를 사용자가 생성했다고는 하지만 ThreadPool 제작자 입장에서는 그 1개의 생성을 미래의 또 다른 요청을 생각해 몇 개의 스레드를 더 만들 수도 있을 것입니다. 다음의 글도 함께 읽어보시다면 도움이 되실 것입니다.

ThreadPool.QueueUserWorkItem 의 실행 지연
; http://www.sysnet.pe.kr/2/0/1455

.NET 응용 프로그램에 기본 생성되는 스레드들에 대한 탐구
; http://www.sysnet.pe.kr/2/0/1247
정성태
2020-01-16 11시04분
[이상준] 아...[ThreadPool.QueueUserWorkItem 의 실행 지연] 이 글은 엄청 흥미있게 읽었습니다. ThreadPool에 대해서 더 알아가는 글이라 뿌듯합니다.
하지만 [.NET 응용 프로그램에 기본 생성되는 스레드들에 대한 탐구] 이 글을 보기엔 아직 GC 관련한 기본지식이 깔리지 않아서 좀 이해하기 어렵네요...
좋은 글 링크 감사드리고, 답변 역시 정말 감사드립니다!
[guest]

1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5646서형주4/6/20223893List에 여러개의 class 객체를 만들어 넣을때, 객체의 method들도 같이 생성되어 메모리를 차지하나요? [1]
5645김인태4/6/20223536윈도우즈 서버의 AD 계정 생성 조건이 있을까요? [1]
5644ㅇㅇ4/6/20224302c# 프로그램을 이용하여 리눅스상에 파일 생성이 가능한가요? [1]
5643유필재4/5/20224180TCP클라이언트 연결 및 통신관련하여 문의드려요 [1]
5642차가워4/4/20224423UdpClient 패킷 수신 문의 [4]
5641장성욱4/4/20224834코어 할당 및 cpu 부하테스트 질문 [7]
5640icoo...4/4/20224356웹가든에서 메모리 동적 업데이트 방법 [1]
5639차가워4/4/20224278c++ 서버 c# 클라이언트 호환 문의 [1]
5638초급4/3/20224580c# sql server 연동 [1]
5637따봉이4/1/20224845Winform Form Load 후 자동 캡쳐관련 [1]파일 다운로드1
5636김철순3/31/20224830WPF에서 Richtext의 View 문의 [5]
5635guest3/30/20224851안정적인 pinning이 가능하네요. [3]파일 다운로드1
5633꿀주세요3/30/20224484선생님 마우스 클릭이벤트 질문이 있습니다. [4]
5632김현수3/30/20224829Remote Desktop으로 접속시 WPF UI 가 다시 그려지는 이벤트를 막을 수 없을까요? [3]
5631김기헌3/24/20224457WPF 컨트롤의 그래픽 처리관련 질문드립니다 [2]파일 다운로드1
5630장성욱3/24/20224277로깅관련 질문입니다. [2]
5629감사합니...3/23/20224529함수에서 예외가 발생하면 try ~ catch처리기를 찾을 때 까지 상위 함수로 계속 올라가나요? [2]
5628홍길동3/23/20225171질문드립니다. [2]파일 다운로드1
5626연준혁3/21/20224417안녕하세요. [3]
5625jaew...3/18/20225350c# 8.0 도서를 구입한 사람입니다. [1]
5624초보자3/17/20224316람다 캡처 관련 문의 [2]
5623한예지 donator3/15/20224690인터프리터 원리가 궁금합니다. [4]
5622김민아3/8/20224608const와 readonly의 명확한 차이가 이게 맞나요? [2]
5621장성욱3/8/20224415c# 로그 관련 질문 [1]
5620김민아3/7/20224447안녕하세요 비관리 객체를 반환하는 메소드 호출 시 궁금한 점이 있어서 질문드립니다 [2]
5619팡팡이3/3/20225791RSA 문의드립니다. [3]
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...