Microsoft MVP성태의 닷넷 이야기
[답변]: [답변]: [답변]: ASP의 ByVal과 ByRef 특성 [링크 복사], [링크+제목 복사],
조회: 11341
글쓴 사람
정성태 (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)
5806스레드1/25/20233164총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
5805어웨이트1/25/20233024Taskcontinuewith vs Async/Await [2]파일 다운로드1
5804나이많은...1/25/20232893MS의 Dependency Injection(DI)에 AddSingleton으로 등록된 객체의 Event 등록후 사용시 앱 종료시 별도로 Event를 해지해야 하나요? [2]
5803dssc...1/24/20233120드라이브 문자를 통해서 물리 디스크 명칭을 알아내고 싶습니다. [1]
5802모바일앱1/22/20233000XAMARINE vs Android Studio [7]
5801블루투스1/19/20233733WPF 은행지폐계수기 개조 후 결과값 서버 전송 [2]파일 다운로드1
5800김민아1/19/20234079안녕하세요 가비지 컬렉터 동작 원리 중 궁금한점이 있습니다 [5]
5799guest1/19/20233210C# 공유폴더 내 Acess 디비 공유 [2]
5798kss1/19/20233004책 오탈인가요? [1]
5797이거비버1/19/20233078C# 공부 이후 MS 프레임워크.. 어느것을 공부해야할까요? 너무 많아서 정신이 없네요 [5]
5796guest1/19/20232793해킹 test [3]
5795동기1/18/20232630동기 스레드와 메서드와 While [2]
5794박규동1/18/20232612.net publish 할때마다 runtimeconfig 값이 바뀌는 현상 [1]
5793후후훗1/18/20232791.NET Core 에서 사용중인 함수 후킹 방법 [2]
5792Will...1/18/20232709소스코드 Log Write 기능을 리스트업 질문 [9]
5791PLC1/16/20233421C# - 실시간 5개 룸 모니터링 [15]
5790집으로 ...1/13/20233084[UI 멈춤 현상]deadlock 관련 글을 보고 혹시나 하고 문의 드립니다. [4]
5789guest1/10/20232976스레드와 Async Task [2]파일 다운로드1
5788kr11/10/20233437C# 에서 제공하는 컬렉션들의 차이점이 궁금합니다. [3]
5787stack1/10/20233219STACKOVERFLOW [1]
5786Dev ...1/9/20234095익명 클래스 말고 익명 구조체는 불가능한걸까요? [4]
5785음성인식1/8/20233683음성인식 System.Speech - 문법에 사용된 언어가 음성 인식기의 언어와 일치하지 않습니다. [2]
5784MS워드1/8/20233306MS워드에서 ctrl Z는 클립보드를 이용하나요? 아니면 참조자 이용하나요? [7]
5783구직자1/7/20233347C#개발자 구인광고와 초급개발자 [3]파일 다운로드1
5782Sqli...1/5/20233337윈도우11 노트북에서 exe(Sqlite)만들어 윈도우 7 PC에 설치 시 [5]
5781List맨1/5/20233859List.Add("newobj") 속도는 빠른 편인지요? [11]
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...