Java 基本数据类型 sizeof 功能
Java 基本数据类型 sizeof 功能
来源 https://blog.csdn.net/ithomer/article/details/7310008

Java基本数据类型
int 32bit
short 16bit
long 64bit
byte 8bit
char 16bit
float 32bit
double 64bit
boolean 1bit,This data type represents one bit of information, but its "size" isn't something that's precisely defined.(ref)
根据http://docs.oracle.com/javase/tutorial/java/nutsandbolts/datatypes.html官方文档的描述:
boolean: The boolean data type has only two possible values: true and false. Use this data type for simple flags that track true/false conditions. This data type represents one bit of information, but its "size" isn't something that's precisely defined.
布尔类型:布尔数据类型只有两个可能的值:真和假。使用此数据类型为跟踪真/假条件的简单标记。这种数据类型就表示这一点信息,但是它的“大小”并不是精确定义的。
可以看出,boolean类型没有给出精确的定义,《Java虚拟机规范》给出了4个字节,和boolean数组1个字节的定义,具体还要看虚拟机实现是否按照规范来,所以1个字节、4个字节都是有可能的。这其实是运算效率和存储空间之间的博弈,两者都非常的重要。
基础类型和包装类型的对应
包装类型 基本类型
Integer int
Short short
Long long
Byte byte
Character char
Float float
Double double
Boolean boolean
Java基本数据类型大小
public class Calcsizeof {
private void calcSize() {
System.out.println("Integer:" + Integer.SIZE/8); // Integer:4
System.out.println("Short:" + Short.SIZE/8); // Short:2
System.out.println("Long:" + Long.SIZE/8); // Long:8
System.out.println("Byte:" + Byte.SIZE/8); // Byte:1
System.out.println("Character:" + Character.SIZE/8); // Character:2
System.out.println("Float:" + Float.SIZE/8); // Float:4
System.out.println("Double:" + Double.SIZE/8); // Double:8
// System.out.println("Boolean:" + Boolean.toString(false));
}
public static void main(String[] args) {
Calcsizeof calcsizeof = new Calcsizeof();
calcsizeof.calcSize();
}
}
Java中模拟c中对sizeof的实现
思路:利用java中GC内存回收前后的heap size差别,得出每个object的大小
|
long
|
freeMemory()
Returns the amount of free memory in the Java Virtual Machine. |
|
|
void
|
gc()
Runs the garbage collector. |
|
|
static Runtime
|
getRuntime()
Returns the runtime object associated with the current Java application. |
|
|
long
|
maxMemory()
Returns the maximum amount of memory that the Java virtual machine will attempt to use. |
|
|
void
|
runFinalization()
Runs the finalization methods of any objects pending finalization. |
|
源码:
public class Calcsizeof {
private static Runtime rTime = Runtime.getRuntime();
private static long usedMemory() {
return rTime.totalMemory() - rTime.freeMemory();
}
private static void runGC() {
for (int i = 0; i < 4; i++) {
long usedMem1 = usedMemory();
long usedMem2 = Long.MAX_VALUE;
for (int j = 0; (usedMem1 < usedMem2) && (j < 500); j++) {
rTime.runFinalization();
rTime.gc();
Thread.yield();
usedMem2 = usedMem1;
usedMem1 = usedMemory();
}
}
}
private void calcSize2() {
runGC();
long heap1 = 0;
final int count = 100000;
Object[] objs = new Object[count];
for (int i = -1; i < count; i++) {
Object obj = null;
obj = new Object(); // Object size = 8 // ? 16
// obj = new Integer(i); // Object size = 16 // ? 16
// obj = new Short((short)i); // Object size = 16 // ? 16
// obj = new Long(i); // Object size = 16 // ? 24
// obj = new Byte((byte)0); // Object size = 16 // ? 16
// obj = new Character((char)i); // Object size = 16 // ? 16
// obj = new Float(i); // Object size = 16 // ? 16
// obj = new Double(i); // Object size = 16 // ? 24
// obj = new Boolean(false); // Object size = 16 // ? 16
// obj = new String(); // Object size = 40 // ? 24
if (i < 0) {
obj = null;
runGC();
heap1 = usedMemory();
} else {
objs[i] = obj;
}
}
runGC();
long heap2 = usedMemory();
final int size = (int)Math.round((heap2 - heap1)/(double)count);
System.out.println("heap1 = " + heap1 + "; heap2 = " + heap2);
System.out.println("heap2 - heap1 = " + (heap2 - heap1) + "; " + objs[0].getClass().getSimpleName() + " size = " + size);
for (int i = 0; i < count; i++) {
objs[i] = null;
}
objs = null;
runGC();
}
private void calcSize() {
System.out.println("Integer:" + Integer.SIZE/8);
System.out.println("Short:" + Short.SIZE/8);
System.out.println("Long:" + Long.SIZE/8);
System.out.println("Byte:" + Byte.SIZE/8);
System.out.println("Character:" + Character.SIZE/8);
System.out.println("Float:" + Float.SIZE/8);
System.out.println("Double:" + Double.SIZE/8);
// System.out.println("Boolean:" + Boolean.toString(false));
}
public static void main(String[] args) {
Calcsizeof calcsizeof = new Calcsizeof();
// calcsizeof.calcSize();
calcsizeof.calcSize2();
}
}
控制台输出内容:
>java -cp out\production\Test Calcsizeof
heap1 = 1099096; heap2 = 2700368
heap2 - heap1 = 1601272; Integer size = 16
注意:Object[] objects = new Object[count];
只是分配了数组空间,没有分配对象的空间。数组中只有引用而已。
结论:下代码测试基本对象时,得出的结果象下面:
Object obj = null;
// obj = new Object(); // Object size = 8
// obj = new Integer(i); // Object size = 16
// obj = new Short(i); // Object size = 16
// obj = new Long(i); // Object size = 16
// obj = new Byte(i); // Object size = 16
// obj = new Character(i); // Object size = 16
// obj = new Float(i); // Object size = 16
// obj = new Double(i); // Object size = 16
// obj = new Boolean(false); // Object size = 16
// obj = new String(); // Object size = 40
怎么会这样呢???解释如下:
这个例子写的很好,正好说明了java中基本类型封装对象所占内存的大小.
1.简单的Object对象要占用8个字节的内存空间,因为每个实例都至少必须包含一些最基本操作,比如:wait()/notify(),equals(), hashCode()等
2.使用Integer对象占用了16个字节,而int占用4个字节,说了封装了之后内存消耗大了4倍
3.那么Long看起来比Integer对象应该使用更多空间,结果Long所占的空间也是16个字节.
那么就正好说明了JVM的对于基本类型封装对象的内存分配的规则是如下:
Object所占内存(8个字节)+最大基本类型(long)所占内存(8个字节) = 16字节.
JVM强制使用8个字节作为边界.
所以所有基本类型封装对象所占内存的大小都是16字节.
但是还是有区别,比如:
Integer对象虽然占用了16个字节的内存,但是只是利用了 Object所占内存(8个字节)+int所占内存(4个字节) = 12字节.
还有4个字节根本没有被使用.呵呵,仔细分析了一晚,还是有很多收获的
====================== End
Java 基本数据类型 sizeof 功能的更多相关文章
- Java 基本数据类型 sizeof 功能【转】
转自:http://blog.csdn.net/sunboy_2050/article/details/7310008 版权声明:本文为博主原创文章,未经博主允许不得转载. Java基本数据类型int ...
- Java基本数据类型总结、类型转换、常量的声明规范,final关键字的用法
1 Java 基本数据类型 变量就是申请内存来存储值.也就是说,当创建变量的时候,需要在内存中申请空间. 内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据. 因此,通过 ...
- Java数组数据类型
Java数组数据类型 数组是多个相同类型的数据的组合,数组中的元素可以是任何类型的数据: 一维数组 package com.ahabest.array; public class ArratTest ...
- java基本数据类型全面总结
Java数据类型(type)可以分为两大类:基本类型(primitive types)和引用类型(reference types).下面是Java团长给大家整理的java基本数据类型相关知识,感兴趣的 ...
- JAVA基本数据类型和注释
一.注释 1.注释的概念 注释是程序中给人看的提示信息,会被编译器忽略:在程序编译和执行过程中不会有任何影响,仅仅在代码阅读时提供提示信息. 2.注释的形式 基本语法://注释的内容 a.行注释 ...
- C++11 Java基本数据类型以及转换
写在前面: 母语是Java,后来学了C++11,这两个语言的基本数据类型隐式转换不太一样,有点晕,整理一下 整理自网络和书籍,标明出处 C++ 基本数据类型 --http://www.cnblogs. ...
- Java基础-数据类型int,short,char,long,float,double,boolean,byte
Java语言是静态类型的(statical typed),也就是说所有变量和表达式的类型再编译时就已经完全确定.由于是statical typed,导致Java语言也是强类型(Strong typed ...
- Java中数据类型及其之间的转换
Java中数据类型及其之间的转换 基本的数据类型 基本类型有以下四种:1)int长度数据类型有:byte(8bits).short(16bits).int(32bits).long(64bits).2 ...
- java 的数据类型
java 的数据类型有基本类型和引用类型 java的类的关系:有继承,有依赖,有关联,聚合,组成.
随机推荐
- zabbix部署(1)(lnmp转)
1.lnmp 首先 确保CentOS7上网络配置正确,可以正常访问互联网. 确保已经关闭了iptables. CentOS7上是firewall,关闭命令: 1 2 # systemctl stop ...
- JAVA程序员必看的15本书-JAVA自学书籍推荐
作为Java程序员来说,最痛苦的事情莫过于可以选择的范围太广,可以读的书太多,往往容易无所适从.我想就我自己读过的技术书籍中挑选出来一些,按照学习的先后顺序,推荐给大家,特别是那些想不断提高自己技术水 ...
- redis系列--深入哨兵集群
一.前言 在之前的系列文章中介绍了redis的入门.持久化以及复制功能,如果不了解请移步至redis系列进行阅读,当然我也是抱着学习的知识分享,如果有什么问题欢迎指正,也欢迎大家转载.而本次将介绍哨兵 ...
- 网络对抗技术 2017-2018-2 20152515 Exp5 MSF基础应用
1.实践内容(3.5分) 本实践目标是掌握metasploit的基本应用方式,重点常用的三种攻击方式的思路. 1.1一个主动攻击实践,如ms08_067; (1分) MS08-067漏洞攻击 这次使用 ...
- Health Endpoint Monitoring模式
Health Endpoint Monitoring模式是一种用来监控服务健康状态的模式. Health Endpoint Monitoring模式通过在应用内额外暴露一个可以进行功能检查的接口来实现 ...
- linux下ipython无法保存历史记录
在Centos7下使用ipython时,发现有个warning,提示无法保存历史记录 [root@localhost pip-]# ipython /usr/local/lib/python3./si ...
- 部署AlwaysOn第三步:集群资源组的健康检测和故障转移
资源组是由一个或多个资源组成的组,WSFC的故障转移是以资源组为单位的,资源组中的资源是相互依赖的.一个资源所依赖的其他资源必须和该资源处于同一个资源组,跨资源组的依赖关系是不存在的.在任何时刻,每个 ...
- stl源码剖析 详细学习笔记 算法(2)
//---------------------------15/03/29---------------------------- //****************************set相 ...
- linux之grep 基础
第一章 -a 将binary文件以text文件的方式搜寻数据-c 只输出匹配行的计数,计算找到匹配的次数-I(大写i) 不区分大小写(只适合用于单字符)-h 查询多文件时不显示 ...
- 关于GitHub上传没有记录(小绿块不显示的问题)
最近开始使用上github来上传保存自己在学习中所写过的代码,打算将自己每天的成果能有个保存,然后就利用上GitHub这么一个利器. 听说GitHub的那个绿块是用来记录每天的上传记录的,结果我将代码 ...