shell脚本获取时间戳偶尔报错value too great

2020-05-05  本文已影响0人  猫尾草

1. 问题:

  在linux Shell中并没有毫秒级的时间单位,只有秒和纳秒。所以在shell中可以获取秒级时间戳,但是不能获取毫秒级时间戳。
  有时候确实需要毫秒级时间戳,于是使用秒和纳秒的时间戳来组合一下。通常我们看到的都是如下写法:

timestamp=$((`date '+%s'`*1000+`date '+%N'`/1000000))
echo $timestamp

这个方法你快速地反复去执行,大概五六次就会出现一次报错value too great for base

2. 原因:

  date '+%N'获取纳秒时获取的是一个字符串,而不是数字,且为了保证九位数,前面会补0,例如073526864。遇到首字母为0的字符串,shell正常的除法不能自动将其转换为数字(是的,虽然你看不到有数据类型,但是他是分数字和字符串类型的,并且使用的时候一般都隐含了类型转换,lua也有这个问题,被坑过无数次)。

3. 解决方法:

  使用expr命令

timestamp=`expr $(date '+%s') \* 1000 + $(date '+%N') / 1000000`
echo $timestamp

需要注意的是乘法符号*需要写成\*,不然无法识别为乘法符号。

上一篇 下一篇

猜你喜欢

热点阅读