每次看到c++的奇技淫巧都觉得这门语言过于复杂庞大,可有时会忍不住去学习,今天学到一个c++判断数组大小,写下做纪念
在c中判断数组大小经常用 #define num(x) sizeof(x)/sizeof(0[x])注意这里用0[x]作用是防止自定义类型计算,但我们用一个指针指向一个数组时。比如int a[2];int *p=a;
num(p) 计算会得到1,但这不是我们要的结果,既然不是我们要的结果,我们应该最好报错在编译期。
#include<stdio.h>
#include<stdlib.h>
#define num(x) sizeof(x)/sizeof(0[x])
template<int N>
struct array_size_struct
{
char c[N];
};
template<class T,int N>
array_size_struct<N> static_size_fn(T (&)[N]);
#define cppnum(x) sizeof(static_size_fn(x).c)
int main()
{
char a[3];
char *p=a;
printf("%d",cppnum(a));
printf("%d",num(p));
}
在这里static_size_fn只是声明,所以不存在任何运行期开销,T(&)[N]是一个T类型数组的引用,返回一个结构体,同时把N写入到c数组,这样sizeof(static_size_fn(x).c)
相当于sizeof(c)。而当传入指针时候编译器会报错, error C2784: “array_size_struct<N> static_size_fn(T (&)[N])”: 未能从“char *”为“T (&)[N]”推导 模板 参数。