일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 | 29 |
30 | 31 |
- hyperledger transaction
- html multimedia
- html code
- mac terminal command
- relative path
- #C++ 연산자함수오버로딩
- html id
- git flow
- border-box
- #1차원배열
- #android activity
- #다차원포인터
- #bubbleSort
- 토큰경제
- html youtube
- 하이퍼레저패브릭
- #CallByAddress
- docker example
- #성적관리프로그램
- #C++ has~a
- #2차원배열
- #3차원배열
- #binary
- #자바상속#자바이즈어#is~a
- html5 new tag
- html plug-in
- html charset
- #JAVASCRIPT
- html object
- html video
- Today
- Total
목록C++ (24)
A sentimental robot
namespace는 논리적인 이름 공간을 만들어주는 방법으로 변수나 함수, 클래스 이름의 충돌을 방지하기 위해서 서로 다른 공간으로 캡슐화를 시켜준다. 예를 들면, 한 개의 소스파일 내에서 , var이라는 이름을 가진 두 가지 변수를 사용한다고 하자. 이름이 같아서 컴파일 에러가 나는 상황이지만 namespace를 사용하면 된다! 형식은 namespace 이름공간 명칭{ } 이다. { }안에 변수, 함수, 클래스를 정의한다. namespace f1{ int var=5; } namespace f2{ float var = 10.5; } 불러오고 싶은 네임스페이스의 변수 앞에 네임스페이스 이름을 함께 기술해야 한다. void main(){ cout
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 #include #include #include using namespace std; /* 소멸자 : 객체 소멸 시 자동호출 public으로 만들어야 한다. 외부에서 객체를 소멸할 수 있게 객체 등록 해제 생성자와 동일하지만 함수명 앞에 ~(틸드)가 붙는다. 오버로딩이 불가능하다. const member function으로 만들 수 없다. virtual 함수로 꼭 만들어서 사용해야 한다. (동적바인딩을 위해서) */ class Obj{ int a; public: Obj(int a=0){this->a=a;} ~Obj() { cout
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 #include #include #include using namespace std; /* this pointer: 메소드의 첫번째 매개변수로 선언되어있다. */ class Obj{ int a; public: Obj(int a=0){this->a=a;} void setA(int a){ // void setA(Obj * this, int a) this->a=a; } int getA(){ return a; } }; void main(){ Obj obj; Obj obj2(100); // obj.setA(100); // ..
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 #include #include #include using namespace std; class Obj{ // 디폴트생성자 public: Obj(){cout
1. private : 외부에서 접근 불가능 단, friend는 접근 가능 2. protected : 상속받은 외부에서만 접근가능 3. public : 아무나 1. 멤버변수, 필드 : 주로 private 2. 생성자함수(디폴트) : public 외부에서 쓰기 위해서 1) 기능 : 객체등록, 필드초기화 2) 명시적 ,암시적 오버로딩이 가능 3) const member function로 만들 수 없다.(cf.const member function: 함수 내의 멤버변수를 보호할 목적을 가진다. 멤버변수의 값을 바꿀 수 없고 읽기만 가능) 4) 디폴트생성자를 명시적으로 구현할 경우 디폴트생성자는 사라진다. 3. 멤버함수, 메소드 : public 외부에서 ..
C++에서는 명시적 오버로딩과 암시적 오버로딩 두가지가 있다. 명시적 오버로딩은 함수들의 데이터 타입 또는 개수가 다르고 기능 또한 다를 수 있다. 암시적 오버로딩은 데이터만 다르고 기능이 같다. (함수가 한개만 존재하기 때문에) 암시적 오버로딩은 디폴트 인자값 이라고도 한다. 디폴트 인자값을 준 기준으로 뒤에 있는 매개변수는 무조건 초기화를 해주어야한다. 디폴트 인자값을 준 횟수 +1개 만큼 호출가능 함수선언부에 디폴트 인자값을 사용하고, 함수 정의부에는 사용을 하면 안된다. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 #include #include using namespace std; void output(int a=0,int b=0, int c=0){..
C++ 에서는 reference가 pointer의 기능의 일부를 대신할 수 있다. 선언과 동시에 초기화해야 한다. 한번 참조하면 참조하는 대상을 바꿀 수 없기 때문에! 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 #include using namespace std; void main(){ int a=10; int b=20; int &aa = a; cout
C++를 사용하기 앞서 절차 지향 | 객체 지향 | 객체 기반 | 일반화 자바에서는 생성자를 만들 때 접근지정자를 명시하지 않으면, default 생성자 -> 같은 패키지 내에서만 접근 가능 C++에서는 생성자를 만들 때 접근지정자를 명시하지 않으면, private 생성자 -> 외부에서 접근 불가능 자바는 단일 상속, C++는 다중상속 가능 클래스 선언 class A{ }; 외부함수에서 클래스를 사용 -> 객체와 외부함수 간 통신가능 자바는 클래스 선언 시 디폴트 생성자 생성 C++는 클래스 선언 시 디폴트로 생성되는 4가지 멤버함수가 있다. 헤더파일 구표준 #include #include 신표준 #include #include using namespace std; 입출력 시, 서식문자 필요없음 ( a ..