鱼C论坛

 找回密码
 立即注册
查看: 1265|回复: 2

求助:用并行计算知识解释同一数组操作的不同速度

[复制链接]
发表于 2015-9-9 11:12:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
对于数组操作a[i] = a[i] *2,执行4百万次,为什么换了操作间距,程序速度相差会很大?
比如这是常规:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(void)
{
    clock_t start, finish;
    double duration;
    int * a = malloc(4000000*sizeof(int));
    int i;
    start = clock();
    for ( i = 1; i <= 4000000; i++)
    {
        a[i] = a[i] * 2;
    }
    finish = clock();
    duration = (double)(finish - start) / CLOCKS_PER_SEC;
    printf( "%f seconds\n", duration );
    free(a);
   
}
然后间隔20个来执行:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(void)
{
    clock_t start, finish;
    double duration;
    int * a = malloc(4000000*sizeof(int));
    int i,j,k;
   
    for (j=0; j < 10; j++)
    {
        start = clock();
        for (k = 0; k < 20 ; k++)
        {
            for ( i = k; i < 4000000; i += 20)
            {
                a[i] = a[i] * 2;
            }
        }
        finish = clock();
        duration = (double)(finish - start) / CLOCKS_PER_SEC;
        printf( "%f seconds\n", duration );
      
    }
   
    free(a);
   
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-9-9 11:36:25 | 显示全部楼层
代码一是 4000000次循环时间
代码二将近4000000*20次循环时间
你说呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-9-9 11:39:20 | 显示全部楼层
然后测试代码运行时间用要求要更加精确最好
#include<stdio.h>
#include<math.h>
#include<windows.h>

#define N 200001

int main(int argc,char ** argv)
{
        LARGE_INTEGER time,time2,ftp;
        int prime[N] = { 0 };
        int i,j,t = 200;
        QueryPerformanceFrequency(&ftp);
        
                QueryPerformanceCounter(&time);
                for (i = 3; i < N; i = i + 2)
                {
                        prime[i] = 1;
                }
                for (i = 3; i < sqrt(N); i = i + 2)
                {
                        if (prime[i])
                        {
                                for (j = i+i; j < N; j += i)
                                {
                                        prime[j] = 0;
                                }
                        }
                }
                QueryPerformanceCounter(&time2);
                printf("%d微秒\n",time2.QuadPart - time.QuadPart);
        return 0;
}
注意不要debug 要release
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 09:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表