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

아래의 질문은 "dotnetguru("http://www.dotnetguru.co.kr/")에 올린 질문이었습니다. 도움이 되지 않을까 싶어서 제 홈페이지에도 올려 봅니다. ^^


다음은 managed 환경의 샘플 Type입니다.
public class CTest
{
public void CallMethod( string text1, string text2 )
{
if ( text1 == "Test" )
{
MessageBox.Show( "text1 == 'Test'" );
}

if ( text2 == "Test" )
{
MessageBox.Show( "text2 == 'Test'" );
}

}
}

이제 위의 모듈을 컴파일해서 나온 DLL을 tlbexp.exe로 TLB 파일을 생산해 내고.


다음은 unmanaged 환경에서의 VC++ 코딩입니다.

#import "TestLib.tlb" raw_interfaces_only

// CLR 호스트하고.
// Default Domain 로드하고.

// Default Domain에서 타입 로드하고.
pDefultDomain->CreateInstance( "TestLib", "TestLib.CTest", &pHandle );
pHandle->Unwrap( &v );
CComQIPtr<TestLib::_CTest> pLibrary = v.pdispVal;

// 인자 한 개는 SysAllocString으로 할당하고.
BSTR bstrTest = ::SysAllocString( L"Test" );
pLibraray->CallMethod( bstrTest, L"Test" ); // 또 다른 인자 한 개는 그냥 전달.

---------------------------------------------------------

위와 같이 실행하면, 정상적인 경우라면 MessageBox가 2번이 떠야 합니다.

"text1 == 'Test'"
"text2 == 'Test'"

실제 실행결과는, SysAllocString 후에 전달된 인자만이 "Test"와의 비교 시에 True가 나옵니다.

제가 뭔가 알지 못하는 Interop 관련 지식이 있는 걸까요?

(Managed인 경우 .NET 1.1(VS.NET 2003)이고, Unmanaged VC++은 VS.NET 2005에서 한 것입니다. Managed를 .NET 2.0으로는 테스트 안 해봤습니다. 비슷하지 않을까 싶어서.)






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

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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  [38]  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13022정성태3/31/202215495Windows: 202. 윈도우 11 업그레이드 - "PC Health Check"를 통과했지만 여전히 업그레이드가 안 되는 경우 해결책
13021정성태3/31/202217228Windows: 201. Windows - INF 파일을 이용한 장치 제거 방법
13020정성태3/30/202214807.NET Framework: 1187. RDP 접속 시 WPF UserControl의 Unloaded 이벤트 발생파일 다운로드1
13019정성태3/30/202216170.NET Framework: 1186. Win32 Message를 Code로부터 메시지 이름 자체를 텍스트로 구하고 싶다면?파일 다운로드1
13018정성태3/29/202216706.NET Framework: 1185. C# - Unsafe.AsPointer가 반환한 포인터는 pinning 상태일까요? [5]
13017정성태3/28/202214933.NET Framework: 1184. C# - GC Heap에 위치한 참조 개체의 주소를 알아내는 방법 - 두 번째 이야기 [3]
13016정성태3/27/202217472.NET Framework: 1183. C# 11에 추가된 ref 필드의 (우회) 구현 방법파일 다운로드1
13015정성태3/26/202219303.NET Framework: 1182. C# 11 - ref struct에 ref 필드를 허용 [1]
13014정성태3/23/202215928VC++: 155. CComPtr/CComQIPtr과 Conformance mode 옵션의 충돌 [1]
13013정성태3/22/202214162개발 환경 구성: 641. WSL 우분투 인스턴스에 파이썬 2.7 개발 환경 구성하는 방법
13012정성태3/21/202213986오류 유형: 803. C# - Local '...' or its members cannot have their address taken and be used inside an anonymous method or lambda expression
13011정성태3/21/202217775오류 유형: 802. 윈도우 운영체제에서 웹캠 카메라 인식이 안 되는 경우
13010정성태3/21/202213956오류 유형: 801. Oracle.ManagedDataAccess.Core - GetTypes 호출 시 "Could not load file or assembly 'System.DirectoryServices.Protocols...'" 오류
13009정성태3/20/202216666개발 환경 구성: 640. docker - ibmcom/db2 컨테이너 실행
13008정성태3/19/202216564VS.NET IDE: 176. 비주얼 스튜디오 - 솔루션 탐색기에서 프로젝트를 선택할 때 csproj 파일이 열리지 않도록 만드는 방법
13007정성태3/18/202214383.NET Framework: 1181. C# - Oracle.ManagedDataAccess의 Pool 및 그것의 연결 개체 수를 알아내는 방법파일 다운로드1
13006정성태3/17/202217206.NET Framework: 1180. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 remuxing.c 예제 포팅
13005정성태3/17/202215433오류 유형: 800. C# - System.InvalidOperationException: Late bound operations cannot be performed on fields with types for which Type.ContainsGenericParameters is true.
13004정성태3/16/202214962디버깅 기술: 182. windbg - 닷넷 메모리 덤프에서 AppDomain에 걸친 정적(static) 필드 값을 조사하는 방법
13003정성태3/15/202215265.NET Framework: 1179. C# - (.NET Framework를 위한) Oracle.ManagedDataAccess 패키지의 성능 카운터 설정 방법
13002정성태3/14/202216960.NET Framework: 1178. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 http_multiclient.c 예제 포팅
13001정성태3/13/202217538.NET Framework: 1177. C# - 닷넷에서 허용하는 메서드의 매개변수와 호출 인자의 최대 수
13000정성태3/12/202216261.NET Framework: 1176. C# - Oracle.ManagedDataAccess.Core의 성능 카운터 설정 방법
12999정성태3/10/202216444.NET Framework: 1175. Visual Studio - 프로젝트 또는 솔루션의 Clean 작업 시 응용 프로그램에서 생성한 파일을 함께 삭제파일 다운로드1
12998정성태3/10/202213898.NET Framework: 1174. C# - ELEMENT_TYPE_FNPTR 유형의 사용 예
12997정성태3/10/202224043오류 유형: 799. Oracle.ManagedDataAccess - "ORA-01882: timezone region not found" 오류가 발생하는 이유
... 31  32  33  34  35  36  37  [38]  39  40  41  42  43  44  45  ...