在这个"number of elements"宏中进行虚拟添加的目的是什么?
What's the purpose of dummy addition in this "number of elements" macro?
Visual C++10附带stdlib.h,其中包含以下gem:
template <typename _CountofType, size_t _SizeOfArray>
char (*__countof_helper(UNALIGNED _CountofType (&_Array)[_SizeOfArray]))[_SizeOfArray];
#define _countof(_Array) (sizeof(*__countof_helper(_Array)) + 0)
它使用了一个巧妙的模板技巧来推断数组大小并防止指针被传递到CCD_ 1中。
+ 0
在宏定义中的用途是什么?它解决了什么问题?
从这里引用STL
我做了这个改变;我通常不会破解CRT,但这次不重要的+0使虚假的"警告C6260:sizeof*sizeof"静音通常是错误的。您打算使用字符计数还是字节计数"当有人写_countof(arr)*sizeof(T)时,从/分析。
在宏定义中使用+0的目的是什么?什么问题它解决了吗?
我觉得它解决不了任何问题。它可能被用来压制另一个答案中提到的一些警告。
重要的是,以下是在编译时查找数组大小的另一种方法(我个人觉得它更可读):
template<unsigned int SIZE>
struct __Array { char a[SIZE]; }
template<typename T, unsigned int SIZE>
__Array<SIZE> __countof_helper(const T (&)[SIZE]);
#define _countof(_Array) (sizeof(__countof_helper(_Array)))
[p.S.:将此视为注释]
相关文章:
- 有没有比在库中添加一个并非由所有派生类实现的新虚拟函数更好的设计实践
- 添加虚拟析构函数会使代码大小膨胀
- 为什么虚拟类的析构函数不会自动添加到 vtable 中?
- 在派生类中添加虚拟说明符
- 将static_pointer_cast添加到<Derived> std::list<shared_ptr<Base>> 会导致称为 error 的纯虚拟方法
- 为什么此指针值在C 中添加虚拟关键字后更改
- 为什么添加虚拟方法在C 中增加了类大小
- 当我在派生类中添加额外的虚拟功能时,什么是开销
- 如何正确覆盖虚拟方法以添加功能
- 为什么没有将虚拟静态成员添加为C++的一个功能
- 将第一个虚拟函数添加到类中
- 为特定虚拟方法添加更多参数
- 在C++中为纯虚拟/抽象函数添加主体
- 在C++中,是否允许强制转换为仅添加非虚拟方法的派生类
- 向虚拟方法添加默认参数
- C++在多态子类中添加虚拟方法
- 与std::bind相反,向函数中添加虚拟参数
- 向std::packaged_task添加虚拟复制构造函数
- 使用代理向Qt SQL模型添加虚拟列
- 如何使用C++在Windows中添加虚拟文件夹