位置: IT常识 - 正文

Google C++ Style中允许使用的Boost库(1) 程序即人生 博客频道 CSDN.NET

编辑:rootadmin
Google C++ Style中允许使用的Boost库(1) - 程序即人生 - 博客频道 - CSDN.NET Google C++ Style中允许使用的Boost库(1) 分类: 【C++】 Google C++ Style中允许使用的Boost库(1) 分类: 【C++】 2011-07-05 09:37 5837人阅读 评论(14) 收藏 举报

write by 九天雁翎(JTianLing) -- blog.jtianling.com

新浪微博--讨论新闻组--代码库--豆瓣

前言

推荐整理分享Google C++ Style中允许使用的Boost库(1) 程序即人生 博客频道 CSDN.NET,希望有所帮助,仅作参考,欢迎阅读内容。

Google C++ Style中允许使用的Boost库(1)  程序即人生  博客频道  CSDN.NET

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

作为系列的第一篇,如同往常一样唠叨几句吧,好久不写这种单纯语言相关的(特别是C++)文章了,因为慢慢觉得这些东西自己学学就OK,实际写出来的价值有限,因为思想少,技巧/知识多。因为前段时间做了半年多的Object C和JAVA了,并且C++ 0x标准就要出来了,语言改变还挺大,趁这个节骨眼,顺面再回头学习/总结一些我感兴趣的C++知识吧,不过应该持续时间不会太长,这个系列也不会太长,因为语言已经不是我关注的重点~~~~Google的C++ Style Guide是我自己写东西的时候遵循的C++代码风格规范,前段时间看到李开复说他才发现Google的C++规范已经公开了,说这是世界上最好的C++规范,我感到很惊讶,因为N年前这个规范已经就公开了-_-!事实上,Google的 C++ Style Guide远不仅是一个传统意义上的代码书写风格指导,对于C++的方方面面做出了Google的解释和使用建议,包括每个规则给出时,较为详细的讲了这个规则好的一面和不好的一面,最最激进的规则甚至有禁用C++的异常,以及除了Google规范的Interface作为基类外,禁用多重继承,在绝大部分情况下禁用默认参数等内容。在很大程度上,Google是想把C++打造成效率高的JAVA来使用~~~~Google的C++ Style Guide有关于Boost的一节,允许使用的Boost库如下:Call Traitsfrom boost/call_traits.hppCompressed Pairfrom boost/compressed_pair.hppPointer Containerfrom boost/ptr_container except serialization and wrappers for containers not in the C++03 standard (ptr_circular_buffer.hpp and ptr_unordered*)Arrayfrom boost/array.hppThe Boost Graph Library (BGL)from boost/graph, except serialization (adj_list_serialize.hpp) and parallel/distributed algorithms and data structures (boost/graph/parallel/* andboost/graph/distributed/*).Property Mapfrom boost/property_map, except parallel/distributed property maps (boost/property_map/parallel/*).The part ofIteratorthat deals with defining iterators: boost/iterator/iterator_adaptor.hpp, boost/iterator/iterator_facade.hpp, and boost/function_output_iterator.hpp对此我感到比较惊讶,除了Array没啥好疑问的以外,我发现一些的确很好用的Boost库Google并不允许使用,比如boost::bind,boost::function,boost::lambda等,这个我不理解~~~~而Google提及的几个Boost库,除了Array很简单实用,BGL是一个数据结构和算法的扩充库,以前没有接触不奇怪外,其他的东西我发现自己竟然没有太接触过,作为自认为C++学习已经接近语言律师的我情何以堪-_-!~~~~~因为很多时候,一个Boost库就代表着一个C++的缺陷的补救,因为即使最后不用Boost库,了解一下对于怎么正确的使用C++还是有很大帮助的。特作此系列。1.Call Traitsfrom boost/call_traits.hpp先谈谈什么是Traits,BS的解释如下:

Think of a trait as a small object whose main purpose is to carry information used by another object or algorithm to determine "policy" or "implementation details". - Bjarne Stroustrup可以参考这里。所谓Call Traits就是调用时需要的Traits。Call Traits中文文档看下基本就明白啥意思了。我感觉最大的作用是在写模版类/模版函数传递参数时,保证没有“引用的引用”的情况发生,并且总以最高效的形式传递参数。所谓的最高效形式的规则类似JAVA,(仅仅是类似)即原生的类型就使用传值方式,对象就采用传引用方式。这里有个中文的例子。正常情况下,一个函数在C++中要么以传值方式传递参数,要么以传引用的方式传递,没法两者兼得:template <class T>class TestClass {

public:

TestClass(T value) { } TestClass(const T& value) { } T value_;};在使用时会报错:error C2668: 'TestClass<T>::TestClass' : ambiguous call to overloaded function因为C++的函数重载规则并没有规定在这种情况下会调用哪一个函数,导致二义性。使用Call_Traits的param_type作为参数类型时,以下例子:int g_i = 0;class PrintClass {public: PrintClass() { printf("PrintClass created"); ++g_i; }};template <class T>class TestClass {public: TestClass(typename boost::call_traits<T>::param_type value) : value_(value){ } T value_;}; TestClass<int> test(10); PrintClass printClass; TestClass<PrintClass> testPrintClass(printClass);g_i会等于1,实际因为传递的typename boost::call_traits<T>::param_type value在参数类型是PrintClass(一个对象)时,传递的是引用。同时,我没有想到更好的办法去验证在传递的参数是int类型时,的确是通过时传值。这样说来就很有意思了,因为即使我们在使用模版时函数全部通过传值方式来设计,会在T是对象时导致很大的额外开销,我们全部通过const T&的方式来传递参数就好了,就算是原生类型,这种额外开销还是小到足够忽略不计的,只是,boost库的制作者觉得这样还是不够完美?同时,Call Traits还解决一个问题,那就是"引用的引用",比如上例中T为T&时的情况..........函数参数假如是通过传递引用的方式的话,const T&的参数,T又等于T&,那么就是const T&&了,C++中没有引用的引用这种东西的存在(只有指针的指针),事实上,Call Traits给函数的调用和参数的类型有完整的一套解决方案,如boost文档中的example 1:template <class T>struct contained{ // define our typedefs first, arrays are stored by value // so value_type is not the same as result_type: typedef typename boost::call_traits<T>::param_type param_type; typedef typename boost::call_traits<T>::reference reference; typedef typename boost::call_traits<T>::const_reference const_reference; typedef T value_type; typedef typename boost::call_traits<T>::value_type result_type; // stored value: value_type v_; // constructors: contained() {} contained(param_type p) : v_(p){} // return byval: result_type value() { return v_; } // return by_ref: reference get() { return v_; } const_reference const_get()const { return v_; } // pass value: void call(param_type p){}};2.Compressed Pairfrom boost/compressed_pair.hpp这里正好找到一个很perfect的文章,简单的说就是当pair中某个类是空类时,compressed Pair比std中的pair会更省一些空间(1个字节...........),我几乎没有想到我实际工作中有什么对空间要求非常高并且还会使用pair的情况.................这也就是compressed_pair的尴尬之处了。可以稍微提及的是,看看compressed pair的定义,就能看到call traits的使用:template <class T1, class T2>class compressed_pair{public: typedef T1 first_type; typedef T2 second_type; typedef typename call_traits<first_type>::param_type first_param_type; typedef typename call_traits<second_type>::param_type second_param_type; typedef typename call_traits<first_type>::reference first_reference; typedef typename call_traits<second_type>::reference second_reference; typedef typename call_traits<first_type>::const_reference first_const_reference; typedef typename call_traits<second_type>::const_reference second_const_reference; compressed_pair() : base() {} compressed_pair(first_param_type x, second_param_type y); explicit compressed_pair(first_param_type x); explicit compressed_pair(second_param_type y); compressed_pair& operator=(const compressed_pair&); first_reference first(); first_const_reference first() const; second_reference second(); second_const_reference second() const; void swap(compressed_pair& y);};说实话,虽然逻辑上感觉完美了,但是代码上还真是累赘...........typedef简直就是C++强类型+类型定义复杂最大的补丁工具.............但是总的来说compress pair是很简单的东西,不多讲。3.Arrayfrom boost/array.hppArray也是最简单的boost库使用类之一了,用于以最小性能损失替代原生C语言数组,并且像vector一样,提供使用的函数和合理的封装(STL提供的vector因为是变长数组,还是有一定的性能损失)感觉不是非常非常效率要求的工程,可以将所有的C语言数组都用Array来代替,意义更加明确,迭代器使用也会更加方便,容器的使用语法也更加统一。另外,C++0X已经确定添加array库,array将来就是未来的标准库,可以较为放心的使用,并且即使使用了,也是可维护的代码(即使将来使用C++0X时也是一样)。操作示例: boost::array<int, 100> intArray; intArray.fill(10); for (boost::array<int, 100>::iterator it = intArray.begin(); it != intArray.end(); ++it) { *it = 20; }小结:基本上,1.call traits是看需求了,假如你实现模板库有需要才使用,不要因为真的仅仅为了一个函数的参数调用能够以最优化的方式进行而去使用call traits。2.comress pair是我不太推荐使用(为了一点点空间,而增加理解的难度不值,推荐的方式是将来STL的pair实现就是compress pair)3.array是推荐使用原则是,有利于抽象和源代码易读性的用,否则不用.............

原创文章作者保留版权 转载请注明原作者 并给出链接

write by 九天雁翎(JTianLing) -- blog.jtianling.com

本文链接地址:https://www.jiuchutong.com/zhishi/303703.html 转载请保留说明!

上一篇:php数组中array_column()函数的使用(php中array用法)

下一篇:php初级面试题的总结(php面试知识点)

  • 旧设备出口增值税处理
  • 免征增值税和增值税区别
  • 旅游发票可以抵扣吗
  • 增值税抵扣不够怎么解决
  • 个体工商户开普票流程
  • 残保金在职职工人数临时工算吗
  • 单位社保缴费基数怎么确定
  • 新会计准则开办费分摊
  • 非居民企业直接投资居民企业取得股息
  • 工业土地划拨性质有年限吗
  • 向境外分派红利怎么计算缴纳企业所得税
  • 会计录入凭证怎么录入
  • 股息红利纳税地点
  • 专项用途财政资金纳税调整规则
  • 租赁收入无发票怎么做账
  • 跨年暂估收入如何调整
  • 销售新的固定资产怎么算
  • 账本印花税税金及附加怎么入账?
  • 开票信息没有电话号码可以吗
  • 建筑工程预收款开票会计分录
  • 员工吃饭发票的怎么报销
  • linux系统配置ip地址命令
  • 王者荣耀中白起的台词
  • php面包屑导航
  • php实现查询功能
  • 计算机怎么设置长亮
  • 残疾人增值税即征即退政策2020
  • 财政应返还额度是什么意思?
  • 先出库还是先发货
  • 辅助生产成本是
  • php常用时间函数
  • 单位购买降暑用品
  • CLIP模型原理
  • 捆绑销售如何进行账务处理?
  • 借款费用如何确认收入
  • 其他综合收益的借贷方向
  • 20分钟,使用Amazon SageMaker快速搭建属于自己的AIGC应用
  • 自动驾驶感知算法
  • python快速检索
  • php7 数组
  • php入门实例
  • 税款返还 分录
  • 兼职算受雇吗
  • 收到银联代收短信
  • 工会的钱怎么取出来
  • 2020年维修基金怎么交
  • 进出口会计账务处理
  • 房地产项目转让流程
  • 建行E信通贴现需要发票吗
  • 安装调试费属于劳务还是服务
  • 入库单金额写错可以改吗
  • 应付账款周转次数计算
  • 以前年度多计提了费用
  • 业务员出差借款,用途写什么
  • 委托付款做账怎么做
  • 公司没有收入怎么办
  • 销售方开具的红字专票购买方在税控盘要怎么操作
  • 外汇申报材料
  • 预提费用如何预提
  • 会计凭证装订的心得体会
  • 委托收款商业汇票
  • 查找非空顺序表l中第一个最大的元素
  • sqlserver临时表详解
  • mysql5.7.35安装
  • window10系统电脑配置
  • jucheck.exe是什么
  • win8查看内存
  • window无法正常启动怎么办
  • win7注册表文件位置
  • xp磁盘空间不足怎么办
  • pm2使用手册
  • linux百度网盘安装
  • python遍历列表判断相同元素
  • unity游戏开发软件
  • python怎么用命令行
  • 国家税务电子发票查验入口
  • 国家税务局39号公告退税
  • 阜阳烟草证办理条件
  • 河北省职称证去哪里查
  • 出口退税函调管理办法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设