컴공 일기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를 선물하세요.
-
만족스럽군 근데 다른 군 등수가 왜이럴까 아..
-
명문대 기준? 3
딱 sky임 뭘 더 왈가왈부 할게 있나
-
그리고 의대라인은 점공계산기가 많이 후하게 주나요?
-
나쁘지 않은 출발이군
-
입갤 5
-
“1박 2일 여자친구 해드려요”… 198만원 일시불 결제 경험담도 13
중고거래 플랫폼에 ‘데이트권’ 논란 유튜버와 만난 여성 “건전한 데이트” 한...
-
빨리 나온다는건 그만큼 덜 들어온단 얘기기도 하기 때문 발표 나고 예비 받고...
-
원광치가 이김?앞에 다 원광치 우선순위네
-
지금 상황 봤을때 숭실대식 907.58은 합격권임 불합권임?
-
반갑구나
-
1등급이랑 9등급이랑 어느 정도 차이 나나요? 그거 커버하려면 다른 곳에서 어느...
-
진짜 진지한 고민인데 한번씩만 봐주세요..! 원서 3장 중에 하나는 가망 없고...
-
기도해야겠다 제발
-
시발꿈에그리던대학인데 너무 늦게 발표하네 재수해서 이번엔 붙고싶은데
-
이제 어둠의 표본들만 더 안들어오면 된다....!
-
시트보호땜에 안되는데 비번 어케알아요??
-
지금돌리는건 별로 의미없나요? 지원한거 둘다 최초합이라는데 불합일수도 있을까요ㅠㅠ
-
한양컴 아직까지 1등이네..
-
서울대... 6
으악
-
7명중 단 한명만 상위표본이어도 불합..걍 마음 접어야하나
-
다른 지원자가 열람 안해도 등록만 했으면 그사람 점수 보임?
-
서강 물리 4
혹시 잘 아시는 분 계세요? 자연대는 스카이 이외에 서강대를 알아준다고 부모님이...
-
히히 발송대기 2
시발점 ㄹㅇ 왤캐비쌈 '그' 탁구선수가 보고싶음뇨
-
어제 접수 다했고 가군 이랑 다군은 서류확인버튼이 있는데 나군은 없음 나군 보니까...
-
입학장학금 0
요즘도 다 있는 편임?
-
오늘 저녁 6-7시에 수학 칼럼 하나 올리겠습니다. 3
조금이라도 도움받는 분이 계시기를 바라며 열심히 작성해보겠습니다 !
-
밥 내놔. 0
-
점공 계산기 2
지금 점공계산기 돌리는건 부정확한가요?? 지거국라인인데…
-
ㅎㅎ
-
내려가서 좋아요 누르고 와주세요 내려가서 좋아요 누르고 와주세요 내려가서 좋아요...
-
연경제 0
점공좀 부탁드리겠습니다! ?
-
허허허
-
2시까지 29%로 버티기 ㄱㄴ?
-
어니면 음..
-
ㅇㅇㅇㅇㅇ
-
ㅈ같다
-
ㅈㄱㄴ
-
대인라 이번 해에도 할 거 같은데 (아마?) 김성민T 들은 사람 후기좀요 강대k...
-
나도 기적맞지 4
그렇다고해줘 무휴학반수햇어
-
진짜 서울대 점공이 어쩌고 고대가 어쩌고 그냥 한없이 부럽다 ㅠㅠ
-
선착순 10명 댓글 달아주시면 1000XDK씩 드립니다
-
헷갈린다 이말이야
-
아주 긴 글임. 그리고 중학교 시절부터를 후회하는 글임. 선행이라는 거 아예 모르고...
-
점공 좆됐다 5
낙지실지원 40명중 6등에 진짜실지원 46명인데 점공 13명중 6등이네 좆됐다...
-
미디어커뮤니케이션 붙나요 다른 학교 제 윗 표본인데 궁금해서요
-
다들 하러 ㄱㄱ
-
설악산 낙상환자 구조한 산림청 대원…헬기 오르다 추락 사망(종합) 8
(인제=연합뉴스) 박영서 류호준 기자 = 설악산에서 낙상환자 구조에 나선 산림청...
-
확실히 합격권 애들이 초반에 많이 넣는듯요.. 모의지원자 평균점수랑 차이 많이남
-
오르비 정도 들어오는 애들이면 모를리가없기때문.
486..