Microsoft MVP성태의 닷넷 이야기
file lock 관련 [링크 복사], [링크+제목 복사],
조회: 17315
글쓴 사람
임동찬 (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)
702clev...9/5/200714880    답변글 [답변]: Exe COM으로 만들면 혹시 Bridge dll없이도 권한 상승이 가능한가요?
695스마일8/30/200714893Visaul Studio 2005에서 디버깅이 안되요...ㅠㅠ [1]
694이호정8/29/200715065[CardSpace 관련 질문] 정리해 좋으신 글 잘 보았습니다.
698정성태9/1/200715183    답변글 [답변]: [CardSpace 관련 질문] 정리해 좋으신 글 잘 보았습니다.
704이호정9/6/200716203        답변글 답변해주신 내용 잘 봤습니다. ^_^b
705정성태9/6/200714495            답변글 [답변]: 답변해주신 내용 잘 봤습니다. ^_^b
706이호정9/7/200715256                답변글 후후... 이러다가 CardSpace 전용게시판 되는 것 아닌지 모르겠습니다. ^_^a;;
693장근배8/29/200714754매핑 구간이 열려 있습니다 [2]
710장근배9/17/200714486    답변글 [답변]: 매핑 구간이 열려 있습니다
692채영사랑8/29/200714359<질문> Ms stress tool 로 부하테스트중.
697정성태9/1/200714097    답변글 [답변]: <질문> Ms stress tool 로 부하테스트중. [1]
690한귀순8/28/200715152ClickOnce 배포 추가질문 [4]
689clev...8/27/200714407SmartClient에서도 Exe COM과 같이 여러곳에서 변수 공유가 가능한가요? [2]
688한귀순8/24/200716930ClickOnce 배포 [1]
686이상욱8/21/200715811[질문] VS.NET 2008 - WCF 를 위한 디버깅 환경 개선 테스트 중에
687정성태8/21/200714025    답변글 [답변]: [질문] VS.NET 2008 - WCF 를 위한 디버깅 환경 개선 테스트 중에
685김동진8/19/200716439Vista에서 WSDL관련 IIs7세팅 질문입니다. [4]
683조스7/31/200715699스마트 클라이언트에서 다른 어셈블리(.NET component) 사용시 에러 [1]
682정해봉7/30/200716716비스타에서 CAS설정하기... 소스 첨부 [1]파일 다운로드1
684정해봉8/14/200717502    답변글 [답변]: 비스타에서 CAS설정하기... 소스 첨부 [3]
681박희진7/27/200715266caspol로 설정된 권한집합 웹에서 읽어올 수 있나요?? [1]
680창민이7/27/200715976COM+등록시 에러 부분 때문에.. [2]
678정해봉7/24/200714870비스타에서 CAS 설정하기... [1]
677첫사랑7/24/200714116SSL에 관한 질문입니다.
679정성태7/26/200714710    답변글 [답변]: SSL에 관한 질문입니다. [1]
676kiuk7/11/200715094웹폐이지상의 이미지 상태 저장을 하고싶습니다. [1]
... 61  62  63  64  65  66  67  68  69  70  71  72  73  [74]  75  ...