inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

9.12 이니셜라이져 리스트 initializer list

9.12 연습문제 대입연산자 오버로딩

401

패러그래프

작성한 질문수 19

0

class IntArray

{

unsigned mLength = 0;

int *mData = nullptr;

public:

IntArray(unsigned length)

: mLength(length)

{

mData = new int[length];

}

~IntArray()

{

delete[]this->mData;

}

IntArray(const std::initializer_list<int> &list)

: IntArray(list.size())

{

int count = 0;

for ( auto &e : list )

{

mData[count] = e;

++count;

//count++로 쓰기도 함

}

}

//=operator

IntArray& operator=(const std::initializer_list<int> &array)

{

cout << "assignment operator" << endl;

delete[] mData;

mLength = array.size();

if(mData!=nullptr )

{

mData = new int[mLength];

int i {};

for ( auto &e : array )

{

mData[i++] = e;

}

}

else

{

mData = nullptr;

}

return *this;

}

};

int main()

{

intArray2 = {1,2,3,4,5,6,7,8,9,10};

cout << intArray << endl;

}

이런식으로 작성을 했는데 버퍼오버런이나옵니다

버퍼오버런이 사이즈가 m-1개인데 더 큰 데이터를 넣을 할 때 발생? 하는 거라고 검색해서 찾았는데 size()함수는 배열 갯수 -1을 반환하는 것은 아닌거 같은데..

 

https://learn.microsoft.com/ko-kr/cpp/standard-library/initializer-list-class?view=msvc-170

 

 

//=operator

IntArray& operator=(const std::initializer_list<int> &array)

{

cout << "assignment operator" << endl;

delete[] mData;

mLength = array.size();

if(mData!=nullptr )

{

mData = new int[mLength+1];

int i {};

for ( auto &e : array )

{

mData[i++] = e;

}

}

else

{

mData = nullptr;

}

return *this;

}

이렇게 1을 추가해주면 오버런이 발생하지 않아요

왜일까요....?? 디버거를 봐도 이해가 안됩니다

 

 

대입연산자 C++

답변 1

0

강민철

음..

일단 첨부해주신 예제 코드로 오류를 재현하기가 어렵습니다.

minchul@uftrace:~/workspace$ g++ test.cc
test.cc: In function ‘int main()’:
test.cc:90:9: error: ‘intArray2’ was not declared in this scope; did you mean ‘IntArray’?
   90 |         intArray2 = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
      |         ^~~~~~~~~
      |         IntArray
test.cc:92:17: error: ‘intArray’ was not declared in this scope; did you mean ‘IntArray’?
   92 |         cout << intArray << endl;
      |                 ^~~~~~~~
      |                 IntArray

 

전체 코드를 말씀해주시면 좀 더 정확히 봐드릴 수 있을 것 같습니다.

말씀해주신 내용만으로 판단해보자면

위 코드에서 혹시 mLength 변수가 0이 되지는 않는지 확인해보시길 바랍니다.

변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠

1

470

1

메모리 주소 10진수로 출력

1

655

1

클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.

1

502

1

여러가지 리턴 타입에 관한 강의가 어떤 걸까요?

1

535

1

메모리 주소에 관한 질분

0

679

1

인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.

0

553

1

형변환 오버로딩에서 const 관련 질문이 있습니다.

0

445

1

Digit 뒤에 reference를 사용하는 이유

0

510

1

4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결

0

324

1

dat파일이...

0

540

1

TODO:대입 연산자 오버로딩에 대한 소스코드입니다.

0

646

1

복사 생성자 관련 질문이 있습니다.

0

454

1

수업 중 궁금한점이 있습니다.

1

390

1

라이브러리자체가 이해가 되지 않습니다.

0

562

1

마지막 예제 질문

0

304

1

증감연산자 위치에 따른 수행 순서 질문입니다.

0

378

1

단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.

1

413

1

friend함수 관련 질문이 있습니다.

0

312

1

operator+ 정의부분에서 궁금한 것이 있습니다.

0

447

1

3분 17초 질문

0

352

1

함수에 값을 대입한다는 개념이 이해가 되지 않습니다.

0

448

1

int getvalue() const에서 const는 왜 뒤에 붙는건가요?

0

449

2

const Something &st에서 const를 빼면 안되나요?

0

301

1

friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??

1

494

1