Linux用两个线程来实现求和,LinuxC多线程求和

我们要实现的是,使用多线程来计算 1 ~ n 范围的所有整数和。计算运行时间因为要将普通求和程序与多线程作比较,所以先介绍一下如何计算程序运行的时间。获取时间函数:#includeint gettimeofday(struct timeval*tv, struct timezone *tz);参数:其参数tv是保存获取时间结果的结构体,参数tz用于保存时区结果。tz 一般为NULL即可。struc...
摘要由CSDN通过智能技术生成

我们要实现的是,使用多线程来计算 1 ~ n 范围的所有整数和。

计算运行时间

因为要将普通求和程序与多线程作比较,所以先介绍一下如何计算程序运行的时间。

获取时间函数:

#include

int gettimeofday(struct timeval*tv, struct timezone *tz);

参数:

其参数tv是保存获取时间结果的结构体,参数tz用于保存时区结果。tz 一般为NULL即可。

struct timezone{

int tz_minuteswest;/*格林威治时间往西方的时差*/

int tz_dsttime;/*DST 时间的修正方式*/

}

struct timeval{

long int tv_sec; // 秒数

long int tv_usec; // 微秒数

}

因为上面获取到的时间,拆分为了秒级和微秒两部分,我们需要将他们组合成一个准确的时间。下面是我自定义的函数:

double get_time()

{

struct timeval t;

gettimeofday(&t,NULL);

return t.tv_sec + t.tv_usec/1000000.0;

}

下面进入正题~

多线程求和

比如,我们要计算1到100的整数和,可以将这100个数分为2部分,利用线程并行的特点,同时计算这两部分整数的和,线程1计算1到50,线程2计算

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值