Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일


COM 개체로 인해 IE 7 비스타 버전이 종료될 때 오류 화면이 뜬다면?

My Toolbar or BHO is Causing IE7 on Vista to Crash on Close. Help!
; https://docs.microsoft.com/en-us/archive/blogs/tonyschr/my-toolbar-or-bho-is-causing-ie7-on-vista-to-crash-on-close-help

코딩에서도, "형식 안정성"을 중요하게 여기는 것처럼, 점차로 마이크로소프트의 전반적인 제품군에서 "오류임에도 불구하고 덮어주던 방식"을 없애는 방향으로 가고 있는 것 같습니다. 위의 기사에서 언급하는 문제도 그와 같은 식이라고 볼 수 있겠지요.

CoInitialize() / CoUninitialize()의 쌍이 맞지 않는 경우에 IE 6까지는 그러한 실수를 감안하여 문제가 없도록 되어 있었는데, IE 7부터는 문제가 발생하게 되었다고 합니다. 만약, 여러분들의 프로그램에서 - 사실 별도의 스레드를 만들지 않는 한 CoInitialize() / CoUninitialize()를 호출할 일은 거의 없지만, 만약 사용하고 있다면 반드시 그 부분에 대한 호출 쌍이 맞는지 확인하셔야 할 것입니다.

그러면서, "IInitializeSpy" 인터페이스를 소개해 주고 있습니다. 어허... 제가 그동안 많이 무심했습니다. 이런 인터페이스가 있었는 줄 처음 알았으니까요. (Windows XP SP1부터 지원되었다고 합니다.) 이 인터페이스는 CoInitialize / CoUninitialize 메서드들이 호출될 때마다 Pre/Post 콜백 함수를 불려지는 것을 목적으로 정의된 것입니다.

테스트 삼아서 간단한 예제를 한번 작성해 보았습니다. (참고로, 위의 기사를 쓴 사람은 절대로 ActiveX 개발자들이 자신들의 CoInitialize() / CoUninitialize() 호출 쌍을 보정하기 위해 이 인터페이스를 구현하지 말라고 당부하고 있습니다.)

참고로, 아래의 예제에 대해 컴파일 가능한 VC++ 8 프로젝트파일은 첨부파일에 넣어두었습니다.

#include "stdafx.h"
#include <windows.h>
#include <objbase.h>
#include <objidl.h>

#pragma comment(lib, "ole32.lib")

class CInitializeSpy : public IInitializeSpy
{
public:
	CInitializeSpy()
	{
		dwCount = 0;
	}

	STDMETHOD(PreInitialize)(DWORD dwCoInit,DWORD dwCurThreadAptRefs)
	{
		::OutputDebugStr(L"PreInitialize\r\n");
		return S_OK;
	}

	STDMETHOD(PostInitialize)(HRESULT hrCoInit,DWORD dwCoInit,DWORD dwNewThreadAptRefs)
	{
		::OutputDebugStr(L"PostInitialize\r\n");
		return S_OK;
	}

	STDMETHOD(PreUninitialize)(DWORD dwCurThreadAptRefs)
	{
		::OutputDebugStr(L"PreUninitialize\r\n");
		return S_OK;
	}

	STDMETHOD(PostUninitialize)(DWORD dwNewThreadAptRefs)
	{
		::OutputDebugStr(L"PostUninitialize\r\n");
		return S_OK;
	}

	STDMETHOD(QueryInterface)(REFIID riid, void **ppvObject)
	{
		bool qied = false;

		if ( riid == IID_IUnknown)
		{
			*ppvObject = this;
			qied = true;
		}

		if ( riid == IID_IInitializeSpy)
		{
			*ppvObject = this;
			qied = true;
		}

		if ( qied == true )
		{
			dwCount ++;
			return S_OK;
		}

		return E_NOINTERFACE;
	}

	virtual ULONG STDMETHODCALLTYPE AddRef( void)
	{
		dwCount ++;
		return dwCount;
	}

	virtual ULONG STDMETHODCALLTYPE Release( void)
	{
		dwCount --;

		if ( dwCount == 0 )
		{
			delete this;
		}

		return dwCount;
	}

	DWORD dwCount;
};

