Microsoft MVP성태의 닷넷 이야기
Task관련 질문입니다 [링크 복사], [링크+제목 복사],
조회: 7891
글쓴 사람
정환맨
홈페이지
첨부 파일
 

안녕하세요 벌써 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 해도 백그라운드에서 돌거나 하겠군요.

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

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

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

... 46  [47]  48  49  50  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
3667김치사발면12/15/201511076템플릿 설정 추가 질문 [1]파일 다운로드1
3666노태현12/15/201510492사용자별로 권한을 주고 볼 수 있는 데이터를 제한하려면 어떤 방법으로 접근하는게 좋을까요? [2]
3665김치사발면12/14/201513590C# 템플릿 설정이 이상해요ㅜㅜ [3]파일 다운로드1
3664KuLu12/10/201510880멀정하던 사이트 중 일부메뉴가 응답없음이 되어버립니다. [3]
3663Sung...12/10/201512247UWP 서버 프로그래밍 작업 중 [5]
3662Sung...12/9/201512093uwp앱에서 접속한 클라이언트 주소값을 받아서 표시하고 싶은데 어떤 메소드를 써야 할까요? [7]
3661김무진12/9/201511429Oracle 환경에서 데이터를 조회할때 한글이 ? 이렇게 표시가됩니다. [1]
3660질문자12/7/201513366OpenFileDialog 호출시 hang걸리는 문제 [4]
3659Sung...12/4/201513012UWP 앱에서 textBox로 클라에서 받은 값을 나타내고 싶은데 안되고 있습니다. [5]
3658강준12/3/201512253Visual Studio (Xamarin) vs Eclipse [2]
3656DEVY...12/1/201511172MasterPageFile 사용시 다국어 처리 질문입니다. [1]
3653DEVY...11/26/201512638ds:Signature 질문입니다. [7]
3654윤용한11/27/201512366    답변글 [답변]: ds:Signature 질문입니다. [3]
3657윤용한12/1/201514669    답변글 [답변]: ds:Signature 질문입니다. [1]
3651노태현11/20/201545371MariaDB - ASP.NET오류의 원인조차 못 찾고 있습니다.. [2]파일 다운로드2
3652노태현11/20/201512251    답변글 [답변]: MariaDB - ASP.NET오류의 원인조차 못 찾고 있습니다.. [3]
3649kokon11/17/201512661예제 파일 실행이 안 되네요 [5]
3647Sang...11/15/201511191Part 3 목차? [5]
3646힘찬도약11/13/201516051c# mscorlib System.IO IOException [8]파일 다운로드2
3644힘찬도약11/11/201515189c# user.config파일 [2]
3645spow...11/13/201512172    답변글 [답변]: c# user.config파일 - Json.NET을 이용한 설정파일 처리 [1]파일 다운로드1
3643힘찬도약11/11/201513967C# 함수의 processing time과 재호출 [14]
3642.net11/10/201512651c# 으로 작성된 com+ 에 대한 문제입니다. [2]
3641힘참도약11/9/201513105c# log file 관련해서 질문드립니다. [5]
3638윤창선11/4/201513667사설IP가 부여된 무선라우터간 영상전송 관련 문의 [8]
3634Hyun...11/2/201511202c# 에서 webkit browser에서 webgl을 이용하는 사이트에 접속이 안됩니다. [1]
... 46  [47]  48  49  50  51  52  53  54  55  56  57  58  59  60  ...