标签:hash_set mda 用户 读书 dash 有用 笔记 数学 容器
C++标准——也就是定义语言的文档和程序库——在1998被批准。在2003年,一个小的“修复bug”版本被发布。然而标准委员会仍然在继续他们的工作,一个“2.0版本”的C++标准预计在2009年被发布(虽然所有的工作很有可能在2007年底被完成)。直到现在,发布下一版C++的预计年份还没有被确定,这就解释了为什么人们把下一版C++叫做“C++0x”——C++的200x年版本。
C++0x可能会包含一些有趣的新的语言特性,但是大多数新C++功能将会以标准库附加物的形式被发布。我们已经知道了一些新的库功能将会是什么,因为它们已经在文档TR1(来自C++库工作组的Technical Report 1)中被指定了。在C++0x被官方正式发布之前,标准委员会保有对TR1的功能进行修改的权利,但是不太可能有大的修改。TR1预示了一个新的C++ release的开始——我们可能将其叫做标准C++ 1.1.如果你不熟悉TR1的功能,你不能被称作一个effective C++程序员,因为TR1中的功能对于各个种类的库和应用来说都是一种福利。
在考察什么是TR1之前,回顾一下C++98版本标准库中的主要部分是很有价值的:
如果你对上面的任何条款不熟悉,我建议你抽出足够的时间来看一些c++参考读物。
TR1提出了14个新的组件(也就是程序库功能片段(pieces))。所有都被放入std命名空间中,更精确的说,是在内嵌命名空间tr1中。TR1组件 shared_ptr的全称因此就为std::tr1::shared_ptr。在这本书中,当讨论标准库的组件时,我通常会省略std::,但是我总是会为TR1组件加上前缀tr1::。
本书举例说明TR1中的一些组件:
Tr1::shared_ptr可能是TR1中最被广泛使用的对象。我在这本书中也使用了多次,包括在Item 13中,在这个条款中我解释了为什么它如此重要。(这本书没有weak_ptr的使用)
1 void registerCallback(std::string func(int)); // param type is a function 2 // taking an int and 3 // returning a string
参数名字 func是可选的,所以registerCallback可以被声明为如下:
1 void registerCallback(std::string (int)); // same as above; param 2 // name is omitted
注意在这里“std::string(int)”为函数签名。Tr1:;function可以使registerCallback更加灵活,它可以接受任何可调用实体作为它的参数,这个调用实体使用int或者可以转换为Int的任何东西作为参数,返回值可以为一个string或者可以转换为string的任何东西。Tr1::function使用目标函数签名作为模板参数:
1 void registerCallback(std::tr1::function<std::string (int)> func); 2 // the param “func” will 3 // take any callable entity 4 // with a sig consistent 5 // with “std::string (int)”
这种灵活性非常有用,我已经在Item 35中展示过了。
我将剩下的TR1组件分成两部分。第一部分提供了相当独立的功能:
TR1组件的第二个集合由为更加复杂的模板编程技术提供的支撑技术所组成,包括模板元编程(Item 48):
虽然TR1中的一些功能(尤其是tr1::bind和tr1::mem_fn)只是将pre-TR1的一些组件纳入其中,但TR1只是标准库的额外添加物。没有TR1组件是对现存组件的替换,所以使用pre-TR1构建的遗留代码仍然有效。
TR1本身只是一个文档。为了使用它指定的功能,你需要访问实现这些功能的代码。这些代码最后将会同编译器捆绑在一块发布,但是我写这本书是在2005年,如果在你的标准库实现中寻找TR1组件,可能会有一些遗漏。幸运的是,可以从其他地方进行搜寻:TR1 的14个组件中的10个是基于可以免费获得的Boost库(见Item 55)来实现的,所以如果你想了解和TR1类似(TR1-like)的功能,这会是一个很好的资源。这里我说“TR1-like”,因为虽然很多TR1功能是基于Boost库的,有一些地方Boost功能还没有同TR1规格完全匹配。很有可能但你读到这本书的时候,不仅对于从Boost 库进化而来的TR1组件,Boost中有了与其一致的实现,而且它同时提供了没有基于Boost的其余4个TR1组件的实现。
如果作为权宜之计你想使用Boost中的类似TR1的库,直到编译器同TR1实现一同被发布,你可能会使用一个命名空间的技俩。所有的Boost组件是在命名空间boost中,但是TR1组件将会在命名空间std::tr1中。你可以告诉编译器,把对std::tr1的引用当作对boost的引用来处理。像下面这样:
1 namespace std { 2 namespace tr1 = ::boost; // namespace std::tr1 is an alias 3 } // for namespace boost
从技术上来说,这会让你进入未定义行为的领域,因为正如在Item 25中解释的,不允许向std命名空间中添加任何东西。在实际情况下,看上去你不会遇到任何麻烦。当你的编译器提供了它们自己的TR1实现的时候,所有你需要做的就是移除上面的命名空间别名;引用std::tr1的代码仍然是有效的。
可能没有基于Boost库实现的TR1中的最重要的部分就是hash table了,但是hash tables已经存在很多年了,它们以hash_set,hash_multiset,hasp_map和hash_multimap命名。有可能你的编译器自带的库中已经包含这些模板了。如果没有,使用你最喜欢的搜索引擎去搜一下这些名字,因为你肯定能够找到一些源代码,无论是商业的还是免费的。
读书笔记 effective c++ Item 54 让你自己熟悉包括TR1在内的标准库
标签:hash_set mda 用户 读书 dash 有用 笔记 数学 容器
原文地址:http://www.cnblogs.com/harlanc/p/6753366.html