2018-03-05
Boolan STL 第四周
万用的hashfunction:
使用以Hash Table为底层的容器,比如unordered_map(hash_map),在使用个过程中,需要有计算hash code的方法来计算出元素在hashtable中的具体位置。 那么对于自定义类型来说,需要指定对应的Hash Function,只有这样才能在使用的过程,系统找到对应元素应该插入的位置,以便系统自动管理我们需要插入到容器中的各个元素。
#includeclass Customer{ //........ };
class CustomerHash {
public:
std::size_t operator()(const Customer& c) const
{ return /*........*/; } };
size_t customer_hash_func(const Customer& c)
{ return /*......*/; } //使用 unorder_set customers(20, customer_hash_func);
//以struct hash 偏特化形式实现hash function
class MyString
{
private: char* _data;
size_t _len; };
namespace std;
{
template<>
struct hash
{
size_t operator()(const MyString& s) const noexcept
{ return hash()(string(s.get())); }
}
}
c++ 2.0提供的hash function
//使用万能的Hash Function
class CustomerHash
{
public: std::size_t operator()(const Cunstomer& c) const
{ return hash_val(c.fname, c,Iname, c.no); //在此,只需要调用hash_val函数,并把每个成员的值传递给他就行了
}
}
tuple:任意类型元素组合
data:image/s3,"s3://crabby-images/c9ce6/c9ce67b8d83faecf478913e153a4d8bf428a3ffb" alt=""
data:image/s3,"s3://crabby-images/e79ba/e79bae968b27e36023658f535b314f7442a7b14d" alt=""
Type Traits定义:
data:image/s3,"s3://crabby-images/73835/738354ea94cb1291ce93422d0f46b4ef9936a801" alt=""
Type Traits测试:
data:image/s3,"s3://crabby-images/7f072/7f072d43ee34f67cde66a7d034fea22561744403" alt=""
data:image/s3,"s3://crabby-images/b60f4/b60f446b77bf4d3381407a285436b7b730d444be" alt=""
data:image/s3,"s3://crabby-images/4bd81/4bd81a99672236fff795d89fd452561a5afed986" alt=""
data:image/s3,"s3://crabby-images/69f83/69f83aeaf6e7a0e8b2767b188703c05fa98ef98f" alt=""
data:image/s3,"s3://crabby-images/cd09b/cd09ba3003a2e819795c196e435c73bbc98c677d" alt=""
data:image/s3,"s3://crabby-images/770b0/770b02b48523623133cff1218e15c7d0efa5fc0a" alt=""
data:image/s3,"s3://crabby-images/f76dc/f76dcc1aafa62ba7ce83b18cd42dfcaada561c00" alt=""
TypeTraits 实现:
data:image/s3,"s3://crabby-images/8b4df/8b4df7ff07f0bc90c739b39a5be6e4502781493b" alt=""
data:image/s3,"s3://crabby-images/ec2bd/ec2bdcccddd538fe52247c634274e468ba2e5488" alt=""
data:image/s3,"s3://crabby-images/13331/13331f8dd7ac43a10754867301e66798b44e12bc" alt=""
data:image/s3,"s3://crabby-images/e1ab0/e1ab0ea16cac57d3c2a36203a8493ec05df972c3" alt=""
moveable :可移动的,可以将原先的指针打断,新建的元素指针直接指向元素,提高效率,但必须包拯原来的指针不会再被使用。