컴공 일기261
- 동적 배열을 즉석에서 한번 구현해봤습니다.
이동시맨틱, 대입연산, 복사생성, …, 자료출력 등등 구현을 했습니다만
결정적으로 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를 선물하세요.
-
시대인재 점공 계산기에서 나온 SemPer 계산기랑 실제 엑셀 계산기랑 결과가 다른데 뭐가 맞나요?
-
통합했으니까 1맞기는 수학이 더 쉬운게 아닐까?
-
이건 예상 못했다;; 동생 재수해서 못알려드려요 ㅈㅅㅈㅅ
-
춥다 0
추워
-
나같은 애도 100점 나오는 과목임 뭐가 꿀인지 안보임? 이걸안해?
-
그 사람이라도 지원하지 않았더라면..
-
씨발… 입원해있어서 정신없어서 못했는데 방법 있나요?
-
과외 제안서 받은 사람들아 왜 연락을 안줘?
-
마크서버같은거라도 열어볼까요? 혹시 하실분 있을까 싶네요
-
놀았다가 인생망했어요
-
언제까지 기다려야하는데
-
중앙 안썼는데 되면 너무 슬플듯ㅠㅠ
-
국수탐(과탐) 중에 1받기 제일쉬운건 수학맞지않음? 5
국어랑 과탐은 1등급 개어려운데
-
1월 1일에 써서 낙지 못봤다고
-
본인 평가원에서 한국사 국어 영어 탐구 한번도 1맞은적없는데 수학은 전부1임
-
영어 올렸는데 0
근데 생각보다 영어도 잘 안오르는듯 작년엔 평가원은 2만나오던데.... 2->1이 통곡의구간임
-
셈퍼 점공계산기 2
한양 정책인데 이거 추합 가능할까요?? 그리고 점공계산기도 나중갈수록...
-
문제를 어떻게 내느냐는 전혀 별개의 문제죠 아무리 요즘 수능이 변별원툴 ㅂㅅ된다고...
-
님들아 재종 조기반 들어가는데 그 과목 아예 노베면 1
수업 따라가기 힘들까요? 참고로 노베인 과목이 미적분 과목입니다. 그리고 선택과목...
-
지금 사상 최고 오르비언의 라이브가 펼쳐지고 있습니다 4
https://www.instagram.com/ksatpickle/live/ 많은 참여 부탁드립니다
-
국어 수학은 반쯤 고정으로 1띄울 자신 있고 과탐은 미끄러지면 몰라도 실력은 1등급...
-
영어 풀 때 0
왓다갓다 컨하는거 어지러워서 잘 못할 것 같아. 집중력 딸릴거 가튼데 근데 그거...
-
올해 재수생인데 작년 강기분 새기분 강e분 우기분 완강 실모 30개이상 시발점 뉴런...
-
내신 개박살이면 서울대는 수능 아무리 잘쳐도 못감? 2
내인생에없는대학교인가
-
재수 삼수면 지나고 보면 아무것도 아닌데 이쯤되니 잃은게 너무 많다 내가 좋아하는...
-
김현우 라이브 0
지금 김현우쌤 라이브 듣는 분 계시나요..? 너무 끊기는데..
-
아직 영상 보는중인데선이 점으로 이루어져있고, 그 점이 크기가 없다면, 어떻게...
-
메디컬 끝자락인데 지금 너무 후하게나와서 나중에 봐야할것같아서요..
-
그거말고는 1(점)을 받을래야 받을수가없음
-
의 저 새기를 맡고있습니다
-
갑자기 혼자 기분 풀고 이러면.......나 진짜 슬픔........말도 편하게...
-
ㄹㅇ루
-
여기서 하긴 좀 그런데
-
본인 평가원 영어 444442임
-
그리고 어려워져봤자 등급컷이랑 만표는 안달라져서 출제자들도 어차피 다 포기함 그러니...
-
일종의 놀이같음
-
과탐을 하루에 3시간도 안 하고 잘보는게 가능함? 10
난 과탐 4시간 넘게 하고도 못봤는데 과탐3시간도 못하면 화작하거나 사탐해야하지않나
-
이건 ㄹㅇ임 누구나 공부하면 1가능
-
17시간 잤음 0
근데 아직도 몸이 안 좋음..
-
정법동사로 5050쟁취
-
재미로 보는 저사람은 서울대학교 경제학과라 저 대학들하고 관련은 없음 저분 말...
-
매년 방학 때 이렇게 놀고 싶어
-
씨발못간다고요.
-
밥 먹기 귀찮
-
진지하게 목표는 높3~낮2 목표 작년 수학 14 15 20 21 22 틀렸습니다...
-
예전에 올렸던 사문 자작문제인데 겉은 쉬워보여도 이런 형식으로 개념이 얼마든지...
-
비문학 지문 읽으려 할때마다 긴장되고 벅차는데, 또 읽다보면 긴장이 풀려서 그런건지...
-
원솔멀텍 할때 강의도 다 듣는게 좋으려나요? 다들으면 볼륨이 실전개념 하나...
-
사람들 다 5일전부터 존나 준비함 심지어 계절인데
-
오노추 0
요즘 허니패밀리에빠짐여
486..