数组的智能初始化
不少人使用的数组初始化方法是这样的:
int a[100];
for (int i = 0; i < sizeof(a); i++) a[i] = 0;
一个for循环的初始化方法效率显然不够高,代码也不够漂亮。其实 C++ Standard Library早已为我们提供了一个又与初始化的强力工具 memset。
void memset(void *s, int c, size_t n);
memset就是把从地址s开始的内存以字符c写入,直到有n个这样的字符被写入为止。
因此,我们利用这个强力工具来替换for循环。代码看起来漂亮多了。另外,由于memset使用底层的内存操作,效率要比for来得高。
int a[100];
memset(a, 0, sizeof(a) );
但是,一般而言我们并不是要把我们定义的数组用'a'或者什么别的字符初始化。0(NULL)才是初始化中最常用的值。基于这个事实,编译器为我们提供了智能初始化的方法。这种方法既快捷又简明。
int a[100] = {0};
有人也许以为这种形式的初始化只会令a[0]为0而其他的并不会被初始化为0。但事实并不是这样的。在标准C++中,一旦你在数组定义时就对其使用'{ }'初始化,不论'{'与'}'之间的数值是多少(当然给比数组的上界小了)编译器会自动给你没有初始化的项用0初始化。因此上面的语句实际上把数组a的所有项都初始化为0了。
如果你还不太理解或是不相信,可以看看下面的小程序,在你的机器上跑一跑。实践是检验真理的唯一标准嘛。
///: show the initialization of an array
#include <iostream>
using namespace std;
enum {array_size = 6};
void watch(const int *x) { // go through the whole array
for (int i = 0; i < array_size; i++)
cout << " x[" << i << "] = " << x[i] ;
cout << endl;
}
void main() {
int a[array_size] = {0};
int b[array_size] = {1};
int c[array_size] = {1,2,3};
int d[array_size]; //the compiler may give a warning for
//not initializing the array
watch(a);
watch(b);
watch(c);
watch(d);
}
///:~
以下是输出的结果:
x[0] = 0 x[1] = 0 x[2] = 0 x[3] = 0 x[4] = 0 x[5] = 0
x[0] = 1 x[1] = 0 x[2] = 0 x[3] = 0 x[4] = 0 x[5] = 0
x[0] = 1 x[1] = 2 x[2] = 3 x[3] = 0 x[4] = 0 x[5] = 0
x[0] = 2008948808 x[1] = 37879496 x[2] = 2009050137 x[3] = 37879776 x[4] =
2009087664 x[5] = 2008948784