数组初始化引起的性能问题
数组初始化
// array.c
int main()
{
char a1[1024] = "";
char a2[1024] = {
0};
char a3[1024] = {
'\0'};
char a4[1024];
a4[0] = '\0';
return 0;
}
如上代码所示,前三种都是数组初始化的方法,a4仅仅初始化第一个元素。
// gcc 版本:gcc (Ubuntu 5.4.0-6ubuntu1~16.04.4) 5.4.0 20160609
$gcc -g array.c
// 使用objdump查看程序汇编代码
$objdump -S a.out
如下图所示:
由此可知,数组a1,a2,a3都初始化整个数组为0,而a4仅初始化第一个元素。
总结
- 在程序中若使用较长数组时,初始化是非常消耗CPU的操作。对性能敏感的程序请谨慎选择初始化,最好优先预估一个正确的缓冲区长度,避免过大缓冲区初始化时消耗CPU。
- 使用数组做临时缓冲时,在得知数据长度len时,完成复制后可设置
a[len] ='\0'
,而不必完全初始化。 - 当初始化的缓冲区很大时,初始化工作由memset函数完成;这里buf长度为1024,当设置为1024*1024时,可以看到程序调用了memset;因此缓冲区初始化根据长度不同使用不同的策略。
还没有评论,来说两句吧...