Microsoft MVP성태의 닷넷 이야기
Task관련 질문입니다 [링크 복사], [링크+제목 복사]
조회: 561
글쓴 사람
정환맨
홈페이지
첨부 파일
 
안녕하세요 벌써 8.0을 출판하셨더군요. 7.3 산지 얼마 안됐는데ㅠㅠ

오늘은 질문 드릴것이 있습니다.

현재 배치프로그램내에서 각 Task를 생성(내부에서 try-catch 사용, 예외발생 빈도는 많음)해서 배열을 (.Net 4.0)
1. Task.WaitAll(배열리스트);
2. Task.Factory.ContinueWhenAll(배열리스트);
로 각각 실행했었습니다.

문제는 릴리즈로 돌릴때 continuewhenall에서는 배열내에서 예외가 몇번 발생하면 아예 continuwhenall 함수가 종료되어 버립니다.
그래서 지금은 1번인 waitall로 돌리긴 하는데 msdn에서는 continuewhenall로 하라고 되어 있었거든요(전임자가 짠 코드라 왜?의 역사는 알지 못합니다...)

그래서 waitall과 continuewhenall의 차이점을 알고 싶습니다.
둘다 task 배열을 돌리는 거면 왜 따로 분리되어 있는거죠??






[최초 등록일: ]
[최종 수정일: 11/18/2019 ]


비밀번호

댓글 쓴 사람
 



2019-11-18 08시57분
ContinueWhenAll에 인자를 하나만 넣었나요? 아래의 도움말에 보면,

TaskFactory.ContinueWhenAll 메서드
; https://docs.microsoft.com/ko-kr/dotnet/api/system.threading.tasks.taskfactory.continuewhenall?view=netframework-4.8

인자 하나가 들어가는 게 없는데요.

일단, 차이점만 말하자면, Task.WaitAll은 인자로 받은 task들이 모두 완료될 때까지 WaitAll을 호출한 측의 스레드가 중지하게 됩니다. 반면 ContinueWhenAll은 인자로 받은 task들이 모두 완료되었을 때 (원래 하나 더 받기로 되어 있는) 부가작업들을 수행하라는 "등록"만 하는 것이므로 ContinueWhenAll을 호출한 측의 스레드가 중지하지 않습니다.

다음과 같은 코드로 간단하게 테스트하면 차이점을 알 수 있을 것입니다.

static void Main(string[] args)
{
    Task<int> task = Task<int>.Factory.StartNew(() =>
    {
        Thread.Sleep(5000);
        Console.WriteLine("Task completed");
        return 0;
    });

    Console.WriteLine(DateTime.Now);
    Task.WaitAll(task);
    Console.WriteLine(DateTime.Now);

    Console.WriteLine(DateTime.Now);
    Task.Factory.ContinueWhenAll(new Task[] { task }, (obj) =>
    {
        Thread.Sleep(5000);
        Console.WriteLine("Task completed");
    });
    Console.WriteLine(DateTime.Now);

    Console.ReadLine();
}
정성태
2019-11-18 09시45분
[정환맨] 답변 감사드립니다.
ContinueWhenAll 은 두번째 인자에 완료동작 Action을 등록해서 사용했기에 제가 빼먹었었습니다(실수...)

그럼 UI에서 호출했다면 UI쓰레드가 블록되느냐 마느냐의 차이가 큰것 같은데,
그렇다면 많은 작업들이 등록되어 있다면 continuewhenall은 작업들을 내부적으로 돌리는 중에 ui는 사용 가능한것이므로 window를 close 해도 백그라운드에서 돌거나 하겠군요.

예외처리와 관련해서는 정확한 처리방식을 잘 모르겠습니다.
예외가 발생하면 중단되는것인지 그냥 통과되는것인지요. 따로 설정하거나 하는 부분이 있나요? 못본것 같아서요.
[손님]
2019-11-18 10시56분
뭔가 문제 정의를 정확하게 하셔야 할 것 같습니다.

