一、一个常见的方法
在定义了一个数组
int a[] = { 1, 34, 11, 23, 34, 111, 107 };
之后,我们经常看到类似于
#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0]))
的代码,它的作用便是获取数组大小。这种方法的优点是适用面广(不依赖任何第三方库),但是这个方法有个缺点,如果你不小心把一个指针传进去了,它不会报错。
二、Windows SDK的方法
Windows SDK提供了一个叫ARRAYSIZE的宏,它能获取数组大小,而且只接受数组,不接受其它类型。不过它适用面不广。
三、推荐的方法
我推荐一个方法,博采二者之长处。
template<typename T, size_t N>
char(&ArraySizeHelper(const T(&array)[N]))[N];
#define ARRAY_SIZE(array) (sizeof(ArraySizeHelper(array)))
由于C++标准规定sizeof(char)为1,故它在各个平台上结果一致。由于它实际上是一个“sizeof”,所以它可以在编译时获取到数组的大小。它不依赖任何第三方的东西,而且ArraySizeHelper的参数表决定了它只能接受数组,不能接受指针或其它类型。
四、实验
template<typename T, size_t N>
char(&ArraySizeHelper(const T(&array)[N]))[N];
#define ARRAY_SIZE(array) (sizeof(ArraySizeHelper(array)))
#include <iostream>
int wmain()
{
int a[15] = { 1, 2, 5, 6, 11 };
double b[ARRAY_SIZE(a)] = {}; // 编译成功
std::cout << ARRAY_SIZE(b) << std::endl; // 15
return 0;
}