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

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

内容如下:

linux通过time命令统计代码编译时间_第1张图片

然后执行time sh build.sh 

linux通过time命令统计代码编译时间_第2张图片

编译完成后输出三个时间 

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

linux通过time命令统计代码编译时间_第3张图片

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

修改下脚本  加上时间 

linux通过time命令统计代码编译时间_第4张图片

输出结果

linux通过time命令统计代码编译时间_第5张图片

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

在换成单核编译

linux通过time命令统计代码编译时间_第6张图片

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

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

linux通过time命令统计代码编译时间_第7张图片

然后改成j2  如下

linux通过time命令统计代码编译时间_第8张图片

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

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

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

linux通过time命令统计代码编译时间_第9张图片

然后试了下make -j4 

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

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

测试只能make这样编译

linux通过time命令统计代码编译时间_第10张图片

测试第二次还 9分钟 18秒  

小盒子的配置如下

linux通过time命令统计代码编译时间_第11张图片

linux通过time命令统计代码编译时间_第12张图片

linux通过time命令统计代码编译时间_第13张图片

还写的4核 拿来写写hello world还行 大项目的话还是不行
linux通过time命令统计代码编译时间_第14张图片
linux通过time命令统计代码编译时间_第15张图片
linux通过time命令统计代码编译时间_第16张图片
今天又在主力的办公电脑上测试了下  
公司的DELL笔记本 
linux通过time命令统计代码编译时间_第17张图片
里面装了个linux mint20的虚拟机 虚拟机 分配了4G内存
单核编译
linux通过time命令统计代码编译时间_第18张图片
j4 编译
Add 20230930   今天 在 家里的台式机 13 4170 上装了个虚拟机 ubuntu 2204
又测试了下同样的代码 
单核情况下  1分钟42秒 
j4 情况下 49秒
j2 情况下 44秒 
cpu本身是 2核下4线程 
j4反而变慢了 

你可能感兴趣的:(linux,运维,服务器)