3,4년 전쯤에 번역했던 것을 공유한다
더 읽기
template<class T> struct foo{ T operator()( ... ){ ... }; }; std::array< double, ... > a = ; bar( foo< >() ); // < > 안에 a의 요소 타입 double을 넣고 싶다.. bar( foo< decltype(a)::value_type >() ); // decltype(a)::value_type은 double...
더 읽기
예제 코드 #include <iostream> #include <map> #include <string> double Add(double a, double b){ return a + b; } double Sub(double a, double b){ return a - b; } double Mul(double a, double b){ return a * b; } double Div(double...
더 읽기
C++에 존재하는 여러 종류의 함수를 wrap 하여 똑같이 다룬다 C++에 있는 함수의 종류 함수 람다식 함수 객체 클래스의 멤버 함수 람다식 사용법 [캡처](인수)->반환 값 타입 { 함수의 내용 }(실행 시 인수); 캡처에는 기본적으로[=] 나 [&]가 들어간다. =는 범위 밖의 변수를...
더 읽기
#include <iostream> // std::cout, std::endl; #include <algorithm> // std::unique #include <vector> // std::vector void printVec(std::vector<int> &vec) { std::cout << ""; for (auto it = vec.begin(); it != vec.end(); ++it) { std::cout << *it << " "; } std::cout << std::endl;...
더 읽기
지정한 함수를 wrap해서 std::function을 만든다. #include <iostream> void test_function(int a, int b) { printf("a=%d, b=%d\n", a, b); } int main(int argc, const char * argv[]) { auto func1 = std::bind(test_function, std::placeholders::_1, std::placeholders::_2); func1(1, 2); // -> a=1, b=2 auto func2...
더 읽기
3,4년 전쯤에 번역했던 것을 공유한다
더 읽기
C#의 확장 메소드와 같이 기존 클래스에 대해서 멤버 함수의 확장을 operator 오버로드를 구사하여 시뮬레이트 하는 idiom 이다. 예컨대 std::vector에 print 라는 모든 요소를 출력하는 확장 구성원을 만들려고 한다면 const struct Listed_print{ using result_type=void; template<class Range> void operator()(const Range& r) {...
더 읽기
원문 스마트 포인터는 객체의 라이프 타임이 다한 때에 자동적으로 확보된 리소스를 삭제한다. 생성자와 소멸자, 연산자 오버 라이드를 잘 구현하였다. 이것을 응용하면 클래스의 멤버 함수가 실행될 때 특정 처리를 실행하는 스마트 포인터를 구현할 수 있다. class ExecutePointer { public: class proxy...
더 읽기
원문 아래는 STL의 컨테이너에서 특정 요소를 삭제하는 코드. std::vector<int> a; /*a에 요소를 추가하는 코드는 생략*/ std::remove(a.begin(), a.end(), 100); 이것으로 사라진 것이 아니다. 실은 remove 함수는 특정 요소를 컨테이너의 뒤에 만든 후 선두의 특정 요소에 대한 반복문을 반환하기만 한다. 정말로 지우려면...
더 읽기