int _tmain(int argc, _TCHAR* argv[])
{
	CInitializeSpy *pSpy = new CInitializeSpy();
	ULARGE_INTEGER ulCookie;

	CoRegisterInitializeSpy(pSpy, &ulCookie);

	CoInitialize(NULL);
	CoUninitialize();

	CoRevokeInitializeSpy(ulCookie);
	return 0;
}




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







[최초 등록일: ]
[최종 수정일: 7/9/2021]

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

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13929정성태5/16/202591오류 유형: 955. 파이썬 - "Windows embeddable package" REPL 환경에서 "NameError: name 'exit' is not defined"
13928정성태5/15/2025606오류 유형: 954. UFO² - "'Invalid URL (POST /v1/chat/completions/chat/completions)'"
13927정성태5/15/2025620오류 유형: 953. OpenAI - The API request of HOST_AGENT failed: OpenAI API request exceeded rate limit: Error code: 429
13926정성태5/14/20251021개발 환경 구성: 743. LLM과 윈도우의 만남 - Desktop AgentOS UFO² 기본 환경 구성
13925정성태5/12/20251228닷넷: 2333. C# - (Console 유형의 프로젝트에서) Clipboard 연동파일 다운로드1
13924정성태5/8/20251267닷넷: 2332. C# - (JetBrains Omea Reader 대상으로) 런타임 시에 메서드 가로채기 [2]파일 다운로드1
13923정성태5/5/20251125스크립트: 74. 파이썬 - C# - Python.NET의 RunSimpleScript, Exec, Eval 차이점파일 다운로드1
13922정성태5/3/20251260스크립트: 73. 파이썬 - Windows embeddable package 버전에서 tkinter 환경 구성
13921정성태5/3/20251527오류 유형: 952. 듀얼 채널 메모리 정렬을 지키지 않은 컴퓨터의 Windows 비정상 종료 현상(Blue Screen) [2]
13920정성태5/3/20251601오류 유형: 951. Typed DataSet 생성 중 "Failed to open a connection to the database" 오류
13919정성태5/2/20251444VS.NET IDE: 201. C# - Typed DataSet(XSD)를 위한 연결 문자열 암호화 [1]파일 다운로드1
13918정성태5/2/20251586VS.NET IDE: 200. C# - app.config 파일의 출력을 Configuration(Debug/Release)에 따라 제어하는 방법파일 다운로드1
13917정성태4/30/20251248VS.NET IDE: 199. Directory.Build.props에 정의한 속성에 대해 Condition 제약으로 값을 변경하는 방법
13916정성태4/23/20251083디버깅 기술: 221. WinDbg 분석 사례 - ASP.NET HttpCookieCollection을 다중 스레드에서 사용할 경우 무한 루프 현상 - 두 번째 이야기
13915정성태4/13/20252084닷넷: 2331. C# - 실행 시에 메서드 가로채기 (.NET 9)파일 다운로드1
13914정성태4/11/20252446디버깅 기술: 220. windbg 분석 사례 - x86 ASP.NET 웹 응용 프로그램의 CPU 100% 현상 (4)
13913정성태4/10/20251586오류 유형: 950. Process Explorer - 64비트 윈도우에서 32비트 프로세스의 덤프를 뜰 때 "Error writing dump file: Access is denied." 오류
13912정성태4/9/20251312닷넷: 2330. C# - 실행 시에 메서드 가로채기 (.NET 5 ~ .NET 8)파일 다운로드1
13911정성태4/8/20251600오류 유형: 949. WinDbg - .NET Core/5+ 응용 프로그램 디버깅 시 sos 확장을 자동으로 로드하지 못하는 문제
13910정성태4/8/20251763디버깅 기술: 219. WinDbg - 명령어 내에서 환경 변수 사용법
13909정성태4/7/20252655닷넷: 2329. C# - 실행 시에 메서드 가로채기 (.NET Framework 4.8)파일 다운로드1
13908정성태4/2/20252873닷넷: 2328. C# - MailKit: SMTP, POP3, IMAP 지원 라이브러리
13907정성태3/29/20252795VS.NET IDE: 198. (OneDrive, Dropbox 등의 공유 디렉터리에 있는) C# 프로젝트의 출력 경로 변경하기
13906정성태3/27/20252900닷넷: 2327. C# - 초기화되지 않은 메모리에 접근하는 버그?파일 다운로드1
13905정성태3/26/20252798Windows: 281. C++ - Windows / Critical Section의 안정화를 위해 도입된 "Keyed Event"파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...