我在开发我的聊天机器人程序时遇到一个特殊的问题:因为我的存储系统可能存在 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 ![]() 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 除了点故障,已经恢复 |