inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

[연습문제] 이니셜라이저 리스트 , 대입연산자 오버로딩

해결된 질문

411

호두

작성한 질문수 85

2

안녕하세요?

이 경우에는 파라미터?로 이니셜라이저 리스트를 받으니까

1. 셀프 어사인먼트 방지하는 방법은 생각을 못했습니다.

    IntArray& operator=(const std::initializer_list<int>& list)
    {
        cout << "assignment operator" << endl;
        cout << "list.size() In assignment operator " << list.size() << endl;

        delete[] m_data;
        int length = list.size();

        m_data = new int[length];

        int count = 0;
        for (auto& element : list)
        {
            m_data[count] = element;
            ++count;
        }

        return *this;
   }

//IntArray(list.size()); // 생성자를 통한 초기화는 안되는거고

2. m_data가 데이터를 가지고 있을 수는 있으니까 지워주고 리스트의 길이만큼 new로 초기화해주고

리스트의 값을 복사해줬습니다.

교재인 learncpp에서 해당 부분을 찾아보니 다음과 같이 출력을 해야 한다더라고요.

그런데 리스트의 사이즈는 7인데 5개만 나왔습니다. 자고 일어나서 해결해보겠습니다. 

감사합니다.

<출력화면>

<전체코드>

// 9_12.cpp : This file contains the 'main' function. Program execution begins and ends there.
//

#include <iostream>
#include <cassert>
#include <initializer_list>

using namespace std;

class IntArray
{
private:
    unsigned m_length = 0;
    int* m_data = nullptr;

public:
    IntArray(unsigned length = 0)
        : m_length(length)
    {
        m_data = new int[length];
    }

    IntArray(const std::initializer_list<int>& list)
        : IntArray(list.size())
    {
        cout << "list.size() In constructor " << list.size() << endl;
        int count = 0;
        for (auto& element : list)
        {
            m_data[count] = element;
            ++count;
        }

        //for (unsigned count = 0; count < list.size(); ++count)
        //  m_data[count] = list[count];    // error

    }
    ~IntArray()
    {
        delete[] this->m_data;
    }

    IntArray& operator=(const std::initializer_list<int>& list)
    {
        cout << "assignment operator" << endl;
        cout << "list.size() In assignment operator " << list.size() << endl;

        delete[] m_data;
        int length = list.size();

        m_data = new int[length];

        int count = 0;
        for (auto& element : list)
        {
            m_data[count] = element;
            ++count;
        }

        return *this;
    }

    friend std::ostream& operator << (std::ostream& outconst IntArray& arr)
    {
        for (unsigned i = 0; i < arr.m_length; ++i)
            out << arr.m_data[i] << " ";
        out << endl;
        return out;
    }
};
int main()
{
    int my_arr1[5] = { 1,23,4,5 };
    int* my_arr2 = new int[5]{ 1,2,3,4,5 };

    auto il = { 102030 };

    IntArray int_array { 12345 };
    cout << int_array << endl;
    int_array = {7232165};
    cout << int_array << endl;
    

    return 0;
}


C++

답변 1

1

홍정모

:)

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

1

466

1

메모리 주소 10진수로 출력

1

653

1

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

1

499

1

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

1

534

1

메모리 주소에 관한 질분

0

679

1

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

0

549

1

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

0

443

1

Digit 뒤에 reference를 사용하는 이유

0

510

1

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

0

323

1

dat파일이...

0

539

1

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

0

644

1

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

0

454

1

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

1

390

1

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

0

561

1

마지막 예제 질문

0

302

1

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

0

375

1

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

1

411

1

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

0

312

1

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

0

447

1

3분 17초 질문

0

350

1

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

0

448

1

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

0

445

2

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

0

300

1

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

1

493

1