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

안녕하세요 벌써 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 접근 시 예외가 발생했을 것입니다.

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

... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
343선재빠4/10/200614176아래와 같은 에러가 나네요.
341선재빠4/8/200613934테스트 페이지를 보면 프레임만 나오고 안에 내용이 나오지 않는군요 [1]
340김형태4/4/200612991파일서버 관련 질문드립니다.. (데브피아 답변에 이어) [2]
339조남정4/4/200613060post 주소 읽어오기 [1]
338장두헌4/4/200614693SDK PlatForm 다시 질문 - 데브피아의 내용 [1]
337강완모4/3/200614958Cab파일이 아닌 설치용 파일로 OCX들 설치하기... [1]
335비니3/23/200616185밑에 Smart Client에 대해서 질문했던 초보입니다.. TreeView컨트롤은 보이는데 안에 내용이 안보여요. [1]
336비니3/24/200613878    답변글 [재질문]:자꾸 죄송합니다...링크페이지로 이동을 안해요.... [1]
334비니3/23/200613605Smart Client강의 따라해보다가 xml에서 활성스키마는 <Tree>,<L> 요소는 지원하지 않는다고 나와요.ㅠㅠ [1]
332정준명3/21/200613633[자문자답] VS.NET에서 COM을 참조했는데, 강력한 서명이 없다고 사용불가네요.
333정성태3/22/200612000    답변글 [답변]: [자문자답] VS.NET에서 COM을 참조했는데, 강력한 서명이 없다고 사용불가네요. [1]
330심현철3/3/200615251[질문] VS2005에서 C#으로 개발한 DLL을 Javascript에서 접근할 수 없습니다. (ActiveX with C#) [2]
329권인성2/27/200613043스마트클라이언트(clickonce) 버전관리 [1]
327권인성2/24/200612986clickonce를 통해 설치 및 업데이트하려고 하는데요...보안때문에요..
331정성태3/12/200613990    답변글 [답변]: clickonce를 통해 설치 및 업데이트하려고 하는데요...보안때문에요..
325권인성2/23/200612583SETUP 및 배포관련 [1]
326권인성2/23/200612148    답변글 [답변]: 한가지만 더 질문할게요.... [1]
323정보문2/21/200612622메일 내용에서 한글이 깨집니다. [1]파일 다운로드1
321셈토2/18/200612363SPOOL --> EMF --> TEXTOUT [1]
320정보문2/18/200612099파일의 최대 크기2 [1]
318정보문2/18/200613221파일의 최대 크기
319정성태2/18/200613278    답변글 [답변]: 파일의 최대 크기 [1]
317narc...2/17/200612343[IE embeded SmartClient]에서 닷넷 리모팅 프록시 사용시 처음 2분간 딜레이현상이 발생합니다. [1]
322narc...2/20/200613184    답변글 [답변]: 다시한번 부탁드리겠습니다..
316이경찬2/15/200614738MSDN 매거진 정기구독 신청은 어디서 할수있나요? [1]
315정준명2/15/200618067[DxFramework Lite] 분산 트랜잭션에 참여하는 동안 오류가 발생했습니다. [2]
... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...