Microsoft MVP성태의 닷넷 이야기
글쓴 사람
tky
홈페이지
첨부 파일
 

여러개의 버퍼의 내용을 압축한 데이터를 담는 스트림 클래스를 작성하고 있습니다.
스트림이다보니 Read, Write와 ReadAsync, WriteAsync메서드를 작성해야 하는데
멀티 스레드 처리를 하려 하는데 어떤 방식이 좋을지 몰라 질문드립니다.
현재는 동기 메서드는 멀티스레드 처리를 하지 않고 있고
Async 메서드는 여러 Task로 멀티 스레드를 하고 있습니다.

1. Task 사용
지금 Async 메서드에 사용하고 있는 방법입니다.
Task 배열에 tasks[i] = CompressAsync(...); 식으로 Task를 받아온 다음
await Task.WhenAll(tasks);로 끝날 때 까지 기다리는 방식입니다.

2. Parallel 사용
Parallel.Invoke를 통해 한번에 처리하는 방식입니다.

3. 새 스레드 생성
스레드를 생성하여 병렬 처리 한 뒤
CountdownEvent 등으로 기다리는 방법입니다.

4. ThreadPool 사용
위 방법에서 ThreadPool.QueueUserWorkItem을 사용하는 방법입니다.

일단 위 4개 방법을 생각해 보았는데... 어떤 방법이 제일 좋을지 질문드립니다.
그리고 SetLength등의 메서드에도 병렬 처리를 하는게 좋을지도 질문드립니다.








[최초 등록일: ]
[최종 수정일: 5/10/2022]


비밀번호

댓글 작성자
 



2022-05-10 12시08분
딱히 어떤 것을 선택해도 무방할 듯합니다. 어차피 3번을 제외하면 각각의 방법이 추상화 정도만 다를 뿐 모두 CLR ThreadPool을 사용하는 유형에 불과합니다. 물론 추상화 정도에 따라 성능 손실이 있겠지만 스트림을 처리하는 데이터의 크기나 작업량에 따라서는 거의 무시해도 좋을 것입니다. (3번을 택한다면 세세한 제어는 가능하겠지만 ThreadPool을 직접 구현해야 하는 불편함이 있을 것입니다.)

"SetLength 등..."이라고 했는데, 그 부분은 질문하신 분이 간단한 테스트를 해보고 필요 여부를 판단해야 하지 않을까요?
정성태
2022-05-10 08시27분
답변 감사드립니다. 그럼 코드는 기존과 같이 작성하고
SetLength 같은건 일단 병렬처리 한것과 아닌것 둘다 작성해볼게요
tky

... 61  [62]  63  64  65  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
1084김종하9/3/201218110team foundation express 2012에서 새 프로젝트 생성... [3]
1082김대경8/23/201216876windows2008 에서 ActiveX 사용 시 문제점. [3]
1091김대경9/20/201216983    답변글 [답변]: windows2008 에서 ActiveX 사용 시 문제점. [2]파일 다운로드1
1081Seon...8/20/201219088WCF 파일 업,다운로드 문제 [2]
1080배동선8/13/201218077정품 라이센스 인증 개발에 대해 조언을 구하고 싶습니다 [4]
1079송준호8/11/201215929basicHttpBinding stream 전송에 관하여 질문드립니다. [1]
1078Ho S...8/10/201214967윈도우폰 지도 구현에서 ㅠㅠㅠ 질문드립니다. [1]파일 다운로드1
1077한우주8/6/201217793웹서비스 호출 후 세션 유지하기 [1]
1076이성환8/2/201217785dynamic 변수 할당은 도대체 어디에???? [1]
1073pass...7/24/201217363c# 으로 만드는 음성인식/TTS 프로그램에 관련해서.. [3]
1072일반인7/23/201220010rss 만드는 방법 알려주실 수 있으신가요? [5]
1069임경훈7/20/201221262아래와 같은 오류후 IIS가 다운되는 현상이 발생합니다. [1]
1068신호철6/15/201219813ClassLibrary COM+ 등록 안되는 현상 [2]
1067김은주6/14/201229831소스세이프 사용시 pfx 파일 빌드 실패 [3]
1066너무초보6/3/201216323안녕하세요! 디렉토리 삭제 오류 질문 좀 드립니다. [4]
1065이성환5/23/201218319Assembly.LoadFrom Assembly.Load 의 차이점이 궁금합니다. [2]파일 다운로드1
1064푸우5/21/201217065GPU 디바이스 재시작시 WPF + .NET 3.5 기반 어플리케이션 UI 문제 [2]
1063발코더5/20/201216977귀신 곡할 상황 질문입니다. [3]
1062김규덕5/12/201217183ffmpeg 관련 조언 구합니다. [2]
1061Dave5/11/201216279언제 스크린 캡쳐 하시나요? [1]
1058정재훈5/11/201218054c#으로 동영상에 로고를 삽입하는 기능을 구현중입니다. [3]
1057전남진5/1/201216943** 몇일째 고생하다가 웹 검색을 통해 알게되어 질문드립니다.. 초보 질문이긴하지만 도움 부탁드려요 [2]
1056안현수5/1/201219034listview 와 웹파싱에관해 질문드립니다 [1]파일 다운로드1
1055이성환4/30/201217309WPF FramworkElement의 이벤트를 가져오고 싶습니다. [3]
1054정웅모4/20/201216249안녕하세요 [1]
1053폭풍코딩4/19/201216655스마트클라이언트 ctrl-c 복사가 작동하지 않습니다. [1]
... 61  [62]  63  64  65  66  67  68  69  70  71  72  73  74  75  ...