Why is {} used to access operator() in std::hash?

2019-05-10 01:37发布

问题:

While reading the examples of std::hash used for std::unordered_map, I noticed that the operator() function was being accessed by {}.

http://en.cppreference.com/w/cpp/utility/hash

result_type operator()(argument_type const& s) const
{
    result_type const h1 ( std::hash<std::string>{}(s.first_name) );
    result_type const h2 ( std::hash<std::string>{}(s.last_name) );
    return h1 ^ (h2 << 1); // or use boost::hash_combine (see Discussion)
}

What does the use of {} here represent?

回答1:

std::hash<T> is a type not a function.

An instance of std::hash has an operator() that does the hash.

So std::hash<std::string> is a hashing type. {} then creates an instance of that type. (s.first_name) calls operator() on a std::hash<std::string>.

std::hash<std::string>{}(s.first_name);
^                     ^       ^
|                     |   call operator() on that instance
type of hasher        |
                create an instance of that type


回答2:

std::hash is not a function, but a class, more specifically a functor. So you have to create an object of that class before you can call its operator().