Microsoft MVP성태의 닷넷 이야기
[답변]: [답변]: [답변]: ASP의 ByVal과 ByRef 특성 [링크 복사], [링크+제목 복사],
조회: 11367
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기


이해하신 것을 정리한 것을 다시 따져 보겠습니다. ^^

  1. ByVal 키워드가 동작하여 Recordset 개체 자체는 의도한 바 그대로 복사본이 넘어갔다.
  2. 그러나 Recordset 개체 내부의 Connection 개체 참조는 여전히 원본 개체와 동일한 참조를 가리킨다.
  3. 따라서 사본 Recordset의 Connection 개체를 닫으면 원본 Connection 개체도 닫히게 된다.

Recordset 자체가 복사본이 넘어간 것이 아닙니다. 메모리에는 이미 Recordset에 대한 개체가 있고, 그 개체를 가리키는 포인터 변수가 있는 상황에서, byval로 넘기면 포인터 변수의 내용이 복사되어 스택에 전달되는 것이고, byref로 넘기면 해당 포인터 변수 자체의 주소가 복사되어 스택에 전달되는 것입니다. 그러니까, 둘다 동일한 RecordSet 개체를 가리키고 있는 것입니다.




질문하신 내용중에는 2번째는 해결하셨으니, 첫 번째 문제를 살펴보면.

1) Set objRecordSet_temp = objRecordSet
2) Set objRecordSet_temp = objRecordSet_temp.NextRecordset 

위에서의 문제를 역시 동일하게 바라보시면 될 것 같습니다. Set으로 인한 할당은 엄밀히 IUnknown::QueryInterface를 호출해서 내부적으로 해당 COM 개체에 대한 ref 카운트를 증가시키고 인터페이스 포인터 값의 복사본을 넘겨주는 것뿐입니다.

따라서, 첫 번째 Set 문의 경우에는 (.NET과 비교하자면) 단지 shallow copy 된 또 다른 별도의 "변수"가 추가된 것일 뿐, "원본 개체를 복사"해서 그 복사된 개체에 대한 인터페이스 포인터를 반환하는 것이 아닙니다.

그 후에 2번과 같은 과정을 거치니, 당연히 원본 Recordset 개체가 NextRecordset으로 되었으므로 Closed 상태로 되어 버리고, temp 변수의 경우에는 (현재 다음 레코드셋이 없는 것으로 보이므로) null 값을 보관하고 있게 되는 것입니다.




[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 6/26/2021]


비밀번호

댓글 작성자
 



2007-05-16 10시26분
그렇군요. 이제 확실히 이해한 것 같습니다.
저의 두 번째 예제가 제대로 동작했던 것도 어느 정도는 운이 좋았기 때문이었군요.
결국은 포인터에 대한 개념이해가 바탕이 되는 문제네요.
감사합니다. ^_^
songgun

... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1306이상현8/7/201410025Entity 프레임웍에서 테이블만 추가로 등록하는 방법
1307이상현8/7/201410326    답변글 [답변]: 자답이네요. [1]
1305popo8/7/201411589wpf UserControl List 바인딩 질문 입니다. [1]
1304민경수8/7/201414150네이버 카페에 구글 스프레드 시트 삽입 [1]
1303김동진8/7/201411386vmware환경에서 Guest IP를 192대역으로 받을 수 있는 방법은 없을까요~? [3]
1302김문경7/31/201410530스마트클라이언트 오라클 연결 [1]
1314이재균8/20/201410580    답변글 [답변]: 스마트클라이언트 오라클 연결
1300아로스7/28/201423441c# 인터넷 임시 파일 삭제 문의 [12]파일 다운로드1
1299서동원7/28/201412044안녕하세요. 혹시 Internet_Zone과 관련된문제인가 해서 질문드립니다. [1]
1298(non...7/25/201417415(글쓴이의 요청으로 삭제합니다.) [15]
1295서동원7/22/201413119안녕하세요. 스마트클라이언트에 대해 질문드립니다. [2]파일 다운로드1
1294(non...7/20/201411505(글쓴이의 요청으로 삭제합니다.) [2]
1293VS20...7/20/201412071VS2013 Ultimate에 Windows Phone 프로젝트 템플릿 추가 방법 문의 [1]파일 다운로드2
1292(non...7/20/201410840(글쓴이의 요청으로 삭제합니다.) [2]
1291zino7/16/201411429chromium 배포본 만들기~ [1]
1290(non...7/13/201412596(글쓴이의 요청으로 삭제합니다.) [3]
1288박주만7/8/201421761C# 서비스 기반 데이터베이스(mdf) & InstallShield Limited Edition 설치 및 배포 [2]파일 다운로드1
1287김용환7/8/201419764오라클 db 사용관련 문의입니다. [4]파일 다운로드1
1286C#조으다7/8/201410712WebBrowser 공유기 관리 웹 페이지 인증 [3]
1285C#조으다7/5/201411056IE DocumentComplete 이벤트가 발생되지 않습니다. [2]
1284(non...7/4/201411207(글쓴이의 요청으로 삭제합니다.) [3]
1283김영대7/3/201414297안녕하십니까 정성태님 죄송하지만 SmartClient 에 관한 질문이 있습니다. [9]
1282(non...7/2/201411164(글쓴이의 요청으로 삭제합니다.) [2]
1281(non...7/1/201412272(글쓴이의 요청으로 삭제합니다.) [4]
1280동동이6/25/201411475안녕하세요. ocx의 비동기 또는 쓰레드에서 호출 [1]
1279(non...6/23/201411551(글쓴이의 요청으로 삭제합니다.) [17]
... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...