gpt4 book ai didi

Java 位解包器与 C 不匹配

转载 作者:太空宇宙 更新时间:2023-11-04 04:05:37 24 4
gpt4 key购买 nike

所以我得到了一个 C 程序,我正试图通过将其转换为 Java 来使其更具可移植性,该程序进展顺利。但是,我遇到了一点挂断,我认为这在于这段代码。它只是一个解包 30 字节帧的函数。我有一种感觉,我遇到了变量类型的问题,试图找出最好的方法来为一些不从 C 继承的 Java 类型创建子类。如果有人看到问题出在哪里,我将不胜感激。

Java:

public static byte[] unPackBits(byte[] Src, int bitOffset, byte[] Dst, int bitCount){

int srcByteOffset, srcBit;
int dstByteOffset, dstBit;
char dstMask, srcMask;

srcByteOffset = bitOffset / 8;
srcBit = bitOffset % 8;
srcMask = (char)(0x01<<srcBit);

dstByteOffset = 0;
dstBit = 0;
dstMask = 0x01;

Dst[dstByteOffset] = '\0';

for(int b = 0; b < bitCount; b++){
if((Src[srcByteOffset] & srcMask) != (char)0x00){
Dst[dstByteOffset] = (byte)(Dst[dstByteOffset]|dstMask);
}
else {
Dst[dstByteOffset] = (byte)(Dst[dstByteOffset] & (~dstMask));
}

srcBit++;
if(srcBit < 8) {
srcMask = (char)(srcMask<<1);
}
else {
srcByteOffset++;
srcBit = 0;
srcMask = 0x01;
}

dstBit++;
if(dstBit < 8) {
dstMask = (char)(dstMask<<1);
}
else {
dstByteOffset++;
dstMask = 0x01;
dstBit = 0;
}
}
return Dst;
}

C:

void TRB::unPackBits(char *Src, int BitOffset, char *Dst, int BitCount) {
int srcByteOffset, srcBit;
int dstByteOffset, dstBit;
char dstMask, srcMask;

srcByteOffset = BitOffset / 8;
srcBit = BitOffset % 8;
srcMask = 0x01<<srcBit;

dstByteOffset = 0;
dstBit = 0;
dstMask = 0x01;
Dst[dstByteOffset] = '\0';


for(int b = 0; b < BitCount; b++) {
if((Src[srcByteOffset] & srcMask) != (char)0x00) {
Dst[dstByteOffset] = Dst[dstByteOffset] | dstMask;
}
else {
Dst[dstByteOffset] = Dst[dstByteOffset] & (~dstMask);
}

srcBit++;
if(srcBit < 8) {
srcMask = srcMask<<1;
}
else {
srcByteOffset++;
srcBit = 0;
srcMask = 0x01;
}

dstBit++;
if(dstBit < 8) {
dstMask = dstMask<<1;
}
else {
dstByteOffset++;
dstMask = 0x01;
dstBit = 0;
}
}

}

最佳答案

您很可能偶然发现了 endianness 的一个非常常见的问题. C 和 java 可能有不同的表示 int 的方式,这取决于运行 c 代码的机器的体系结构。

通常 C 程序应该将多字节整数转换为 network byte order像您现在所做的那样简化可移植性工作。

要获得正确的字节顺序,您必须使用 bit-shift 来改变您的位。和“和”运算符。

也很感兴趣 - nio package具有轻松处理通常由遗留 c 代码生成的 LSB 字节顺序整数的功能。

关于Java 位解包器与 C 不匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6445272/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com