bash 脚本中的计时器在长时间使用时不准确

bash 脚本中的计时器在长时间使用时不准确
#!/bin/bash

# get user input
ZENITY1=$(zenity --entry --text '  1m:    60s\n  5m:   300s\n10m:   600s\n15m:   900s\n20m: 1200s\n25m: 1500s\n30m: 1800s\n35m: 2100s\n40m: 2400s\n45m: 2700s\n50m: 3000s\n55m: 3300s\n   1h: 3600s' --entry-text "Input only int in seconds!" --title "Timer")

# put starting date in variable
STARTTIME=$(date)

# audit/check user input
WAITINGTIME=$(echo $ZENITY1 | egrep "[0-9]{1,}" -o)
if [ "$WAITINGTIME" == "" ]; then exit 1; fi

# main stopwatch
for i in `seq $WAITINGTIME -1 1`; do echo $i | osd_cat -A left -p top -i 100 -c black -d 1; done

# time expired message
zenity --info --text="Time expired@\n$(date)\n\nStarted@\n$STARTTIME"

这就是我桌面上的脚本。如果我需要警告某人:“请在 15 分钟后警告我”。但如果我使用更长的时间,例如:12小时,那就不太准确了!它可能与实际时间有约 10 分钟的差异...:\ 为什么会这样?

答案1

如果您发现它始终花费太长的时间,我猜您会看到四万多次执行echo和的开销osd_cat

相关内容