Microsoft MVP성태의 닷넷 이야기
[답변]: [답변]: [답변]: ASP의 ByVal과 ByRef 특성 [링크 복사], [링크+제목 복사],
조회: 11345
글쓴 사람
정성태 (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

1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5910guest4/24/20233468Async 메서드와 try~catch [1]
5909guest4/22/20233889Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/20233705텅빈 원그리기 [5]
5907민성4/21/20233344안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/20233479Dispatcher 서비스 구현 질문 [1]
5905guest4/20/20233815tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/20233754[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
5903guest4/18/20233172fileSystemWatcher 이벤트 관련 질문입니다 [2]
5902guest4/17/20233834c#으로 USB 관련 질문 [2]
5901guest4/17/20233373내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [5]
5900guest4/17/20234580DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [2]파일 다운로드1
5899guest4/17/20233484Dictionary와 Linq [4]
5898차가워4/17/20233351CNTK 교육 문의 [1]
5897guest4/17/20233262Socket스레드와 UI thread [4]
5896HAN4/16/20233255c언어 return 에 대해 궁금한게 있어요. [1]파일 다운로드1
5895guest4/15/20233009Drag and Drop - 모든 컨트롤 [2]
5894송부장4/14/20234428[질문] Visual Studio 2022에서 '도구 상자 항목 선택'의 'COM 구성 요소' 탭에서 ActiveX 목록이 보이지 않습니다. [3]파일 다운로드2
5893감사합니...4/14/20232997오라클 OLEDB방식 접속 후 SELECT 'TEST' TEST_VALUE FROM DUAL의 값이 이상합니다. [1]
5892한무4/14/20233188C# 으로 백그라운드에서 워드를 실행하여 매크로 실행이 가능 할까요? [2]
5891리세4/14/20233091안녕하세요.C# 서버프로그램에서의 Mysql 쿼리문제(다중쿼리 실행)에 대해 문의드립니다. [2]
5890guest4/14/20233731C# 프리랜서로 돈 벌려면 성태님 책 마스터하면 되나요? [6]
5889전예찬4/14/20232917C# 파일 복사 관련 질문 드립니다. [3]
5888정경구4/12/20233204C# 첫 환경 세팅과 관련해서 [4]
5887HAN4/12/20232828안녕하세요 파이썬도 공유 가능 할까요? [1]
5886guest4/11/20233218필요한 어셈블리만 다운로드 및 재로딩하는 방법에 관하여 [2]
5885guest4/11/20233055c#으로 드림위버같은 거 만들어볼려는데요 [6]
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...