Microsoft MVP성태의 닷넷 이야기
file lock 관련 [링크 복사], [링크+제목 복사],
조회: 12247
글쓴 사람
임동찬 (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]

1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5832김지우2/21/20233230event와 delegate의 차이 , event를 써야하는 이유 [1]
5831이우람2/20/20233467ref 전역변수가 pinned가 될수 있나요? [2]
5830냉수마찰2/19/20233639C# GridView에 Column별 데이터 추가하는 방법에 대해 [1]
5829수박942/19/20233695키움 API를 윈폼과 WPF의 네임스페이스 없이 콘솔이나 WinUI3에서 사용할 수 있는 방법이 있나요? [2]파일 다운로드1
5828김재영2/19/20233551장기적으로는 this 구문을 안쓰는게 맞을까요? [2]
5827lee2/18/20233483파이썬 설치 오류 질문입니다 [1]
5826Syong2/14/20233986Socket 관련 Leak (OverlappedAsyncResult, OverlappedData) 관련 문의 [7]파일 다운로드1
5825박성원2/14/20233626Listview 컨트롤의 화면 전환 시 갱신 속도 [1]
5823검은콩2/13/20234163catch(Exception ex)의 line번호를 쉽게 알 수 없는지요? [7]
5822김지우2/11/20233434책을 보면서 sync, async 이해가 되지 않는 부분이 있습니다. [5]파일 다운로드2
5821검은콩2/9/20233454Async 신뢰성과 소켓데이터 [4]
5820차가워2/8/20233639다른 프로세스 실행 후 포커스 가져오기 [3]
5819취준생2/7/20233667WPF 관련 실무가 궁금합니다. [3]
5818윤길2/7/20233077ObservableCollection 에서 INotifyPropertyChanged 구현해야하나요? [2]
5817흰털너부리2/7/20233244배포 시 winform 실행 콘솔로그 보는 방법 [1]
5816흰털너부리2/6/20233063.net core json array validation 질문 드립니다. [1]
5815김재영2/6/20233191종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [2]
5814한예지 donator2/6/20233573decompile? [9]
5813김재영2/5/20233389openssl genrsa 2048시 키 생성이 다르게 됩니다. - 파일첨부 [4]파일 다운로드1
5812김재영2/5/20233606openssl genrsa 2048시 키 생성이 다르게 됩니다. [2]
5811치르바2/3/20233511MiniDumpWriteDump API로 덤프수집을 했는데요.. [3]
5810이건우1/31/20233643윈도우서비스를 통한 웹통신관련 질문입니다 [3]
5809이상훈1/31/20234025다채널 영상 디스플레이어 개발 관련 질문입니다. [3]
5808근우1/30/20233727WPF 에서 UserControl 과 ControlTemplate 의 차이점은 무엇인가요? [6]
5807궁금맨1/28/20234864C# 10 책에 나온 예제의 결과가 제 컴에서는 좀 달라서요. 이유가 궁금합니다. [1]
5806스레드1/25/20233453총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...