如何解决从nsdata中的二进制数据流中提取数据
| 目前,我对目标c还是陌生的,并试图对作为NSdata对象获取的数据流进行解码。 数据为8个字节长,例如: 1 2 3 4
0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| code1 |code2 | code3 | code4 |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
5 6 7 8
0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
code5 |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
考虑到code3不在字节边界上,我如何从nsdata数组轻松地输出不同的代码?
我已经尝试过这样的方式:
NSUInteger len = [data length];
Byte *byteData = (Byte*)malloc(len);
memcpy(byteData,[data bytes],len);
但是不能使它在不同的边界上正常工作。抱歉,如果看上去有点含糊,可以在需要时确认详细信息
解决方法
您正在做什么看起来很好-问题是什么?您是否可以将数据输入到byteData指针中?如果是这样,那么Objective-c或C或其他任何东西都没有区别(然后NSData并不是一个很好的标签)-您只需要按位访问字节即可。
这可以通过创建具有这样的位域定义的结构(伪代码,google位域)来实现
struct
{
char byte1;
char a3bitfield : 3;
char a5bitfield : 5;
char byte3;
}
或通过使用位掩码或通过使用移位。
编辑以回应评论:
这说明了如何进行换档
您将要遇到的第一个问题是,您要从左到右显示位,这在小端系统中是不准确的,您需要考虑以下位:
7 6 5 4 3 2 1 0
代替
0 1 2 3 4 5 6 7
否则,您将永远无法理解掩蔽和移动方向的工作方式。
因此,假设您看起来好像有多个字节,并且知道要操作的字节是字节x:
7 6 5 4 3 2 1 0
[5位a] [3位b]
如果a和b是您关心的消息,则获得这些“单独”的方式为:
char onlya = ((x & 11111000b) >> 3);
这意味着,我想使用a的高5位,并丢弃最低的3位,然后将所有3位右移以进行补偿。如果您开始使用:
AAAAABBB,其中A是来自a的数据,B是来自B的数据,您并不关心,\“ x&11111000b \”将导致:
AAAAA000
随后的>> 3将导致:
000AAAAA
A \的位置来自右移,在间隙处引入0 \并在右侧丢弃0 \。
因此,在这种情况下,让B一个人,您只需要做:
char onlyb = (x & 00000111b);
无需换档。
如果您正在跨越带有2个字节N和M的位边界,例如:
M
7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0
X X X X A A A A A A A X X X X X X
您可以这样做:
char merged = 0;
merged |= (N & 00001111b) << 3;
merged |= (M & 11100000b) >> 5;
我屏蔽了从N和M仅得到A的位置,然后我转到了结果位置。这样,当我按顺序完成这三个步骤时,合并后的结果将是:
合并= 0给出:
0 0 0 0 0 0 0 0
首先合并| =给出:
0 N N N N 0 0 0
第二合并的| =给出:
0 N N N N M M M
此时,您将像往常一样对数据进行操作(广播到int或其他内容)
就像我说的,替代方案是位域
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。