[c++] 이 문법이 맞는지 한 번 봐 주시겠습니까? 포인터.
글쓴이: assa / 작성시간: 화, 2006/01/10 - 3:25오후
#include <iostream> using namespace std; class aaa{ public: aaa(){ a= 0; b= 1; }; ~aaa(){}; int a; int b; }; void kkk(aaa &temp); int main(){ aaa t; cout << t.a << "\t" << t.b << endl; kkk(t); cout << t.a << "\t" << t.b << endl; return 0; } void kkk(aaa &temp){ aaa *k= new aaa; k->a= 1; k->b= 2; temp= *k; cout << temp.a << "\t" << temp.b << endl; }
문제로는 aaa a에 대해서 값을 넣고자 하는 것입니다.
그런데, 위의 소스대로 하면 값은 제대로 되는데 이것이 운이 좋아서(?)
인것인지 아니면 원래 이런 것인지 궁금합니다.
그리고 추가적으로 메모리 문제인데, 메모리 leak이 발생할 것 같은데.
VC 컴파일러로 볼 때는 leak이 발생하지 않네요. 컴파일러 자체의 문제인지.. 궁금합니다.
Forums:
Re: [c++] 이 문법이 맞는지 한 번 봐 주시겠습니까? 포인터.
값은 제대로 복사된 것입니다.
new를 하고 delete를 하지 않았으니 leak이 발생합니다. 다음과 같이 확인할 수 있습니다.
이렇게 고쳐서 디버거로 실행하면 디버그 출력창에 뭔가 출력될 겁니다. :-)
delete가 빠졌네요.이렇게 수정하시면 될듯합니다.[code:1
delete가 빠졌네요.
이렇게 수정하시면 될듯합니다.
delete 시킨 후에도 temp는 값이 유효한데요...
왜냐하면 temp 에 값복사( temp = *k )를 했기 때문입니다.
그런데 왜 k 라는 중간 변수를 사용하는지 모르겠네요...
k 없이 직접 temp.a = 1; temp.b = 2; 이렇게 하면 되지 않나요?
일하는 사람들의 희망 민주노동당 : http://www.kdlp.org
반공 교육의 성과로, 민주주의의 반대가 공산주의(또는 사회주의)라고 생각하는 사람이 많다.
Re: [c++] 이 문법이 맞는지 한 번 봐 주시겠습니까? 포인터.
오프 토픽이지만 생성자에서 초기화는 아래의 형태가 더 좋습니다.
나는 아래의 형태로 코딩합니다.
그리고 세미콜론(;)도 필요 이상으로 쓰시는 것 같습니다.
- 죠커's blog / HanIRC:#CN
댓글 달기