Movatterモバイル変換


[0]ホーム

URL:


cppreference.com
Namespaces
Variants
    Actions

      std::not1

      From cppreference.com
      <cpp‎ |utility‎ |functional
       
       
      Utilities library
       
      Function objects
      Function invocation
      (C++17)(C++23)
      Identity function object
      (C++20)
      Old binders and adaptors
      (until C++17*)
      (until C++17*)
      (until C++17*)
      (until C++17*)  
      (until C++17*)
      (until C++17*)(until C++17*)(until C++17*)(until C++17*)
      not1
      (until C++20*)
      (until C++20*)
      (until C++17*)(until C++17*)
      (until C++17*)(until C++17*)

      (until C++17*)
      (until C++17*)(until C++17*)(until C++17*)(until C++17*)
      (until C++20*)
      (until C++20*)
       
      Defined in header<functional>
      template<class Predicate>
      std::unary_negate<Predicate> not1(const Predicate& pred);
      (until C++14)
      template<class Predicate>
      constexprstd::unary_negate<Predicate> not1(const Predicate& pred);
      (since C++14)
      (deprecated in C++17)
      (removed in C++20)

      std::not1 is a helper function to create a function object that returns the complement of the unary predicate function passed. The function object created is of typestd::unary_negate<Predicate>.

      The unary predicate type must define a member type,argument_type, that is convertible to the predicate's parameter type. The unary function objects obtained fromstd::ref,std::cref,std::negate,std::logical_not,std::mem_fn,std::function,std::hash, or from another call tostd::not1 have this type defined, as are function objects derived from the deprecatedstd::unary_function.

      Contents

      [edit]Parameters

      pred - unary predicate

      [edit]Return value

      std::not1 returns an object of typestd::unary_negate<Predicate>, constructed withpred.

      [edit]Exceptions

      (none)

      [edit]Example

      Run this code
      #include <algorithm>#include <functional>#include <iostream>#include <iterator>#include <numeric>#include <vector> struct LessThan7:std::unary_function<int,bool>{bool operator()(int i)const{return i<7;}}; int main(){std::vector<int> v(10);std::iota(std::begin(v),std::end(v),0); std::cout<<std::count_if(begin(v), end(v), std::not1(LessThan7()))<<'\n'; // the same as above using std::functionstd::function<bool(int)> less_than_9=[](int x){return x<9;};std::cout<<std::count_if(begin(v), end(v), std::not1(less_than_9))<<'\n';}

      Output:

      31

      [edit]See also

      (C++17)
      creates a function object that returns the complement of the result of the function object it holds
      (function template)[edit]
      (deprecated in C++17)(removed in C++20)
      wrapper function object returning the complement of the unary predicate it holds
      (class template)[edit]
      (C++11)
      copyable wrapper of any copy constructible callable object
      (class template)[edit]
      move-only wrapper of any callable object that supports qualifiers in a given call signature
      (class template)[edit]
      (deprecated in C++17)(removed in C++20)
      constructs customstd::binary_negate object
      (function template)[edit]
      (deprecated in C++11)(removed in C++17)
      creates an adaptor-compatible function object wrapper from a pointer to function
      (function template)[edit]
      (deprecated in C++11)(removed in C++17)
      adaptor-compatible unary function base class
      (class template)[edit]
      Retrieved from "https://en.cppreference.com/mwiki/index.php?title=cpp/utility/functional/not1&oldid=161809"

      [8]ページ先頭

      ©2009-2025 Movatter.jp