数组初始化引起的性能问题

迷南。 2022-06-10 14:29 268阅读 0赞

数组初始化

  1. // array.c
  2. int main()
  3. {
  4. char a1[1024] = "";
  5. char a2[1024] = {
  6. 0};
  7. char a3[1024] = {
  8. '\0'};
  9. char a4[1024];
  10. a4[0] = '\0';
  11. return 0;
  12. }

如上代码所示,前三种都是数组初始化的方法,a4仅仅初始化第一个元素。

  1. // gcc 版本:gcc (Ubuntu 5.4.0-6ubuntu1~16.04.4) 5.4.0 20160609
  2. $gcc -g array.c
  3. // 使用objdump查看程序汇编代码
  4. $objdump -S a.out

如下图所示:
这里写图片描述

由此可知,数组a1,a2,a3都初始化整个数组为0,而a4仅初始化第一个元素。

总结

  1. 在程序中若使用较长数组时,初始化是非常消耗CPU的操作。对性能敏感的程序请谨慎选择初始化,最好优先预估一个正确的缓冲区长度,避免过大缓冲区初始化时消耗CPU。
  2. 使用数组做临时缓冲时,在得知数据长度len时,完成复制后可设置a[len] ='\0',而不必完全初始化。
  3. 当初始化的缓冲区很大时,初始化工作由memset函数完成;这里buf长度为1024,当设置为1024*1024时,可以看到程序调用了memset;因此缓冲区初始化根据长度不同使用不同的策略。

发表评论

表情:
评论列表 (有 0 条评论,268人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Race Condition引起性能问题

    Race Condition(也叫做资源竞争),是多线程编程中比较头疼的问题。特别是Java多线程模型当中,经常会因为多个线程同时访问相同的共享数据,而造成数据的不一致性。为了