컴공 일기261
게시글 주소: https://ys.orbi.kr/00070988182
- 동적 배열을 즉석에서 한번 구현해봤습니다.
이동시맨틱, 대입연산, 복사생성, …, 자료출력 등등 구현을 했습니다만
결정적으로 l-value [] 연산을 지원을 안하고 있습니다.
따라서, 객체가 생성될 때 극한의 효율로 생성이 되게 했고, 자료 출력도 가능하게 했습니다만
사용자 코드 쪽에서 동적 배열 객체의 값들을 초기화해서 사용할 수 있도록 [] 연산에 대한 오버로딩을 해줘야 합니다.
간단하지만 그건 시간이 늦은 관계로 내일… 하겠습니다.
이동시맨틱 연습 겸 짜본 코드지요…
자고로, 여기에서 탬플릿과 상속을 조금 더 추가해 봄 직 합니다.
며칠 간은 계속 손을 볼 예제죠. 아직 미완성입니다.
극한의 추상성을 제공해보려고요.
vector STL 흉내 내보겠다는 건데,
객체지향 프로그래밍 공부할 때 이 자세가 중요하지 않나 생각합니다.
흉내를 우선 낼 줄 알아야, 창조를 할 수 있는 거니까요.
#pragma once
#include <iostream>
using namespace std;
class dynamic_array
{
public:
dynamic_array() = default;
explicit dynamic_array(int n);
dynamic_array(const dynamic_array&);
dynamic_array(dynamic_array&&) noexcept;
int* begin() const;
int* end() const;
const int getSize() const;
void PrintData() const;
int operator[] (const int index) const;
dynamic_array operator+(const dynamic_array&);
dynamic_array& operator=(const dynamic_array&);
dynamic_array& operator=(dynamic_array&&) noexcept;
~dynamic_array();
private:
int* data = nullptr;
int size = 0;
};
dynamic_array::dynamic_array(int n)
{
cout << "dynamic_array(int)" << endl;
data = new int[n];
size = n;
}
dynamic_array::dynamic_array(const dynamic_array& rhs)
{
cout << "dynamic_array(const dynamic_array&)" << endl;
this->size = rhs.getSize();
data = new int[size];
for(int i=0; i<size; i++)
{
data[i] = rhs.data[i];
}
}
dynamic_array::dynamic_array(dynamic_array&& rhs) noexcept
{
cout << "dynamic_array(dynamic_array&&)" << endl;
//의도적인 shallow copy
this->data = rhs.data;
this->size = rhs.getSize();
rhs.data = nullptr;
rhs.size = 0;
}
dynamic_array::~dynamic_array()
{
delete[] data;
}
int* dynamic_array::begin() const
{
return data;
}
int* dynamic_array::end() const
{
return data+size;
}
const int dynamic_array::getSize() const
{
return size;
}
void dynamic_array::PrintData() const
{
for(int i=0; i<this->getSize(); i++)
{
cout << this->data[i] << " ";
}
cout << endl;
}
int dynamic_array::operator[](const int index) const
{
if(index < 0 || index >= this->getSize())
{
cout << "Invalid Index!!" << endl;
exit(-1);
}
return this->data[index];
}
dynamic_array dynamic_array::operator+(const dynamic_array& rhs)
{
dynamic_array retVal(this->getSize() + rhs.getSize());
copy(this->begin(), this->end(), retVal.begin());
copy(rhs.begin(), rhs.end(), retVal.begin() + this->getSize());
return std::move(retVal);
}
dynamic_array& dynamic_array::operator=(const dynamic_array& rhs)
{
cout << "dynamic_array::operator=(dynamic_array&)" << endl;
if(data != nullptr)
delete[] data;
data = new int[rhs.getSize()];
for(int i=0; i<rhs.getSize(); i++)
{
data[i] = rhs[i];
}
size = rhs.getSize();
return *this;
}
dynamic_array& dynamic_array::operator=(dynamic_array&& rhs) noexcept
{
cout << "dynamic_array::operator=(dynamic_array&&)" << endl;
if (this != &rhs) { // 자기 대입 방지
if (data != nullptr) {
delete[] data;
}
data = rhs.data;
size = rhs.size;
rhs.data = nullptr;
rhs.size = 0;
}
return move(*this);
}
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
ㅈㄱㄴ ㅠ
-
'한약학과, 한약사'를 진로로 선택해서는 안되는 이유.txt 4
마치 사이비 종교와같은 일부 한약학과 학생+졸업생들의 올려치기에, 온갖 허위정보,...
-
최고점 ㅇㅈ 7
-
오르비하기 싫어지네;;
-
어그로 ㅈㅅ 수특수완 어떤 과목 풀건지 적어줘요
-
담배 언제 끊냐 6
하 이런내가싫어
-
처음엔 그냥 그럭저럭이었는데 먹을때마다 점점 우러나는느낌
-
ㅇㅈ 4
내일 내 생일이야. 인정좀해줘
-
8시에 먹어야했는데 잘려고 안 먹었더니
-
음
-
뭘 좀 아네 짜식
-
담주에 학과 정모하는데 ㄹㅇ 특정당함
-
40명정도 되는 공대인데 한학년 위 선배 마주칠일 있나요??
-
약 2년반동안 26회차 방문중
-
10레벨 찍어주십쇼 자고 싶습니다
-
성대 자연계열 붙어서 다닐 예정인데 현역에서 재수하면서 물리 4등급->1등급 지구...
-
운치있는 지금 0
-
ㅇㅈ 21
-
지금 대학을 다시 가는 것 아니면 나중에는 돌이킬 수 없다는 생각이 들어서 우울함...
-
예전 기출인데 B국이 철제 통조림 개발했고 B국에 유학갔다온 C국 발명가가 철제...
-
난 스스로 인상 되게 날카롭다 생각했는데
-
성적표로 과외알바 구해도됨?
-
난 게으른데ㅠ
-
건강이 안좋다 5
님들도 조심하셈
-
민초 호감도 조사 14
-
환급형 패스때문에 캐시 들어올게 있어서 지금 2월말까지 존버타고 있거든요.. 지금...
-
movling_11
-
키168 ㅆㅅㅌㅊ(차은우급은 아님,평균보단 많이 잘생김) 키 185...
-
없으니 오우석 원장님이 주신 부엉이 인형 꼬옥 안고 자야지
-
잠깐 하는 ㅇㅈ 25
ㅋㅋ
-
기하런하기
-
美 초등 교사, 13세 남학생 성폭행하고 아이 출산 13
미국의 한 초등학교 여교사가 미성년 제자를 성폭행하고 그 과정에서 임신한 아이를...
-
누가 당근마켓에 0
학습상담 만오천원 올려놨네 나도올릴까? ㅋㅋ
-
선넘질받 12
칼바람 한 판 하고 답변해드림
-
설대뱃지예쁘다 0
나도설대넣을걸
-
잘자요 6
-
어그로 죄송합니다 현역입니다 지금 시대 단과 미적 다니고 있고 어렵지만 따라가보고...
-
현황조사 2탄 5
ㄱㄱ
-
호감오르비언 20
그건바로나
-
좀 벌려
-
ㅇㅈ 갑니다 4
에타에서 만나요
-
어쩔건데
-
강기분 듣고있는데, 이게 문제들이 난이도가 높아지더라도 글은 어차피 다 비슷한...
-
글 쓰면 이것저것 질문해드려요 최대 20명까지만 받습니다 너무 많아짐 힘들어서...
-
선넘질받 6
다물어봐
486..