람다 함수와 함께 auto 를 사용하는 것은 매우 고무적인 일이다. 다음과 같이 말이다. auto f = [](auto x) { return normalize(x); }; 이 람다 함수는 컴파일러에 의해 다음과 같은 클로저 클래스가 생성된다. class 컴파일러가_생성한_클래스 { public: template auto operator()(T x) const { return normalize(x); } ... }; 이제 문제가 생기는 것은 x 를 normalize 에 완벽 전달을 하고 싶어지면 어떻게 해야할까? auto f = [](auto&& x) { return normalize(std::forward(x)); }; ???에 적어야할 타입은 무엇일까? 우리는 항목3에서 배운 decltype 을 사용하..
이전 항목에서 우리는 보편 참조에 대한 중복적재의 문제점에 대해 이야기하였고 문제를 해결하기도 하였다. 다음과 같이 말이다. template void logAndAdd(T&& name) { auto now = std:;chrono::system_clock::now(); log(now, "logAndAdd"); names.emplace(std:;forward(name)); } std::string petName("Darla"); logAndAdd(petName); logAndAdd(std::string("Persephone")); logAndAdd("Patty Dog"); 위의 코드는 어떤 상황에서든 함수 하나로 우리가 원하대로 수행해준다. 그런데 여기서 오버로딩 함수 하나를 더 추가한다고 해보자. voi..
- Total
- Today
- Yesterday
- 보편참조
- 보편 참조
- std::forward
- async
- 람다
- 포인터
- C++
- CPP
- Unreal
- Effective Modern C++
- const
- Perfect
- detach
- auto
- C++11
- std::move
- Overloading
- C++14
- thread
- Forwarding
- Modern
- 발아시기
- Effective
- Join
- forward
- Future
- MOVE
- 다이소
- C
- Override
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |