Microsoft MVP성태의 닷넷 이야기
COM 개체 관련: 19. COM의 Apartment를 이해해 보자. [링크 복사], [링크+제목 복사],
조회: 22451
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

마침, COM 관련한 자료를 보고 나니 생각이 나는군요.

이번 토픽은 "문제"와 함께 풀어나가는 식으로 구성을 해보겠습니다.(음... 이런 식으로 토픽 쓰는 시간을 벌 수도 있군요. ^^;)
참고로, 이 문제를 푸실 수 있는 자격은, 저에게 최초로 ^^ "ATL 강의"를 들었던 "L" 업체분들을 제외하고 모두 가능합니다.

제 사이트에 오시는 분들이 대부분 .NET만을 하시는 분들임을 감안하면, 거의 답변이 안 달릴 것 같은데... ^^;



[Q1] COM의 Apartment에 대해서 많이 들어보셨을 것입니다. STA, MTA가 대표적인 예이지요.
그럼, 다음과 같은 STA에서 생성된 STA COM 개체를 전역 변수에 보관했다가 다른 STA 스레드에서 호출하면 어떨까요? 이 코드는 "예외 없이" 동작할까요?

환경:	SimpleObject COM 개체 - STA
		Console Application

ISimpleObjectPtr g_ptr;

int _tmain(int , char** )
{
	// STA 스레드에서 STA COM 개체를 생성
	CoInitializeEx( NULL, COINIT_APARTMENTTHREADED );
	{
		g_ptr = ISimpleObjectPtr( __uuidof( SimpleObject ) );
		g_ptr->MyMethod();
		
		DWORD dwAnotherThreadID;
		HANDLE hHandle = ::CreateThread( NULL, 0, AnotherThread, 0, 0, &dwAnotherThreadID );
		CloseHandle( hHandle );		
	}
	
	getchar();
	g_ptr = 0;
	CoUninitialize();
}

DWORD WINAPI AnotherThread( LPVOID lpParameter )
{
	// STA 스레드에서 전역 변수로 존재하는 STA COM 개체를 직접 호출
	CoInitializeEx( NULL, COINIT_APARTMENTTHREADED );
	g_ptr->MyMethod();
	CoUninitialize();

	return 0;
}



