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

... 76  77  78  79  80  81  82  83  84  85  86  87  88  89  [90]  ...
NoWriterDateCnt.TitleFile(s)
180최성우5/7/20056871[Q] POST 형식의 데이터 훅킹?
182정성태5/9/20057430    답변글 [답변]: [Q] POST 형식의 데이터 훅킹?
190최성우5/10/20056446        답변글 [답변]: [답변]: [Q] POST 형식의 데이터 훅킹?
177최정희5/4/20056859네트워크 케이블의 연결상태
178정성태5/4/20056924    답변글 [답변]: 네트워크 케이블의 연결상태 [1]
188최정희5/10/20056487        답변글 [답변]: [답변]: 네트워크 케이블의 연결상태
189정성태5/10/20056771            답변글 [답변]: [답변]: [답변]: 네트워크 케이블의 연결상태 [2]
191최정희5/11/20056403                답변글 [답변]: [답변]: [답변]: [답변]: 네트워크 케이블의 연결상태 [1]
175안연준5/3/20056379IE 제어에 대한 궁금 증 ㅡ,.ㅡ;;
179정성태5/4/20057230    답변글 [답변]: IE 제어에 대한 궁금 증 ㅡ,.ㅡ;;
168안연준5/2/20056659[Database] Connection Error파일 다운로드1
169정성태5/2/20056902    답변글 [답변]: [Database] Connection Error
170안연준5/2/20056522        답변글 [답변]: [답변]: 계속 에러가 똑같애요
171정성태5/2/20057217            답변글 [답변]: [답변]: [답변]: 계속 에러가 똑같애요
172안연준5/2/20056956                답변글 [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요파일 다운로드1
173정성태5/2/20056764                    답변글 [답변]: [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요
174안연준5/3/20056634                        답변글 [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요
165장희석4/22/20057220[질문]ASP에서 ATL 서버 컴퍼넌트로 바이너리 데이타 전달하기
167정성태4/29/20057055    답변글 [답변]: [질문]ASP에서 ATL 서버 컴퍼넌트로 바이너리 데이타 전달하기
160카심4/21/20056799Internet Explorer 에서의 닷넷 Smart Client 개발
163정성태4/22/20056819    답변글 [답변]: Internet Explorer 에서의 닷넷 Smart Client 개발
159신대철4/21/20056478자동 로긴 프로그램
162정성태4/22/20056486    답변글 [답변]: 자동 로긴 프로그램
166신대철4/22/20056276        답변글 [답변]: [답변]: 자동 로긴 프로그램파일 다운로드1
157이용휘4/20/20056223w3ip를 통해서 윈도우 미디어 화을을 올려놓을 서버..
158정성태4/20/20056671    답변글 [답변]: w3ip를 통해서 윈도우 미디어 화을을 올려놓을 서버..
... 76  77  78  79  80  81  82  83  84  85  86  87  88  89  [90]  ...