std:: unary_function
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Old binders and adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
헤더에 정의됨
<functional>
|
||
|
template
<
typename
ArgumentType,
typename
ResultType
>
struct unary_function ; |
(C++11에서 사용 중단됨)
(C++17에서 제거됨) |
|
std::unary_function
는 하나의 인수를 갖는 함수 객체를 생성하기 위한 기본 클래스입니다.
std::unary_function
는
operator
(
)
를 정의하지 않습니다; 파생 클래스에서 이를 정의할 것으로 예상됩니다.
std::unary_function
은 템플릿 매개변수로 정의된 두 가지 타입 -
argument_type
과
result_type
- 만 제공합니다.
일부 표준 라이브러리 함수 객체 어댑터들, 예를 들어
std::not1
는, 그들이 적응시키는 함수 객체들이 특정 타입들을 정의하고 있기를 요구합니다;
std::not1
는 적응되는 함수 객체가
argument_type
이라는 이름의 타입을 가지고 있기를 요구합니다. 단일 인자를 받는 함수 객체들을
std::unary_function
로부터 파생시키는 것은 이들을 그런 어댑터들과 호환되도록 만드는 쉬운 방법입니다.
std::unary_function
는 C++11에서 사용이 중단되었습니다.
멤버 타입
| 유형 | 정의 |
argument_type
|
ArgumentType
|
result_type
|
ResultType
|
예제
#include <algorithm> #include <functional> #include <iostream> #include <vector> struct less_than_7 : std::unary_function<int, bool> { bool operator()(int i) const { return i < 7; } }; int main() { std::vector<int> v(10, 7); v[0] = v[1] = v[2] = 6; std::cout << std::count_if(v.begin(), v.end(), std::not1(less_than_7())); // C++11 솔루션: // std::function<bool (int)>로 캐스팅 - 람다를 사용하더라도 // std::cout << std::count_if(v.begin(), v.end(), // std::not1(std::function<bool (int)>([](int i) { return i < 7; }))); }
출력:
7
참고 항목
|
(C++11)
|
복사 생성 가능한 모든 호출 가능 객체의 복사 가능 래퍼
(클래스 템플릿) |
|
(C++23)
|
주어진 호출 시그니처에서 한정자를 지원하는 모든 호출 가능 객체의 이동 전용 래퍼
(클래스 템플릿) |
|
(C++11에서 사용 중단됨)
(C++17에서 제거됨)
|
함수 포인터로부터 어댑터 호환 함수 객체 래퍼 생성
(함수 템플릿) |
|
(C++11에서 사용 중단됨)
(C++17에서 제거됨)
|
단항 함수 포인터용 어댑터 호환 래퍼
(클래스 템플릿) |
|
(C++11에서 사용 중단됨)
(C++17에서 제거됨)
|
어댑터 호환 이항 함수 기본 클래스
(클래스 템플릿) |