출발합니다 안전벨트 매시구요
식사 하고 오셨나요? 멀미가 좀 심할텐데...
식사 하고 오셨나요? 멀미가 좀 심할텐데...
1.2. 이번에 배울 것 ¶
- C와 C++의 차이점
- 헤더와 include 개념 잡기
- 네임스페이스
- std::cout, std::cin, std::endl
- 참조형
- 함수 오버로딩
- 디폴트 파라미터
- 동적 할당 연산자 new, delete, delete[]
- 구조체와 클래스
- 클래스와 인스턴스
- 클래스 정의 문법
- 메서드 외부 정의와 헤더
- ★(C++11)auto
- ★(C++11)range-based for loop
- ★(C++11)std::array
2.1. 내용 ¶
1. C와 C++의 차이점
7. 디폴트 파라미터
- C++은 객체지향 프로그래밍 언어이다.
- C는 규모적으로 C++의 subset이라고 생각하기 쉽다.
- C++에서의 표준 라이브러리 헤더명은 .h로 끝나지 않는다.
- 기존 C에서의 헤더를 이용하고 싶다면 <이름.h>를 <c이름>으로 선언해서 이용할 수 있다(C++호환버전).
- 헤더는 다른 헤더의 include나 전처리기 매크로, 클래스나 함수 등의 declaration이 들어간다.
- 외부 파일에 정의된 함수나 클래스의 declaration은 모든 파일에 필요하다. declaration이 없으면 외부에 정의된 함수나 클래스를 이용할 수 없다.
- declaration이 있지만 definition이 없는 identifier는 링커에 의해 외부 링크가 이루어진다.
- 네임스페이스는 다른 팀원이 작성한 소스 코드와의 이름 충돌을 막아준다.
- 네임스페이스 중괄호 블록은 같은 이름으로 다시 만들 수 있다.
- std::cin, std::cout은 C++에서의 표준 입출력 스트림이다.
- <<연산자와 >>연산자를 이용하여 모든 기본 타입을 출력할 수 있다.
- std::endl은 줄바꿈을 의미한다.
- 참조형은 변수의 이름을 추가 정의하는 방법이다.
- 참조형은 선언 시 참조할 대상을 초기화해야 한다.
- 한번 대상을 지정한 참조형은 참조 대상을 바꿀 수 없다.
- 참조형은 포인터보다 안전한 call-by-reference 방법이다.
- 함수 파라미터로 참조형을 이용할 수 있다.
- 참조형을 이용하면 값의 복사가 전혀 일어나지 않는다.
- C++에서는 같은 이름의 함수라도 인자의 개수나 타입이 다르다면 중복 정의할 수 있다.
- 리턴 타입만 다른 경우에는 오버로딩할 수 없다.
- 함수를 오버로딩할 때는 실제 호출할 때 모호성이 발생하지 않아야 한다.
void func(int, int); | void func(float, float); |
func(1, 2)는 왼쪽 함수가 호출된다 |
7. 디폴트 파라미터
- 함수 파라미터에 디폴트 값을 지정하면 해당 인자를 생략하여 디폴트 값을 지정할 수 있다.
- 디폴트 파라미터는 가장 우측 파라미터부터 적용해야 한다. 그렇게 강제하지 않으면 어느 인자가 생략됐는지 구분할 수 없기 때문이다.
- 디폴트 파라미터는 함수 프로토타입 선언을 사용할 경우 선언부에만 작성해야 한다. 정의부에서는 디폴트 값을 기술하지 않는다.
- 디폴트 파라미터에 의해 생략이 가능한 함수를 오버로딩할 때는 모호성 에러를 피해야 한다.
- example
int foo(bool a, int b = 5){}
8. 동적 할당 연산자 new, delete, delete[]
- new 연산자를 이용하여 단일 변수나 배열을 편리하게 동적 할당할 수 있다.
- 단일 변수의 해제에는 delete, 배열의 해제에는 delete[]를 이용한다.
- 클래스는 추상적 개념을 정의한 것이고 인스턴스는 그것을 구체화한 실제 변수이다.
- 클래스를 정의할 땐 세미콜론을 쓴다.
- 클래스의 메서드는 클래서 정의부에 선언만 하고 외부에서 정의할 수 있다.
- 보통 헤더에는 메서드 정의를 포함하지 않는다.
- auto 키워드는 수식으로부터 타입을 추론한다.
- auto& 키워드는 추론된 타입의 참조형을 의미한다.
- 범위 기반 for문을 이용하면 배열이나 STL 컨테이너를 편리하게 순회할 수 있다.
- example
auto && __range = range_expression ; for (auto __begin = begin_expr, __end = end_expr; __begin != __end; ++__begin) { range_declaration = *__begin; loop_statement }
14. (C++11)std::array
- std::array를 이용하면 편리하게 배열을 다룰 수 있다.
- example
#include <string> #include <iterator> #include <iostream> #include <algorithm> #include <array> int main() { // construction uses aggregate initialization std::array<int, 3> a1{ {1, 2, 3} }; // double-braces required in C++11 (not in C++14) std::array<int, 3> a2 = {1, 2, 3}; // never required after = std::array<std::string, 2> a3 = { std::string("a"), "b" }; // container operations are supported std::sort(a1.begin(), a1.end()); std::reverse_copy(a2.begin(), a2.end(), std::ostream_iterator<int>(std::cout, " ")); std::cout << '\n'; // ranged for loop is supported for(const auto& s: a3) std::cout << s << ' '; }
2.2. 코드 ¶
- C 헤더 이용하기
C | C++ |
#include <stdio.h> | #include <cstdio> |
#include <stdlib.h> | #include <cstdlib> |
#include <string.h> | #include <cstring> |
기타 등등...
- namespace 키워드
using namespace std; // std 네임스페이스를 생략하고 사용가능 using std::endl; // endl만 std를 생략하고 사용가능 namespace A { void testMethod() { std::cout << "A.testMethod called" << std::endl; } } namespace B { void testMethod() { std::cout << "B.testMethod called" << std::endl; } } void main(void) { A::testMethod(); B::testMethod(); /* output A.testMethod called B.testMethod called */ }
- std::cout, std::cin, std::endl
#include <iostream> // 필요함 void main(void) { std::cout << "출력하는 함수" << 0 << 0.4 << std::endl; // std::endl은 개행, 숫자나 실수도 출력가능 int a; char * testArr[5] = {0, }; std::cin >> a; // & 필요없음 std::cin >> testArr // 가능 }
- 참조형
void main(void) { int num = 4; int& refNum = num; // refNum은 num과 같이 취급됨, 포인터도 아니다. addOne(num); // call-by-value. num = 4로 변함 addOne(refNum); // call-by-reference. num = 5로 변함 }
- 함수 오버로딩
void overloadMethod(); void overloadMethod(int a); void overloadMethod(int b, int c); // 오버로드된 함수들
- 디폴트 파라미터
void testMethod(int a, int b, int c = 5) // c는 디폴트 파라미터 void main(void) { testMethod(1,2,3); // 가능 testMethod(1,2); // 이것도 가능 } void testMethod(int a, int b, int c) // 정의부에는 디폴트 파라미터 금지 { // .... }
- 동적 할당 연산자 new, delete, delete[]
void main(void) { int * allocArray = new int[5]; std::string * allocString = new string(); // new로 동적할당 delete allocString; // 메모리 해제 delete[] allocArray; // 배열 메모리를 해제할 때 사용 }
- 클래스와 인스턴스
class TestClass // 클래스 { }; void main(void) { TestClass inst = TestClass(); // 인스턴스 TestClass * pInst = new TestClass(); // 동적 할당 인스턴스 delete pInst; }
- Class 정의하기
class TestClass { // 필드(멤버)나 메서드를 채워넣기 }; // 세미콜론 삽입에 주의
- 메서드 외부 정의
class TestClass { void testMethod(int para1, int para2); // 프로토 타입만 정의 }; // 외부에서 testMethod 메서드를 정의함 void TestClass::testMethod(int para1, int para2) { std::cout << para1 << para2 << std::endl; }
- (C++11) auto 키워드
auto typeArray = new int[5]; // typeArray는 자동으로 int *로 설정됨 TestClass testInst = TestClass(); auto& realNum = testInst; // realNum은 TestClass&로 자동 설정됨
- (C++11) ranged-based for loop
int testArray[5] = { 1, 2, 3, 4, 5 }; for (int value : testArray) { // value는 순서대로 1, 2, 3, 4, 5가 대입됨 } for (int& refValue : testArray) { // 참조형으로도 가능 } for ((auto 혹은 auto&) value : something) { // 뭔가를 한다. }
- (C++11) std::array
#include <array> // 필요함 void main(void) { std::array<type, size> cppArray = { .... }; // cppArray 아래에 있는 다양한 메서드 이용 가능 }