在前面两篇博客中,介绍了字节序和网路字节序。
如果你有兴趣的话,可以访问 Java_NetWork_Endianness-字节序、 Java_NetWork_Endian相关的几个函数。
这篇博客主要说说JavaVM与字节序,通过一个例子来说明。
我们知道,不同的cpu或者是相同的cpu不同的操作系统,内存存储数据的机制也不一样!
但是Java虚拟机是如何存储数据的呢,换个话说,JVM是大端序还是小端序?举个例子吧!
package mark.zhang;
import java.nio.ByteBuffer;
import java.util.Arrays;
public class JVMEndianTest {
public static void main(String[] args) {
int x = 0x01020304;
ByteBuffer bb = ByteBuffer.wrap(new byte[4]);
bb.asIntBuffer().put(x);
String ss_before = Arrays.toString(bb.array());
System.out.println("默认字节序 " + bb.order().toString() + "," + " 内存数据 " + ss_before);
}
}
运行这个demo,得到结果应该是这样子的:
默认字节序 BIG_ENDIAN, 内存数据 [1, 2, 3, 4]
可以看出,JVM的字节序是大端序。那麽,是否可以改变JVM的字节序呢?先看下面的例子,再来回答这个问题。
该例子,只是使用ByteBuffer这个类的方法来说明问题。
package mark.zhang;
import java.nio.ByteBuffer;
import java.nio.ByteOrder;
import java.util.Arrays;
public class JVMEndianTest {
public static void main(String[] args) {
int x = 0x01020304;
ByteBuffer bb = ByteBuffer.wrap(new byte[4]);
bb.asIntBuffer().put(x);
String ss_before = Arrays.toString(bb.array());
System.out.println("默认字节序 " + bb.order().toString() + "," + " 内存数据 " + ss_before);
bb.order(ByteOrder.LITTLE_ENDIAN);
bb.asIntBuffer().put(x);
String ss_after = Arrays.toString(bb.array());
System.out.println("修改字节序 " + bb.order().toString() + "," + " 内存数据 " + ss_after);
}
}
默认字节序 BIG_ENDIAN, 内存数据 [1, 2, 3, 4]
修改字节序 LITTLE_ENDIAN, 内存数据 [4, 3, 2, 1]
ok,说到这里吧!
如果有兴趣的话,可以研究一下ByteBuffer这个类。