asd001110 2016-05-24 13:35 采纳率: 0%
浏览 1075
已结题

cache line填充后运行时间问题

#include
#include

int main(int argc,char* argv[])
{
int len = 64*1024*1024;
int K =atoi(argv[1]);
int arr = (int)malloc(sizeof(int)*len);
int i;
for(i=0;i<len;i+=K)
{
arr[i]*=3;
}
return 0;
}

 按照http://blog.csdn.net/cool_way/article/details/41855595这篇文章说法,K的取值只有在
 16到32,64等64字节处 时间才会发生越变,可是我在Ubuntu上测试的结果却完全不同
 在1和2和4间变化较快,到了后面基本不变,这是什么原因,希望各位大牛解读

  • 写回答

1条回答

  • threenewbee 2016-05-24 13:40
    关注

    不同的处理器缓存的大小、速度、架构、层次、结合性、缓存淘汰算法是不同的,作者只是根据他的处理器的经验写的,没有普遍性。

    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题