프로그래밍 일반/C++ 프로그래밍 17

[Effective Modern C++] 항목 1: 템플릿 형식 연역 규칙을 숙지하라

항목 1: 템플릿 형식 연역 규칙을 숙지하라 템플릿 선언은 다음과 같은 모습입니다. template void f(ParamType param); 호출하는 코드는 다음과 같은 모습니다. f(expr); 예를 들어 템플릿의 선언이 다음과 같습니다. template void f(const T& param); 그리고 이를 다음과 같이 호출한다고 합시다. int x = 0; f(x); T가 expr의 형식일 것이라고 기대합니다. 실제로 위의 예제에서 x는 int이고 T는 int로 연역됩니다. 그러나 항상 그런 것이 아닙니다. T에 대해 연역된 형식은 expr의 형식과 Paramtype의 형태에 의존합니다. 그 형태에 따라 총 세가지 경우로 나뉩니다. ParamType이 포인터 또는 레퍼런스이지만 Universal..

[C++] Online C++ 컴파일러

온라인 컴파일을 사용하면 매우 유용합니다. Wandbox https://wandbox.org/ [Wandbox]三へ( へ՞ਊ ՞)へ ハッハッ wandbox.org Compiler Explorer https://gcc.godbolt.org/ Compiler Explorer gcc.godbolt.org 각종 CPU, 컴파일러별 어샘블리 코드를 바로 볼 수 있습니다. Quick C++ Benchmarks https://quick-bench.com/ Quick C++ Benchmarks Quickly benchmark C++ runtimes quick-bench.com

[C++] decltype 과 auto

decltype은 주어진 식의 구체적인 타입 그대로 전달하는(추출하는) 키워드입니다. decltype(expression) auto는 상응하는 타입을 추론하는 키워드라면, declytype은 상응하는 타입을 추출하는 키워드 입니다. const int n = 1; auto m = i; // auto는 추론되며 int decltype(i) k = i; // decltype(i)는 추출되어 const int decltype의 expression에 식별자(객체의 이름)가 아닌 expression이 온다면 어떻게 추출 되는지를 알아야 합니다. 이를 알기 위해서는 lvalue, prvalue, xvalue가 무엇인지 명확히 알아야 하며 Type Category를 참고해주세요. [객체 지향 프로그래밍/C++ 프로그래..

[C++] 문자열 리터럴이 lvalue인 이유

C 문자열 리터럴은 Lvalue 입니다. C의 lvalue와 rvalue를 가집니다. 직관적으로 생각하면 lvalue은 왼쪽에 올 수 있는 표현들을 rvalue는 오른쪽에 올 수 있는 표현들입니다. 예를 들면 다음과 같이 두 항당 문이 있다고 생각해 봅시다. int x; x = 1; // OK 1 = x; // Error 첫번째 문장은 x가 lvalue이고 1이 rvlaue이며 이상없습니다. 두번째 문장은 왼쪽에 rvalue가 왔기 때문에 에러가 발생합니다. 러터럴(literal)은 일반저긍로 7, tue, 1.0f와 같은 rvalue들을 말합니다. 이는 리터럴들은 할당 표현에서 오른쪽에 올 수 있습니다. 그러나, 예외의 경우가 있습니다. 문자열 리터럴(예:"hello")는 실제로는 lvalue입니다. ..

C++ Type Category

glvalue(generalized lvalue)는 일반화된 좌측값 rvalue는 우측값 lvalue는 좌측값 xvalue(eXpiring value)는 소멸하는 값 prvalue(pure rvalue)는 순수 우측값 C++에서 타입 카테고리를 따질 때 크게 두 가지로 구분 합니다. Identity(정체를 알 수 있는가?) Movable(이동 시킬 수 있는가?) 모든 타입은 다음과 같이 다섯 가지고 구분 할 수 있어요. lvalue Identity && Not Movable 즉, 정체를 알 수 있고 이동 시킬 수 없습니다. int n; int m; n과 m은 정체를 알 수 있나요? n와 m은 다른 주소를 가지고 있고 이 주소값들에 의해서 구분 됩니다. 즉, 정체를 알 수 있습니다. 그렇다면 이동은 가능한..

[Effective Modern C++] 형식 연역(type deduction)

형식 연역이 일어나는 경우는 다음의 경우입니다. C++98 : template만 존재 C++11 : auto, decltype 추가 C++14 : auto와 decltype를 사용할 수 있는 문맥 확장, decltype(auto) [C++] decltype 과 auto 참고해 주세요. 형식 연역의 범위가 증가한 덕분에 자명하거나 이미 언급된 형식들을 여러 번 일일이 지정해야하는 경우가 크게 줄었습니다. 코드의 한 곳만 수정하면 그 변화가 형식 연역을 통해 다른 장소들로 자동으로 전파됩니다. 그러나 코드의 의미를 추론하기는 좀 더 어려워졌습니다. 컴파일러가 연역하는 형식이 독자가 언뜻 보고 추측하는 것과 다른 경우가 있기 때문입니다. 형식 연역이 일어나는 방식을 확실히 이해해야야 효과적인 프로그래밍을 할 ..

C++, 어떻게 효과적으로 Vector를 사용하는가?

엘리먼트를 마지막에 추가 또는 삭제 할때 더 효과적이다. Vector의 데이터는 연속적으로 관리 되다 따라서 중간에 insert를 하면 데이터는 오른쪽으로 쉬프트된다. reserve() 함수를 이용하여 저장소를 초기화 하라 한번에 하나의 엘리먼트를 여러번 호출 하는 대신에 한번 호출에 여러 엘리번트들을 추가하라. https://thispointer.com/how-to-use-vector-efficiently/ How to use vector efficiently in C++? – thispointer.com We can use vector efficiently by taking care of following points, 1.) Vector will be more efficient if elements..