CSAPP 数组访问模式测试

一、已知结论

  1. 数组按行顺序步长为1访问模式具有最好的空间局部性-数组在内存中顺序存放
  2. 顺序访问对高速缓存友好

二、测试代码

  1. 测试数组按行顺序和列顺序的时间倍数差
  2. 测试数据:400MB数组大小 64位机器 六核i7
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define N 10000
#define M 10000
#define LEN N*M 

void sum(int *a) {  // 按行访问
    int i, j, res = 0;
    for (i = 0; i < N; i++) 
        for (j = 0; j < M; j++)
            res += *(a+N*i+j);
}

void sum2(int *a) {  // 按列访问
    int i, j, res = 0;
    for (j = 0; j < M; j++) 
        for (i = 0; i < N; i++)
            res += *(a+N*i+j);
}


int main()
{
    int *a = (int*)malloc(sizeof(int)*LEN);  // 400MB 
    for (int i = 0; i < LEN; i++)
        a[i] = 1;
    clock_t start_time, finish_time;
    double total_time;
    start_time = clock();
    // sum(a); // 0.18s
    sum2(a); // 0.63s
    finish_time = clock();
    total_time = (double)(finish_time - start_time) / CLOCKS_PER_SEC;
    printf("%fsec\n", total_time);
    return 0;
}
  1. 结论:本次测试中 行访问比列访问快3倍 结果显然与数据大小的机器配置相关
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值