강의

멘토링

로드맵

인프런 커뮤니티 질문&답변

홍재윤님의 프로필 이미지
홍재윤

작성한 질문수

홍정모의 따라하며 배우는 C++

9.11 대입 연산자 오버로딩, 깊은 복사, 얕은 복사

대입연산자 오버로딩 리턴형

작성

·

480

1

클래스내에 deep copy를 하는 복사 생성자와 

deep copy를 하는 대입연산자가 있다면

deep copy를 한다는 측면에서는 기능이 갔다고볼수있습니다.

대입연산자를 오버로드 할때 카피생성자 처럼

리턴형이 없이 void operator= (....) 해도

데이터를 복사하는 데에는 이상이 없는데

레퍼런스로 리턴해주는 이유라도있나요?

코드도 첨부합니다

class String

{

private:

char* m_data = nullptr;

unsigned m_length = 0;

public:

String()

{}

String(const char* source)

{

//assert(source);

m_length = strlen(source) + 1;

m_data = new char[m_length];

data_copy(source);

}

String(const String& source)

{

cout << "카피생성자" << endl;

deep_copy(source);

}

String& operator=(const String& source)

{

cout << "대입연산자" << endl;

if (m_data == source.m_data) return *this;

delete[] m_data;

deep_copy(source);

return *this;

}

void deep_copy(const String& source)

{

m_length = source.m_length;

if (source.m_data != nullptr)

{

m_data = new char[m_length];

data_copy(source.m_data);

}

else m_data = nullptr;

}

void data_copy(const char* source)

{

for (unsigned i = 0; i < m_length; ++i)

{

m_data[i] = source[i];

}

}

};

퀴즈

66%나 틀려요. 한번 도전해보세요!

사용자 정의 타입에 대해 연산자 오버로딩을 하는 주된 목적은 무엇일까요?

코드 실행 속도를 빠르게 하기 위해

사용자 정의 타입을 내장 타입처럼 자연스럽게 사용하기 위해

객체의 메모리 관리를 자동화하기 위해

클래스의 상속 관계를 정의하기 위해

답변 1

3

원래 대입연산자 자체가 리턴이 있는 연산자입니다.

a = b = 3

라는 식이 있다면 b = 3 라는 대입 연산식에서 b 를 리턴하기 때문에 이어서 a = b 를 할 수 있게 됩니다.

대입과 동시에 리턴을 하도록 return a = 2; 이런식으로 함수 코드를 짜기도 해요!

대입 연산자 오버로딩시 void 로 할지 리턴을 넣을지는 프로그래머 마음입니다. 그치만 대입연산자 자체가 원래 리턴이 있는 연산자이기 때문에 강의에서 코드를 저렇게 진행하신게 아닐까 싶네요~

홍재윤님의 프로필 이미지
홍재윤
질문자

답변 감사합니다.

홍재윤님의 프로필 이미지
홍재윤

작성한 질문수

질문하기