准备看的书

cryptto 加解密的,太专业

json  json解析的

 

atexit.cc,顺便可以看一下crt0.c了解下程序的启动和关闭过程

程序退出前做动作的,通过超出变量范围时调用析构,执行事先注册在一个栈变量的函数,具体是执行的啥没看过

首先其他函数调用RegisterCallback

然后退出前具体执行 ProcessCallbacksNow();

 

base_switches.cc一些设置选项怎么用还待查

 

 

 

 

 

basictypes.h

 

template <typename T, size_t N>

char (&ArraySizeHelper(T (&array)[N]))[N];

#define arraysize(array) (sizeof(ArraySizeHelper(array)))

这个用法很是奇怪,google了下,发现跟stdlib的_countof是一样的

atlapp.h中的,符合一般的习惯用法

  #define _countof(_Array) (sizeof(_Array) / sizeof(_Array[0]))

 

 

stdlib.h中的,跟google这个一个原理

template <typename _CountofType, size_t _SizeOfArray>

char (*__countof_helper(UNALIGNED _CountofType (&_Array)[_SizeOfArray]))[_SizeOfArray];

#define _countof(_Array) sizeof(*__countof_helper(_Array))

具体解释参见http://blog.sina.com.cn/s/blog_494684f00100ihkd.html

为啥简单问题复杂化,难道atlapp中的不好么?继续看下去就知道答案了,

#define ARRAYSIZE_UNSAFE(a) ((sizeof(a) / sizeof(*(a))) / static_cast<size_t>(!(sizeof(a) % sizeof(*(a)))))

如果被传入的参数是个指针?safe就会报个编译错误,unsafe会返回一个你不想要的值,看google的代码就像看书,注释很详细

在vc下,sizeof不会返回0,但是gcc会

!(sizeof(a) % sizeof(*(a)))这个不知道什么意思,它里面说是bool跟具体实现相关,可能某些bool只占一个位?

// Since the size of bool is implementation-defined, we need to cast

 

// !(sizeof(a) & sizeof(*(a))) to size_t in order to ensure the final

// result has type size_t.

A bit field is an std::vector<bool>. It is a specialization of vector designed to optimize memory utilization. Every element in a bit field uses exactly 1 bit. The capacity of a bit field can only grow in multiples of 8, though.

 

lazy_instance.cc

使用位置new操作符 return new (instance) Type();

  int8 buf_[sizeof(Type)];  // Preallocate the space for the Type instance.

单例模式相对于全局静态变量,最大的问题就是多线程竟态下的不可预知性

google怎么做的呢?他通过原子操作InterlockedCompareExchange来比较是否为0

是的话,创建完成之后设为end,然后其他线程循环判断并sleep(0)等待创建完成,但是这个state_变量啥时候变成0的呢

难道这个类在外面也始终作为全局变量来用?是做为全局变量的

这个问题其实很难碰到,

写写应用,估计是从来不需要考虑这种问题

 

pickle.cc 处理其他格式合并到内存的一个类,以前都是使用结构,他这个不需要预定义结构了,只要打包进去就行了,再按顺序解包就行了

 

tuple 强大的元组出现了,以前要做这事,就得定义一大堆的struct,模板的使用很强大

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值