Microsoft MVP성태의 닷넷 이야기
COM 개체 관련: 19. COM의 Apartment를 이해해 보자. [링크 복사], [링크+제목 복사],
조회: 22275
글쓴 사람
정성태 (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
정성태

... 166  167  168  [169]  170  171  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
789정성태10/13/200927277COM 개체 관련: 22. BB FlashBack SDK와 ActiveX 버전 관리 [7]
786정성태10/9/200923530개발 환경 구성: 52. 테스트를 위한 평가판 운영체제 구하기
785정성태10/8/200930185.NET Framework: 165. WPF - UI 업데이트를 바로 반영하고 싶다면? (2)파일 다운로드1
783정성태10/7/200927929.NET Framework: 164. WPF - 데이터 바인딩된 트리에서 부모 노드 찾는 방법 [1]파일 다운로드1
782정성태10/6/200929778개발 환경 구성: 51. Windows 7 - 다중 원격 접속(Remote Desktop) 허용
781정성태9/30/200926836.NET Framework: 163. WPF - TreeView 자동 스크롤 기능 해지 [2]파일 다운로드1
780정성태9/28/200930899Windows: 48. Windows 7/2008에서 ping을 위한 echo 요청 열기 [2]
779정성태9/24/200922235.NET Framework: 162. WPF - 중첩된 ScrollViewer의 크기 제어 - 두 번째 이야기파일 다운로드1
778정성태9/23/200923664오류 유형: 87. 시스템 시간 변경 후 Session이 맺어진 WCF 클라이언트의 예외 발생파일 다운로드1
776정성태9/17/200922943개발 환경 구성: 50. Reference assembly
775정성태9/13/200939649VC++: 37. XmlCodeGenerator를 C/C++ 코드 생성에 적용 [2]파일 다운로드1
773정성태9/5/200930131오류 유형 : 85. DEP 비호환 ActiveX 오류
772정성태9/2/200926692.NET Framework: 161. WPF - 윈도우 이벤트 가로채기 [1]파일 다운로드1
771정성태8/28/200920724.NET Framework: 160. WPF - 입력 포커스 외곽선 없애는 방법
770정성태8/26/200923039.NET Framework: 159. WCF - 같은 컴퓨터에서만 WCF 요청을 서비스하도록 설정
769정성태8/25/200926062개발 환경 구성: 49. GAC와 같은 Namespace Extension에 의해서 보여지는 폴더의 원본 확인 방법
768정성태8/24/200925545오류 유형: 85. WCF 연결 오류: MessageSecurityException
767정성태8/23/200933792.NET Framework: 158. 닷넷 프로파일러 - IL 코드 재작성 [14]
766정성태8/23/200934745.NET Framework: 157. C# 4.0 - dynamic 키워드 [4]파일 다운로드1
765정성태8/22/200928515.NET Framework: 156. XamDataGrid의 UnboundField 사용파일 다운로드1
764정성태8/21/200922811Windows: 47. Windows Virtual PC에 설치된 Windows 7 VPC에서 Aero 효과 사용 [3]
763정성태8/20/200926427Windows: 46. Windows 7 - XP 모드 응용 프로그램 바로가기 만드는 방법 [2]
762정성태8/18/200932044개발 환경 구성: 48. 개발자 PC 환경 - 유니코드(Unicode)를 위한 설정 [3]
760정성태8/17/200938429개발 환경 구성: 47. XmlCodeGenerator 1.0.0.4 업데이트 [2]
759정성태8/16/200930235.NET Framework: 155. 닷넷 프로파일러의 또 다른 응용: Visual Studio 2010 Historical Debugging
758정성태8/15/200923525VS.NET IDE: 65. WPF 프로젝트용 Visual Studio 패치들 [2]
... 166  167  168  [169]  170  171  172  173  174  175  176  177  178  179  180  ...