来自 32 位时间戳的 6 字节 little-endian 序列乘以 1000

Posted

技术标签:

【中文标题】来自 32 位时间戳的 6 字节 little-endian 序列乘以 1000【英文标题】:6-byte little-endian sequence from 32-bit timestamp multiplied by 1000 【发布时间】:2018-05-01 14:10:18 【问题描述】:

取 y = 1510751840。假设您想要数字 y*1000 的 6 字节 little-endian 字节序列。您正在使用 Lua 5.1。你怎么能得到它?没有整数数据类型,只有双精度,这是 Lua 的默认值。怎么可能?

例如,如果 y = 1510743753,则 6 字节序列应为:01 5f bf 58 41 28。

谢谢!

我为什么要问?我必须使用 Lua 嵌入式系统为自 UNIX 纪元以来的毫秒数生成一个 little-endian 序列。我只有秒数,所以我可以生成这个数字的 little-endian 4 字节序列。但我必须生成一个 6 字节、48 位的字节序列。所以我的想法是将 32 位时间戳乘以 1000,但我似乎无法在 Lua 5.1 可嵌入系统中乘以该数字。所以我希望有一个 hack 可以让我得到对应于时间戳 * 1000 的 6 字节序列。

【问题讨论】:

如果可以安装 LuaRocks 模块,bit32 应该启用基于整数的按位运算:luarocks.org/modules/siffiejoe/bit32 【参考方案1】:
local y = 1510743753

local lo16 = y % 2^16 * 1000 % 2^16
local hi32 = (y - y % 2^16) / 2^16 * 1000 + (y % 2^16 * 1000 - lo16) / 2^16

print(("%08x %04x"):format(hi32, lo16))   -->  015fbf58 4128

【讨论】:

【参考方案2】:

另一种方法:

function byte_n(val,byte_num)
  val = val * 1000
  for i = 1, byte_num-1 do
    val = ('%.0f'):format((val - val % 256) / 256)
  end
  return ('%02x'):format(val % 256)
end

y = 1510743753      --> 01 5f bf 58 41 28

print(byte_n(y,6))  --MSB
print(byte_n(y,5))
print(byte_n(y,4))
print(byte_n(y,3))
print(byte_n(y,2))
print(byte_n(y,1))  --LSB

【讨论】:

以上是关于来自 32 位时间戳的 6 字节 little-endian 序列乘以 1000的主要内容,如果未能解决你的问题,请参考以下文章

32位和64位数据类型大小对比

java时间戳多少位

TCP报文段的首部格式

C# 字节数组截取

STM32 SPI数据打包

IP协议