数组的智能初始化 不少人使用的数组初始化方法是这样的: 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

|