linux通过time命令统计代码编译时间

首先编写一个编译脚本 build.sh

内容如下:

然后执行time sh build.sh 

编译完成后输出三个时间 

time sh xxx.sh
# 会返回3个时间数据
(1) real:从进程 ls 开始执行到完成所耗费的 CPU 总时间。该时间包括 ls 进程执行时实际使用的 CPU 时间,ls 进程耗费在阻塞上的时间(如等待完成 I/O 操作)和其他进程所耗费的时间(Linux 是多进程系统,ls 在执行过程中,可能会有别的进程抢占 CPU)。
 
(2) user:进程 ls 执行用户态代码所耗费的 CPU 时间。该时间仅指 ls 进程执行时实际使用的 CPU 时间,而不包括其他进程所使用的时间和本进程阻塞的时间。
 
(3) sys:进程 ls 在内核态运行所耗费的 CPU 时间,即执行内核系统调用所耗费的 CPU 时间。
 
现在,我们应该对这三个时间非常清楚了吧。ls 命令的真正执行时间是多少?答案就是 user+sys 的时间,但一般情况下,real=user+sys,因而我们就使用 real 的时间作为 ls 的执行时间了(注意,这里会有几个坑,我们将在后面进行介绍)。

重新修改加脚本 加上4核编译

make -j4

这么一看上面的说法就不成立了 

修改下脚本  加上时间 

输出结果

可以看到 结束时间-开始时间大约19秒  差不多= real时间 

在换成单核编译

所以 看real时间就可以知道 项目编译的耗费了多少时间了 

我的cpu是64核 再把j改成大点的数字试下 和j4的时间差不多 

然后改成j2  如下

实际测试 j大于4 没啥效果   也有可能和我的工程有关系 

晚上回来 在刚买的arm小盒子上试了下 

同样的工程单核编译时间:

然后试了下make -j4 

小主机直接挂了 没有响应了 

改成j2还是会挂。只能把电源拔了

测试只能make这样编译

测试第二次还 9分钟 18秒  

小盒子的配置如下

还写的4核 拿来写写hello world还行 大项目的话还是不行
今天又在主力的办公电脑上测试了下  
公司的DELL笔记本 
里面装了个linux mint20的虚拟机 虚拟机 分配了4G内存
单核编译
j4 编译
Add 20230930   今天 在 家里的台式机 13 4170 上装了个虚拟机 ubuntu 2204
又测试了下同样的代码 
单核情况下  1分钟42秒 
j4 情况下 49秒
j2 情况下 44秒 
cpu本身是 2核下4线程 
j4反而变慢了 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

QMCY_jason

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值