我在java中编写无符号4字节int时遇到问题。
在java中写一个long值在64位MacOS和32位Linux(Ubuntu)上有不同的结果 要么 向网络写入一个4字节的无符号整数有一个问题。
以下调用在我的本地OSX上完美运行
writeUInt32(999999,outputstream)
读回来给了我999999
然而,当应用程序部署到网络时,写入一个长值会产生一些其他随机数(我假设已经切换了字节序?)并且读取它会给我一些其他大数字。
----------完整的方法堆栈如下---------------
public void writeUInt32(long uint32,DataOutputStream stream) throws IOException {
writeUInt16((int) (uint32 & 0xffff0000) >> 16,stream);
writeUInt16((int) uint32 & 0x0000ffff,stream);
}
public void writeUInt16(int uint16,DataOutputStream stream) throws IOException {
writeUInt8(uint16 >> 8, stream);
writeUInt8(uint16, stream);
}
public void writeUInt8(int uint8,DataOutputStream stream) throws IOException {
stream.write(uint8 & 0xFF);
}
编辑:添加到写入文件的混乱,然后通过网络传输它给我发送正确的值!因此,当输出流指向本地文件时,它会写入正确的值,但是当输出流指向ByteArrayOutputStream时,则写入的长值是错误的。
答案 0 :(得分:6)
只需使用DataOutput / InputStream。
要撰写,请将long
投放到int
public void writeUInt32(
long uint32,
DataOutputStream stream
) throws IOException
{
stream.writeInt( (int) uint32 );
}
读取时,使用readInt,分配给long并屏蔽前32位以获得无符号值。
public long readUInt32(
DataInputStream stream
) throws IOException
{
long retVal = stream.readInt( );
return retVal & 0x00000000FFFFFFFFL;
}
修改强>
从您的问题来看,您似乎对Java转换和原始类型的促销感到困惑。
阅读关于转化和促销的Java规范的这一部分:http://java.sun.com/docs/books/jls/third_edition/html/conversions.html