本文介绍了这是更快/ 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的或循环归零双打的数组?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!