WaitAll이든, ContinueWhenAll이든 전달되는 task 내부의 코드가 try/catch로 예외를 잡게 되어 있다면 문제될 것이 없습니다.
단지, WaitAll은 후처리를 WaitAll 다음의 코드에 했을 것이므로 UI 관련 접근 코드 등에서 자유로웠을 것이고, ContinueWhenAll의 경우 3번째 인자로 TaskContinuationOptions.ExecuteSynchronously 값을 주지 않았다면 Action 델리게이트의 코드가 UI 접근 시 예외가 발생했을 것입니다.

암튼, 문제를 정확하게 분리해 재현 가능한 최소한의 코드를 만들어 보세요.
정성태

1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5323나그네4/15/2020189해결 115p 네임스페이스의 ConsoleApp1.exe는 netcoreapp3.1 폴더에 있었습니다. [1]파일 다운로드1
5322나그네4/14/2020215질문 115p 네임스페이스의 ConsoleApp1.exe 컴파일 또는 빌드방법 [2]파일 다운로드1
5321나그네4/14/2020279오타인가요? [2]
5320kiki41224/10/2020484C# Serial 통신 관련 질문 입니다. [5]
5319권대현4/10/2020277C++(UWP)Dll에서 C#(UWP)Dll 호출이 가능한가요? [1]
5318이승준4/9/2020332동영상 관련 업계 근황? 입니다. [1]
5317kskku18114/7/2020260OpenCV 이용 해상도 설정 질문 입니다.. [3]
5316윤현수4/7/2020192pipe 비동기방식 질문 [1]파일 다운로드1
53154/6/2020230dll파일 로드 원리? 부분에서 도움받고싶습니다. [3]
5314강성욱3/31/2020568메서드 내에서 await 2번 등장할 때의 이해 [11]파일 다운로드1
5313강성욱3/27/2020332await 2번 [1]
53121a2a3a4a3/20/2020331Re raw data write 질문 관련 [1]파일 다운로드1
53111a2a3a4a3/20/2020331Raw data write 관련 질문 [1]파일 다운로드1
5310아스파넬3/15/20203191초에 5회 함수호출 제한 관련 질문입니다. [1]
5309하태3/11/2020588안녕하십니까. c# Winform UI 질문드리겠습니다! [3]파일 다운로드1
5308질문3/9/2020341Window XP SP3 32bit 환경(Window Update 모두 완료)에서 .Net Framework 4.0.3 으로 빌드된 .dll 파일 gacutil.exe 등록 관련 문의 [5]
5306개발자3/9/2020324C#을 통해 인터넷 접속 가능한 이더넷을 선택할 수 있는지요? [1]
5305JaeSSG3/9/2020342RAW파일 생성 질문드립니다 [8]파일 다운로드1
5303궁금하당2/27/2020449C#에서 C++ DLL읽기 (아래 글쓴이) [1]
5302궁금하당2/27/2020608C#에서 C++ DLL호출 ('PInvokeStackImbalance') [4]파일 다운로드1
5301질문합니다.2/27/2020389소켓 대량 데이터 디자인 문의 [1]
5300nalsandori2/27/2020344vs2013에서 BinaryFormatter Serialize 후 vs2015에서 Deserialize시 예외 발생 [3]파일 다운로드1
5298질문2/26/2020246.lic 파일에 대해 질문 있습니다. [9]
5297임한승2/26/2020142vs2013에서 BinaryFormatter Serialize 후 vs2015에서 Deserialize시 예외 발생 건 [1]파일 다운로드1
5295나그네2/25/2020314클라이언트 PC 정보 조회관련.. [2]
5294닷넷초보ㅠ2/25/2020250윈폼으로 socket통신프로그램 만든후 release로 디버깅한 실행파일을 다른컴퓨터에서 실행할때 반응이없어요 [1]
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...