这是更快/ preferred:memset的或循环归零双打的数组? [英] Which is faster/preferred: memset or for loop to zero out an array of doubles?

查看:107
本文介绍了这是更快/ preferred:memset的或循环归零双打的数组?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

 双D [10];
INT长度= 10;memset的(D,长*的sizeof(双),0);//要么的for(int i =长度;我 - ;)
  D [i] = 0.0;


解决方案

请注意,对于memset的你必须通过的字节数,而不是元素的数量,因为这是一个老的C函数:

  memset的(D,0,sizeof的(双)*长);

的memset的可以的会更快,因为它是用汇编写的,而的std ::填写是一个模板函数,它只是做内部循环。

但类型安全和更具可读性code 我会建议 的std ::填写() - 这是C ++的方式做的事情,并考虑 memset的如果需要在这个地方在code进行性能优化。

double d[10];
int length = 10;

memset(d, length * sizeof(double), 0);

//or

for (int i = length; i--;)
  d[i] = 0.0;

解决方案

Note that for memset you have to pass the number of bytes, not the number of elements because this is an old C function:

memset(d, 0, sizeof(double)*length);

memset can be faster since it is written in assembler, whereas std::fill is a template function which simply does a loop internally.

But for type safety and more readable code I would recommend std::fill() - it is the c++ way of doing things, and consider memset if a performance optimization is needed at this place in the code.

这篇关于这是更快/ preferred:memset的或循环归零双打的数组?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