[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 8/19/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2006-10-10 11시33분
저도 문제에 도전해보고 싶은데, C++ 을 거의 몰라서... ^_^;;; 혹시 Thread Local Storage (TLS) 관련 문제인가요?
songgun
2006-10-10 11시58분
흔히들, "STA 개체는 스레드 간에 호출하려면 인터페이스 포인터를 마샬링해서 전달해야 된다고 알고 있습니다." 바로 이 문구가 정확한지 않은지 곱씹어 보는 의미에서 질문을 드리는 것입니다. ^^
kevin25
2006-10-12 09시49분
[텨텨텨] 예외란게 Exception을 말씀하시는 것인지 "항상" 이란 뜻인지 모르겠습니다만...

위 코드 조각만 봐서는 일단 '호출'을 하는 데는 아무런 문제가 없죠.
다만 다중 쓰레드의 동기화 관점에서 보면 오류 가능성을 가지고 있겠지요?
STA의 sematics 상 MyMethod()는 단일 쓰레드에 의해 호출된다고 스스로 가정할 수 있지만
위 코드는 동시에 두 쓰레드가 MyMethod() 호출이 가능한 상황이 연출 됩니다.
(마샬링 된 인터페이스 포인터를 전역 변수에 기록해 두어야만 오류 수정이 가능합니다.)

이거 너무 어려운 토픽을 잡으신듯....
저도 몇번 STA, MTA 토픽에 덤비려다 설명할게 너무 많아 포기했었다는...
(누구게? -_-;)
텨~텨~텨~~~
[guest]
2006-10-13 08시00분
유수석님... ^^ 예. 맞습니다. 제가 원하던 답이었습니다.
왜 이런 문제를 냈냐면요... ^^; "STA 개체는 스레드 간에 마샬링이 필요하다"라는 책의 내용만을 읽어온 분들이 "호출"조차도 안 되는 것으로 알고 있어서 직접 확인해 보시라고 내본 것입니다. 역시나 말씀하신 것처럼 동기화에 문제가 발생하지만요... ^^

솔직히 저도 사실 아직도 STA/MTA에 대한 메카니즘을 완전히 이해하지 못 해서 완벽하게 쓸 예정은 아닙니다. 단지 내부 수준까지는 아니더라도 "실용적인" 수준으로만 써보려고 합니다. ^^
kevin25
2006-10-13 08시24분
문제랑은 전현 상관없지만... ^_^;;;

'텨텨텨' 라는 아이디 보고 유경상님이라는 감이 바로 왔습니다.
아마 유경상님 블로그에 자주 가는 사람들은 말투만 보고서도 바로 눈치 채실듯...
songgun
2006-10-13 09시16분
[유경상] 단박에 알아내시다니... 너무 티를 냈나 보군요... -_-;
너무 버릇없이 글을 쓰지 않았나 걱정도 되고...
(실명을 밝히지 않고 장난한 거 죄송합니다... 너그러이 용서 해주세요... ^^)
[guest]
2006-10-13 10시11분
에이... ^^ 유수석님이라면 언제든지, 어떤 식으로든지 환영이옵니다.
kevin25
2015-10-21 12시38분
What is COM marshaling and how do I use it?
; https://devblogs.microsoft.com/oldnewthing/20151020-00/?p=91321

What are the rules for CoMarshalInterThreadInterfaceInStream and CoGetInterfaceAndReleaseStream?
; https://devblogs.microsoft.com/oldnewthing/20151021-00/?p=91311

What are the rules for CoMarshalInterface and CoUnmarshalInterface?
; https://devblogs.microsoft.com/oldnewthing/20151022-00/?p=91301

CoGetInterfaceAndReleaseStream does not mix with smart pointers
; https://devblogs.microsoft.com/oldnewthing/20151023-00/?p=91291
정성태

... 61  62  63  64  65  66  67  68  69  70  71  72  73  74  [75]  ...
NoWriterDateCnt.TitleFile(s)
12061정성태11/20/201919439Windows: 167. CoTaskMemAlloc/CoTaskMemFree과 윈도우 Heap의 관계
12060정성태11/20/201921048디버깅 기술: 132. windbg/Visual Studio - HeapFree x64의 동작 분석
12059정성태11/20/201920347디버깅 기술: 131. windbg/Visual Studio - HeapFree x86의 동작 분석
12058정성태11/19/201920919디버깅 기술: 130. windbg - CoTaskMemFree/FreeCoTaskMem에서 발생한 덤프 분석 사례
12057정성태11/18/201916743오류 유형: 579. Visual Studio - Memory 창에서 유효한 주소 영역임에도 "Unable to evaluate the expression." 오류 출력
12056정성태11/18/201922457개발 환경 구성: 464. "Microsoft Visual Studio Installer Projects" 프로젝트로 EXE 서명 및 MSI 파일 서명 방법파일 다운로드1
12055정성태11/17/201916548개발 환경 구성: 463. Visual Studio의 Ctrl + Alt + M, 1 (Memory 1) 등의 단축키가 동작하지 않는 경우
12054정성태11/15/201918178.NET Framework: 869. C# - 일부러 GC Heap을 깨뜨려 GC 수행 시 비정상 종료시키는 예제
12053정성태11/15/201919838Windows: 166. 윈도우 10 - 명령행 창(cmd.exe) 속성에 (DotumChe, GulimChe, GungsuhChe 등의) 한글 폰트가 없는 경우
12052정성태11/15/201918674오류 유형: 578. Azure - 일정(schedule)에 등록한 runbook이 1년 후 실행이 안 되는 문제(Reason - The key used is expired.)
12051정성태11/14/201922163개발 환경 구성: 462. 시작하자마자 비정상 종료하는 프로세스의 메모리 덤프 - procdump [1]
12050정성태11/14/201919723Windows: 165. AcLayers의 API 후킹과 FaultTolerantHeap
12049정성태11/13/201920230.NET Framework: 868. (닷넷 프로세스를 대상으로) 디버거 방식이 아닌 CLR Profiler를 이용해 procdump.exe 기능 구현
12048정성태11/12/201920378Windows: 164. GUID 이름의 볼륨에 해당하는 파티션을 찾는 방법
12047정성태11/12/201922688Windows: 163. 안전하게 eject시킨 USB 장치를 물리적인 재연결 없이 다시 인식시키는 방법
12046정성태10/29/201917193오류 유형: 577. windbg - The call to LoadLibrary(...\sos.dll) failed, Win32 error 0n193
12045정성태10/27/201917151오류 유형: 576. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 - 두 번째 이야기
12044정성태10/27/201916730오류 유형: 575. mstest.exe - System.Resources.MissingSatelliteAssemblyException: The satellite assembly named "Microsoft.VisualStudio.ProductKeyDialog.resources.dll, ..."
12043정성태10/27/201918310오류 유형: 574. Windows 10 설치 시 오류 - 0xC1900101 - 0x4001E
12042정성태10/26/201917952오류 유형: 573. OneDrive 하위에 위치한 Documents, Desktop 폴더에 대한 권한 변경 시 "Unable to display current owner"
12041정성태10/23/201918913오류 유형: 572. mstest.exe - The load test results database could not be opened.
12040정성태10/23/201919351오류 유형: 571. Unhandled Exception: System.Net.Mail.SmtpException: Transaction failed. The server response was: 5.2.0 STOREDRV.Submission.Exception:SendAsDeniedException.MapiExceptionSendAsDenied
12039정성태10/22/201916792스크립트: 16. cmd.exe의 for 문에서는 ERRORLEVEL이 설정되지 않는 문제
12038정성태10/17/201916891오류 유형: 570. SQL Server 2019 RC1 - SQL Client Connectivity SDK 설치 오류
12037정성태10/15/201924382.NET Framework: 867. C# - Encoding.Default 값을 바꿀 수 있을까요?파일 다운로드1
12036정성태10/14/201925534.NET Framework: 866. C# - 고성능이 필요한 환경에서 GC가 발생하지 않는 네이티브 힙 사용파일 다운로드1
... 61  62  63  64  65  66  67  68  69  70  71  72  73  74  [75]  ...