bash 脚本比较 100 个程序运行时间,精确到毫秒,脚本

脚本如下:

bash 复制代码
#!/bin/bash

# 设置测试次数
NUM_TESTS=100
# 设置要测试的程序路径
PROGRAM="./your_program"  # 替换为你的程序路径
# 设置程序参数(如果没有参数则留空)
ARGS=""  # 例如: "input.txt output.txt"

# 初始化统计变量
total_time=0
min_time=999999.99
max_time=0

echo "开始测试 $PROGRAM,共 $NUM_TESTS 次运行..."

# 创建结果文件
result_file="timing_results_$(date +%Y%m%d_%H%M%S).csv"
echo "运行次数,时间(秒)" > "$result_file"

for ((i=1; i<=$NUM_TESTS; i++))
do
    # 使用time命令计时,精度到毫秒
    start_time=$(date +%s.%3N)
    
    # 运行程序(后台运行,捕获输出和错误)
    $PROGRAM $ARGS > /dev/null 2>&1
    
    end_time=$(date +%s.%3N)
    
    # 计算耗时(秒,保留3位小数后四舍五入到2位)
    elapsed=$(echo "scale=3; $end_time - $start_time" | bc)
    elapsed=$(printf "%.2f" $elapsed)
    
    # 更新统计信息
    total_time=$(echo "scale=2; $total_time + $elapsed" | bc)
    
    # 比较并更新最小时间(使用awk处理浮点数比较)
    if (( $(echo "$elapsed < $min_time" | bc -l) )); then
        min_time=$elapsed
    fi
    
    # 比较并更新最大时间
    if (( $(echo "$elapsed > $max_time" | bc -l) )); then
        max_time=$elapsed
    fi
    
    # 输出当前结果并写入文件
    echo "第 $i 次: $elapsed 秒"
    echo "$i,$elapsed" >> "$result_file"
done

# 计算平均值
average_time=$(echo "scale=2; $total_time / $NUM_TESTS" | bc)

echo ""
echo "============= 测试结果 ============="
echo "测试程序: $PROGRAM $ARGS"
echo "测试次数: $NUM_TESTS"
echo "总耗时: $total_time 秒"
echo "平均时间: $average_time 秒"
echo "最短时间: $min_time 秒"
echo "最长时间: $max_time 秒"
echo ""
echo "详细结果已保存到: $result_file"
相关推荐
How_doyou_do25 分钟前
数据传输优化-异步不阻塞处理增强首屏体验
开发语言·前端·javascript
jingfeng51442 分钟前
C++11可变参数模板、emplace系列接口、包装器
开发语言·c++
云天徽上43 分钟前
【数据可视化-107】2025年1-7月全国出口总额Top 10省市数据分析:用Python和Pyecharts打造炫酷可视化大屏
开发语言·python·信息可视化·数据挖掘·数据分析·pyecharts
Tina表姐1 小时前
(C题|NIPT 的时点选择与胎儿的异常判定)2025年高教杯全国大学生数学建模国赛解题思路|完整代码论文集合
c语言·开发语言·数学建模
轮到我狗叫了2 小时前
牛客.小红的子串牛客.kotori和抽卡牛客.循环汉诺塔牛客.ruby和薯条
java·开发语言·算法
yudiandian20142 小时前
【QT 5.12.12 下载 Windows 版本】
开发语言·qt
高山有多高3 小时前
详解文件操作
c语言·开发语言·数据库·c++·算法
狂奔的sherry3 小时前
单例模式(巨通俗易懂)普通单例,懒汉单例的实现和区别,依赖注入......
开发语言·c++·单例模式
EnigmaCoder3 小时前
【C++】引用的本质与高效应用
开发语言·c++
zhangfeng11334 小时前
BiocManager下载失败 R语言 解决办法
开发语言·r语言