百科问答小站 logo
百科问答小站 font logo



memcpy比循环赋值快吗?为什么? 第1页

  

user avatar   zhang-hao-72 网友的相关建议: 
      

除了各位提到的simd, 在支持dma的平台上可以用dma优化. cpu需要做的只是告诉dma控制器, 源地址, 目的地址, 需要copy多少个、多少位宽的数据, 开始传输,等着完事。

单论传输时间不一定比直接赋值快(可能慢不少),但是在等待dma控制器那边说“传完了”的这段时间, cpu可以并行去干别的事了,总的来说还是快的。

ARM支持内存到内存的DMA传输(比内存到设备还是要慢一些),x86以前不支持,但是现在也有办法了,详细见链接:

还有这个:


user avatar   yang-lei-96-72 网友的相关建议: 
      

共产主义政党长期治理的喀拉拉邦在印度处于人类发展指数的前茅,这就是共产主义对印度的影响。

印度及印占藏南、印占克什米尔的人类发展指数


另外,南亚人是非常非常喜欢取经名的。这也是一个地域特色了。




  

相关话题

  C 语言的「void main」是怎么一代代传下来的? 
  semaphore和mutex的区别? 
  c语言0xFFFF换成十进制不应该是65535吗? 
  为什么要有指针? 
  运行时异常处理程序是如何实现的? 
  写 C C++ 语言时候,如果每次申请内存就把 Free 内存的代码写上,是否能有效避免内存泄漏? 
  C++的CRTP所带来的静态多态功能具体有什么用? 
  「C++ 早就过时了,大部分写工程不用 C++,学习这个语言只是为了竞赛」的观点是否正确? 
  Linus Torvalds 开过哪些著名的嘴炮? 
  为什么C++在构造函数和析构函数中不能抛出异常? 

前一个讨论
同样用pow()表示10^2,为什么分别用字面量和变量作参数会返回不同的值?
下一个讨论
一个人想写出foxmail这种软件,需要知道哪些知识(详细的)?





© 2025-05-27 - tinynew.org. All Rights Reserved.
© 2025-05-27 - tinynew.org. 保留所有权利