Microsoft MVP성태의 닷넷 이야기
file lock 관련 [링크 복사], [링크+제목 복사],
조회: 12226
글쓴 사람
임동찬 (dngchn.im at samsung.com)
홈페이지
첨부 파일
 

안녕하세요.
질문있어 이렇게 또 찾아뵙니다.

아래와 같은 코드가 있습니다.

// C# 버전
void method_A
{
   object obj = apple.invoke(...); // type of obj == System.__ComObject
   IStream strm = (IStream)obj;
   strm.Read(...
   ...
   return;
}

// C++ 버전
void method_A
{
   CComVariant varStrm;
   apple.invoke(..., &varStrm);
   pIUnknownTest->QueryInterface(IID_IStream, (void**)&pIStreamTest)))
   pIStreamTest->Read(...
   ...
   return;
}

위의 C#, C++ 코드는 같은 기능을 하는 코드입니다.
apple.invoke는 외부 라이브러리를 이용하는 부분입니다.
이를 통해 리턴 받는 obj는 __ComObject 타입이구요. (C#버전)
이 obj가 로컬 파일시스템의 특정파일을 가리킵니다(?)
이를 IStream형으로 캐스팅해서 이용하는데요.

문제는 C++ 버전에서는 return 후에 연결된 특정 파일을
Close 해줍니다.
이에 대한 확인을 FileMon 유틸리티로 했는데요.
invoke하면 특정파일이 open되고 read됩니다.
그리고 return문을 떠나면 close됨을 FileMon의 로그를 통해 확인했습니다.

그런데 이를 C# 버전으로 실행시켜 보면,
return 문을 떠나도 close되지 않습니다.
이로 인해 다음 단계에서 해당파일에 대해 write해야하는데,
sharing violation문제가 발생합니다.
c++버전에서는 당연히 close되었으니 이후 write에서 문제 없구요.

이를 해결하기 위해 IStream으로 정의된 객체를 Close하려고 했으나,
Close 메서드도 없더라구요.

제가 생각해볼 수 있는 방안이,
첫번째는 C#에서 obj 또는 IStream으로 정의된 객체와 연결된 파일에 대해
어떻게든 close 시키는 방법,
두번째는 위 method_A를 실행 후에
무조건 해당파일의 lock을 풀어주는 코드를 삽입하는 방법이 있는데,
어떤게 나을지, 가능은 할지 모르겠네요.
아니면 다른 깔끔한 방법이 있을지...
이에 대해 정책임님 조언을 부탁드립니다.








[최초 등록일: ]
[최종 수정일: 10/15/2010]


비밀번호

댓글 작성자
 



2010-10-15 11시59분
일단, 원칙적으로 볼 때 C++이나 C#이나 동작방식은 같습니다.
따라서, 일단 해보는 데까지는 ^^ 그 원칙에 맞게 시도해보는 것이 더 좋을 것 같은데요. 소스 코드 전체가 아니라서 뭐라고 정확히 말씀드릴 수는 없지만, 대개의 경우 __ComObject 는 반드시 Release 해주는 것이 좋습니다. 이런 때 사용하는 것이 Marshal.ReleaseComObject 인데요. object obj = apple.invoke(...); 로 받은 것에 대해서 Marshal.ReleaseComObject(obj) 를 시도해보시고요. 소스에 나와있지 않은 부분에 대해 잠재적으로 C# 에서 AddRef되는 부분마다 COM 개체 사용후에 Marshal.ReleaseComObject 를 해주면 아마도 문제가 잘 해결될 것입니다. 해보시고 결과 좀 알려주세요. ^^
kevin25
2010-10-15 01시14분
[임동찬] 잘 되네요!
이 문제로 밤샐뻔 했어요.
주말 행복하시길...
[guest]

... 61  62  63  64  65  66  [67]  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
886김재영6/16/201011162스레드 선언시 (Parameterized/)ThreadStart에 정의되는 메소드의 위치에 질문이 있습니다. [3]
885장근배6/13/201018302Win32Exception 창 핸들 에러 [1]
883채동민6/10/201010758비동기 DB 쿼리관련 질문
884정성태6/10/201012074    답변글 [답변]: 비동기 DB 쿼리관련 질문
881최준영5/24/201011702load되지않은 아이템 load하는 방법? [1]
880임상일5/10/201013628VS2010 TestManager를 통한 UI Test 관련 질문입니다. [2]파일 다운로드1
879정용훈5/3/201014650wcf 인증 문제 [2]
878채동민4/20/201013796WCF에서 maxItemsInObjectGraph 오류 관련 질문드립니다. [2]
872날쌘돌이4/8/201016670Windows7 에서 IIS에서 폼인증 으로 디버깅.. [1]파일 다운로드1
871영초4/7/201011920실버라이트로 스캐너 구동 프로그램이 가능할까요? [1]
869김재영4/6/201010696이미 실행된 어셈블리 컨트롤 권한을 다른 어셈블리에서 가져올 수 있습니까? [2]
868Lime3/5/201014531WCF 에서의 DataTable 사용 [2]
867Dani...2/18/201014465Question - HTTP 401.3 on DELETE, PUT verbs [6]파일 다운로드1
865박근대2/16/201011287WCF 오류 문의. [1]
863날쌘돌이1/31/201014054ActiveX Cab에서 닷넷 dll 등록 [1]
862장근배1/28/201011326AppPolId를 알 수 있는 방법이 있는지요? [1]
864장근배2/1/201011166    답변글 [답변]: AppPolId를 알 수 있는 방법이 있는지요?
858생초보1/26/201011452안녕하세요.. 파일 생성 처리 문제로 .... [2]
857꼭지1/22/201016460How to support Basic + Windows authentication mode in WCF(RESTful service) [4]파일 다운로드2
856질의자1/13/201015077vcredist_x86 배포 관련 여쭙습니다. [1]
855임동찬1/13/201012945이벤트 핸들러와 쓰레드의 관계 2 [4]파일 다운로드2
854임동찬1/12/201012984이벤트 핸들러와 쓰레드의 관계 [1]
853장근배1/12/201012973압축 프로그램,, [1]
852임동찬1/6/201010760base.OnStart(agrs) [1]
851한귀순1/6/201016220oracle & transaction 질문 [5]
850박한주12/31/200913357COM과 C#간 권한 문제에 관해 여쭤봅니다. [5]
... 61  62  63  64  65  66  [67]  68  69  70  71  72  73  74  75  ...