Microsoft MVP성태의 닷넷 이야기
[답변]: [답변]: [답변]: ASP의 ByVal과 ByRef 특성 [링크 복사], [링크+제목 복사],
조회: 11346
글쓴 사람
정성태 (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)
5857guest3/17/20233041귀도 반 로썸을 보고 [4]
5856guest3/17/20233241Form1_FormClosing에 closing time을 Sqlite 저장하는 법? [6]파일 다운로드1
5855욜로3/17/20232804C# 메타데이터에서 불러오는 참조 정의가 안됨 [1]
5854민성3/16/20232983안녕하세요 asp.net mvc using문 관련하여 [1]
5853pa3/16/20233253오피스 2016 업데이트 후 파일 출력 불가 [1]
5852guest3/16/20232945입력 foreach 검색/출력 foreach [3]
5851guest3/15/20233261foreach내 list변경 [10]
5850독서가3/14/20232943C#에서 동적dll 사용시 문의입니다. [4]파일 다운로드1
5849guest3/9/20232923C# wpf로 Web에서 구동되는 hts가능한가요? (노트북없고 스마트폰 없음) [4]
5848민성3/9/20232831도움 요청드립니다. [2]파일 다운로드1
5847guest3/7/20233002SQlike Like 구문 - 1시간째 인데 안되네요 [13]
5846Huuu...3/7/20232657웹 다운로드에 대한 고찰 [5]파일 다운로드1
5845guest3/7/20232682C# Split함수의 불친절함 [1]
5844까망이3/7/20232812c# 무료 디컴파일러는 어떤게 좋습니까? [1]
5843guest3/7/20232789판매 후 dll 등 에러 [5]
5842kr13/6/20232811publish 할 때 분석기 관련 dll 제외 [5]
5841guest3/3/20233002프로그램 판매 시 - Upgrade 버전 판매 [2]
5840joe3/2/20233105C# 클래스 라이브러리 수정 -> C++에서 참조시 함수 목록 갱신되지 않음. [4]파일 다운로드1
5839guest3/2/20233741윈도우 서비스 프로그램 - FORM 애플리케이션 감시서비스 [8]
5838랄랄라3/1/20232940event 사용 시 두 표현의 차이점이 있을까요? [1]
5837감사합니...2/28/20233098오라클 DB서버 접속관련 문의 드립니다.(Load Balancing, HA Events) [2]
5836박지범2/27/20232885static instance의 initialize 순서가 보장되나요? [6]
5835주민호2/25/20235749Windows Software Development Kit - 최신버전 1개 남기고 다 삭제하면 안되는지요? [10]파일 다운로드1
5834guest2/24/20232951Python IDE - 비주얼스튜디오 [3]
5833무지남2/23/20232639Async 메서드 그리고 나서 Bool 메서드 [5]
5832김지우2/21/20232948event와 delegate의 차이 , event를 써야하는 이유 [1]
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...