好久不写代码,今天动动手就出现了bug:关于数组作为形参的bug,以及二维整型数组初始化的bug。先看看代码吧:
void test(int p[])
{
int n = sizeof(p) / sizeof(p[0]);
int m[n][n];
memset(m, 1, sizeof(p[0]) * n * n);
for(int i = 0; i < n; ++i)
{
for(int j = 0; j < n; ++j)
{
cout << m[i][j] << ' ';
}
}
}
这个简单的函数是为了说明这两个bug。
首先,你认为局部变量n的值是多少?答案是1,不管数组p中有多少个元素,n永远都是1。原因在于当数组作为参数传递给函数,该数组会退化为一个整型指针。所以,sizeof(p)等于4,而sizeof(p[0])也显然等于4,所以,n恒为1。
其次,我本想用memset对二维整型数组m进行初始化,将m中得元素全部初始化为1。然而,调试时发现,输出的m[0][0]始终为16843009。这个数字很奇怪,不是我想要的1。稍微思考一下便知道错在哪里了:void *memset(void *s, int ch, size_t n)的作用是将s中前n个字节替换为ch并返回s。注意,是前n个字节,而非前n个元素!于是,二维数组m的前4个字节统统被初始化为1,当把这4个字节作为一个整型独处时,就得到这样一个二进制数:1000000010000000100000001,计算一下它的十进制,恰好为16843009。所以,如果你想把二维整型数组中元素全部初始化为0,用memset没问题;如果想初始化为其他值,还是乖乖地用两个for比较可靠。
还是熟能生巧,不然,这些小bug还真能浪费时间呢!