TODO:대입 연산자 오버로딩에 대한 소스코드입니다.
#include <iostream>
#include <cassert>
#include <initializer_list> // std header file
using namespace std;
class IntArray
{
private:
int length_ = 0; //unsigned int는 32비트임
int* data_ = nullptr;
public:
IntArray(const int& length) : length_(length)
{
data_ = new int[length];
}
IntArray(const std::initializer_list<int>& list)
: IntArray(static_cast<int>(list.size())) // list의 size만큼 위임생성자가 호출됨
{
int count = 0; //count는 인덱스 기능
for (auto& element : list) // for-each구문에서는 initializer_list안의 iterator가 사용됨
{
data_[count] = element; // 아래의 operator<<에서 객체 출력을 위해
++count;
}
}
~IntArray()
{
delete[] data_;
}
//TODO: overload operator =
IntArray& operator= (const std::initializer_list<int>& copy)
{
cout << "Assignment operator" << endl;
length_ = copy.size();
delete[] data_; // 기존에 있던 리스트를 지움
/*if (this == copy)
return *this; */
if (data_ != nullptr)
{
data_ = new int[length_ + 1]; // 아래의 ++count때문에 +1해줘야함
int count = 0;
for (auto& e : copy)
{
data_[count] = e;
++count; //
}
}
else
data_ = nullptr;
return *this;
}
friend ostream& operator<< (ostream& os, const IntArray& arr)
{
for (int i = 0; i < arr.length_; i++)
os << arr.data_[i] << " ";
os << endl;
return os;
}
};
int main()
{
auto il = {2,4,6};
IntArray int_array{ 1,2,3,4,5,6,7,8,9,10 };//이니셜라이져 리스트로 인스턴스 생성
cout << int_array << endl;
int_array = { 1,3,5,7,9,11 };
cout << int_array << endl;
}부분 중, IntArray(const std::initializer_list<int>& list) : IntArray(static_cast<int>(list.size()))
를 static_cast로 바꿨는데도 아래와 같은 오류가 나네요. 환경설정을 64비트로 하고 보통 vs 소스코드를 짜는데요 int는 32비트라서 저런 오류가 뜰 수 밖에 없다고 하네요. 혹시 해결할 방법이 없을까요??

Câu trả lời 1
1
결국 타입을 맞춰주어야 할 것으로 보입니다.
IntArray 생성자의 인자 타입을 std::size_t로 변경하는 방법도 있습니다.
아래와 같이요:
perlCopy codeIntArray(const std::size_t& length) : length_(static_cast<int>(length))
{
data_ = new int[length_];
}
위와 같이 수정하면 IntArray 객체를 생성할 때 std::initializer_list의 크기를 사용하여 IntArray 객체를 생성할 수 있으며, 이를 이용한 대입 연산도 가능합니다.
0
음....그래도 C4267 오류가 나서 아예 int타입을 size_t로 바꾸었더니(int* data_도 size_t* data_로 변경했습니다) 오류가 나오지 않더군요. 그런데 64비트에서 32비트인 int타입을 이니셜라이져 리스트로 사용하는데 오히려 남는 메모리가 남아서 좋은거 아닌가요?
아니면 저 오류가 '64비트 데이터 타입을 사용할 경우 int로 선언하면 데이터 손실이 날 우려가 있습니다' 라는 메시지니까 공부하는 입장에서는 64비트를 사용할 일이 없으니 무시해도 되나요??
변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠
1
461
1
메모리 주소 10진수로 출력
1
650
1
클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.
1
496
1
여러가지 리턴 타입에 관한 강의가 어떤 걸까요?
1
529
1
메모리 주소에 관한 질분
0
676
1
인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.
0
546
1
형변환 오버로딩에서 const 관련 질문이 있습니다.
0
439
1
Digit 뒤에 reference를 사용하는 이유
0
504
1
4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결
0
319
1
dat파일이...
0
534
1
복사 생성자 관련 질문이 있습니다.
0
450
1
수업 중 궁금한점이 있습니다.
1
386
1
라이브러리자체가 이해가 되지 않습니다.
0
558
1
마지막 예제 질문
0
299
1
증감연산자 위치에 따른 수행 순서 질문입니다.
0
371
1
단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.
1
408
1
friend함수 관련 질문이 있습니다.
0
308
1
operator+ 정의부분에서 궁금한 것이 있습니다.
0
443
1
3분 17초 질문
0
346
1
함수에 값을 대입한다는 개념이 이해가 되지 않습니다.
0
443
1
int getvalue() const에서 const는 왜 뒤에 붙는건가요?
0
440
2
const Something &st에서 const를 빼면 안되나요?
0
296
1
friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??
1
489
1
연쇄호출에 대해 질문있습니다!
0
371
1

