Java_NetWork_Java字节序

在前面两篇博客中,介绍了字节序和网路字节序。

如果你有兴趣的话,可以访问 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);
	}
}


Run as javaapp 输出结果:

默认字节序 BIG_ENDIAN, 内存数据 [1, 2, 3, 4]
修改字节序 LITTLE_ENDIAN, 内存数据 [4, 3, 2, 1]

ok,说到这里吧!

如果有兴趣的话,可以研究一下ByteBuffer这个类。




你可能感兴趣的:(java,jvm,String,Class,NetWork,byte)