当前位置: 首页 > news >正文

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还行 大项目的话还是不行
http://www.lryc.cn/news/176129.html

相关文章:

  • logback日志是怎么保证多线程输出日志线程安全的
  • 2022年统计用区划代码表SQL 01
  • EM@基本初等函数@幂和根式@指数函数
  • 时序预测 | MATLAB实现NGO-GRU北方苍鹰算法优化门控循环单元时间序列预测
  • element 二次确认框,内容自定义处理
  • 【软件设计师-中级——刷题记录4(纯干货)】
  • 9.24 校招 实习 内推 面经
  • 第二章:25+ Python 数据操作教程(第二十五节用 PYTHON 和 R 制作祝福圣诞节)持续更新
  • 你是怎么理解自动化测试的?理解自动化测试的目的和本质
  • 二十六、MySQL并发事务问题:脏读/不可重复读/幻读
  • RK3588平台开发系列讲解(项目篇)视频监控之RTMP推流
  • http基础教程(超详细)
  • Vue3 <script setup> 单文件组件 组合式 API 相关语法
  • 为什么说网络安全是IT行业最后的红利?是风口行业?
  • DD5 进制转换
  • 操作系统权限提升(二十七)之数据库提权-MySQL MOF提权
  • springcloud:四、nacos介绍+启动+服务分级存储模型/集群+NacosRule负载均衡
  • 人生第一个java项目 学生管理系统
  • Oracle统计信息手动收集与修改
  • 鸿鹄工程项目管理系统 Spring Cloud+Spring Boot+Mybatis+Vue+ElementUI+前后端分离构建工程项目管理系统
  • ubuntu安装freeswitch 1.10.10
  • 什么类型的企业适合应用RPA?
  • LuatOS-SOC接口文档(air780E)-- fdb - kv数据库,掉电不丢数据
  • 世界500强都摒弃使用FTP的真实原因
  • 医院电子病历编辑器,EMRE(EMR Editor)源码
  • 分享从零开始学习网络设备配置--任务3.8 使用动态路由OSPF实现网络连通
  • 构建高效的同城O2O外卖系统APP:技术要点和最佳实践
  • 【残差网络ResNet:残差块输入输出形状控制】
  • 【编译和链接——详解】
  • 【python爬虫】爬虫所需要的爬虫代理ip是什么?