我在开发我的聊天机器人程序时遇到一个特殊的问题:因为我的存储系统可能存在 bug ,写入数据读出来可能不对(小概率) 所以我希望在 float 的 4 个字节中嵌入我的校验信息,达到这种效果:
请问哪位大神能帮我?
1
enenaaa 2017-01-11 13:46:50 +08:00
检验数据可以附在正常数据后面。 为啥非得在 float 格式上较真?
|
2
warmheartli OP @enenaaa 因为我不知道是不是存储系统的 bug ,也可能是我程序的 bug ,所以如果要是附加到正常数据后面,那这里的“正常数据”有可能已经是错的了
|
3
kysida 2017-01-11 13:59:48 +08:00
楼上+1 ,你的校验数据可以放在你的数据后面或者前面作为一个 flag
|
4
Kilerd 2017-01-11 14:17:02 +08:00 via iPhone
那你需要重新定义中新的 float ,底层储存方式都要重新设计。加油,少年。
最简单的就是奇偶检验,其他的检验方式看回科班的书吧。 |
5
canfoderiskii 2017-01-11 14:22:40 +08:00 via Android
你动了 float 的内部格式还怎么满足 ieee754 标准
|
6
knightdf 2017-01-11 14:25:52 +08:00
我们曾经用 redis 时也出现了这个 BUG ,后来。。。恩,确实是程序的 BUG ,不能怪 redis
|
7
dallaslu 2017-01-11 14:37:49 +08:00 1
float 的前八位是指数位,后 24 位是尾数。
你可以牺牲尾数精度,来占用最右的 n 个 bits 来写入你的校验信息。或者占用第 9 位到第 9+n 位。 在写入和读取时都需要有这种处理转换,以保证程序在内存中使用的依然是标准的、准确的 float 。 float 与 byte[] 转换可参考: http://blog.csdn.net/cshichao/article/details/9813973 |
8
warmheartli OP 我先说一个我想的方案,大家帮我参谋一下,因为我确定我的 float 的取值范围最大不会超过 2^30 ,所以我把浮点数加上固定的 2^30+2^32+2^34+2^36 ,读的时候我就看我的浮点数减去 2^30+2^32+2^34+2^36 得的数是不是在正负 2^30 之间,还有没有别的办法?
|
9
v2dead 2017-01-11 15:00:19 +08:00
为什么不老老实实用 crc 一类的校验码呢。回去看看科班的书还是有用的。附加在数据后面,即使校验码错了也一样的。
|
10
xiao17174 2017-01-11 16:07:17 +08:00
不知道你怀疑的存储的 BUG 是什么粒度的?位级别?不如直接每次存 float 就存两次?
|
11
lucifer9 2017-01-11 16:58:49 +08:00
遇到这种情况,正常的想法不是赶紧换硬盘换内存么?
|
13
SmiteChow 2017-01-11 17:11:31 +08:00
一个问号?既然你存储系统有问题,你的校验特征码即便算出来了,和你想存储的东西混一起了,读出来也会有问题啊
|
14
pmispig 2017-01-11 18:27:47 +08:00
单字节异或得出值到第 5 个字节
|
15
warmheartli OP @dallaslu 靠谱
|
16
fffflyfish 2017-02-02 11:21:29 +08:00
@warmheartli shareditor.com 这个网站挂掉了,还会再开吗?( v 站没有私信的方式,我就随便找了一个您的帖子,恕我冒昧~)
|
17
warmheartli OP @fffflyfish 除了点故障,已经恢复
|