Microsoft MVP성태의 닷넷 이야기
file lock 관련 [링크 복사], [링크+제목 복사],
조회: 18006
글쓴 사람
임동찬 (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)
763단테4/17/200817204COM 객체 생성하는 방법
765정성태4/21/200817801    답변글 [답변]: CreateInstance를 부르시는 것이 추천됩니다.
762이민지4/16/200820905ClickOnce 실행 시 Internet Explorer 7.0에서 에러 메세지 출력 [1]
761이민지4/16/200817466ClickOnce로 배포를 하다가 생긴 문제에 대해 질문드립니다. [1]
760한귀순4/15/200818539DataSet 의 designer.cs [2]
759정성태4/14/200818942[데브피아 Q&A 모음] 2008-04-04 ~ 2008-04-12
7573/28/2008167332008 Server, Vista 에서 RDS 지원? [4]
756손승휘3/24/200820438Microsoft Web Browser OCX 부분이 안전하지 않는 ACTIVEX로 IE에서 인식되어는 점 [1]
754단테3/19/200817659실행파일의 아이콘을 프로그램 적으로 변경할 수 있을까요? [1]
753신동열3/12/200818357비스타의 권한 상승 관련 질문 있습니다. [2]
751김재영3/6/200817475스레드와 비스레드간의 대기상태 순서에 대해 질문이 있습니다. [2]파일 다운로드1
752정성태3/7/200817127    답변글 [답변]: 스레드와 비스레드 간의 대기 상태 순서에 대해 질문이 있습니다. [1]
750김용현3/3/200816563스마트 클라이언트로 파일 다운로드시 파일의 크기가 0인 경우가 발생합니다. [2]
749임영한2/28/2008318592003서버에서 msxml3.dll 오류 "80070005" 문제입니다. [2]
748류재상2/27/200821022Remoting , Tcp Channel 사용시.. 외부에서 접근 보안문제... [3]
747한귀순2/20/200819320WinForm - DataGridView 소계 등 [3]
746박상영2/20/200817222리모팅 관련해서 [3]파일 다운로드1
745조승현2/20/200817848Response.Charset ANSI로 설정..하는부분이 어려워서요.. [1]
744오야2/5/200816540멤버십, 웹파트등의 생성테이블과 업무테이블간의 관계를 어떻게.. [2]
743김기룡1/29/200818390동일 이미지 판단 방법 관련 [2]파일 다운로드1
740경혜원1/28/200819763C#에서 이런게 가능 할런지요?
742정성태1/29/200817789    답변글 [답변]: C#에서 이런게 가능 할런지요? [1]
738임경훈1/25/200818690웹서비스에서 오라클DB에 연결할 때
741임경훈1/28/200818190    답변글 [답변]: 웹서비스에서 오라클DB에 연결할 때 [1]
737단테1/25/200819769안녕하세요 정성태님. C Run-time Library의 배포에 대해서 질문있습니다. [3]
736김현기1/24/200817322XML 접두어 포함한 XmlElement 작성법? [1]
... 61  62  63  64  65  66  67  68  69  70  71  [72]  73  74  75  ...