天天看点

Java基本类型

转自http://myeyeofjava.iteye.com/blog/1738143

1G=1024M=1024K=1024BYTE=8BIT 

1 byte = 1字节  = 8bit 可表达 2的八次方个数字    = 256 

1 short= 2字节  = 16bit 可表达2的十六次方个数字  = 65536 约6W 

1 char = 2字节  = 16bit 可表达2的十六次方个数字  = 65536 约6W 

1 int  = 4字节  = 32bit 可表达2的32次方个数      = 4294967296 约42亿 

1 float= 4字节  = 32bit 可表达2的32次方个数      = 4294967296 约42亿 

1 long = 8字节  = 64bit 可表达2的64次方个数      = 18446744073709551616 约184亿亿 184*10^16次方 

1 double= 8字节  = 64bit 可表达2的64次方个数     = 18446744073709551616 约184亿亿 

知道这些,才能理解bitmap需要多大的内存来计算10亿个数字里是否有重复数字,每个数字是一个IP,可见存储这些数据只需要一个int大小的内存已经足以,但运算还是需要内存的。 

bitmap是比hash更加优越的地方在于此吧 

1个IP 192.168.101.129 为12位的数据,也就是说有10亿个12位的数字。1个12位的数字99999999999 999亿那么需要一个double类型的数字来表示这个12位的数字,1个double类型占用8字节,也就是大概需要10亿*8字节来做这个事情,总共需要内存10亿byte,约0.93G内存即可。

数据类型                   大小(二进制位数)                 范围                                                                                 默认值 

byte(字节) 	         8                     -128 - 127                                                                                             0
shot(短整型)            16                   -32768 - 32768                                                                                      0
int(整型)                  32                    -2147483648-2147483648                                                                    0
long(长整型)            64                   -9233372036854477808-9233372036854477808                                0        
float(浮点型)            32                   -3.40292347E+38-3.40292347E+38                                                     0.0f
double(双精度)	        64                 -1.79769313486231570E+308-1.79769313486231570E+308              0.0d
char(字符型)           16                  ‘ \u0000 - u\ffff ’                                                                                      ‘\u0000 ’      
boolean(布尔型)      1                   true/false                                                                                                 false      

摘自http://www.blogjava.net/stevenjohn/archive/2013/10/18/405416.html

JAVA基本数据类型所占字节数是多少?

byte     1字节               

short    2字节               

int      4字节               

long     8字节               

char     2字节(C语言中是1字节)可以存储一个汉字

float    4字节               

double   8字节               

boolean  false/true(理论上占用1bit,1/8字节,实际处理按1byte处理)       

JAVA是采用Unicode编码。每一个字节占8位。你电脑系统应该是 32位系统,这样每个int就是 4个字节      
其中一个字节由8个二进制位组成

      
Java一共有8种基本数据类型(原始数据类型):     
类型  存储要求 范围(包含) 默认值 包装类
整 int 4字节(32位) -231~ 231-1 0 Integer
数 short 2字节(16位) -215~215-1 0 Short
类 long 8字节(64位) -263~263-1 0 Long
型 byte 1字节(8位) -27~27-1 0 Byte
浮点 float 4字节(32位) -3.4e+38 ~ 3.4e+38 0.0f Float
类型 double 8字节(64位) -1.7e+308 ~ 1.7e+308 0 Double
字符 char 2字节(16位) u0000~uFFFF(‘’~‘?’) ‘0’ Character
   (0~216-1(65535))  
布尔 boolean 1/8字节(1位) true, false FALSE Boolean      

在移动开发中由于移动设备内存的局限性,往往需要考虑使用的数据类型所占用的字节数。下面简单介绍下Java中几种基本数据类型,以加深记忆。

在Java中一共有8种基本数据类型,其中有4种整型,2种浮点类型,1种用于表示Unicode编码的字符单元的字符类型和1种用于表示真值的boolean类型。(一个字节等于8个bit)

1.整型

类型              存储需求     bit数    取值范围      备注

int                 4字节           4*8 

short             2字节           2*8    -32768~32767

long              8字节           8*8

byte              1字节           1*8     -128~127

2.浮点型

float              4字节           4*8                  float类型的数值有一个后缀F(例如:3.14F)

double          8字节           8*8                       没有后缀F的浮点数值(如3.14)默认为double类型

3.char类型

类型              存储需求     bit数     取值范围      备注

char              2字节          2*8

4.boolean类型

类型              存储需求    bit数    取值范围      备注

boolean        1字节          1*8      false、true

补充:Java有一个能够表示任意精度的算书包,通常称为“大数值”(big number)。虽然被称为大数值,但它并不是一种Java类型,而是一个Java对象。

如果基本的整数和浮点数精度不能够满足需求,那么可以使用java.math包中的两个很有用的类:BigIntegerBigDecimal(Android SDK中也包含了java.math包以及这两个类)这两个类可以处理包含任意长度数字序列的数值。BigInteger类实现了任意精度的整数运算,BigDecimal实现了任意精度的浮点数运算。具体的用法可以参见Java API。

http://blog.csdn.net/witsmakemen/article/details/8974200

int常见为4个字节,跟操作系统有关系。
turbo c(以及Turbo c的一些衍生编译器,他们用的一套编译程序)是dos时代的编译器,是上世纪80年代的产物,严重过时,属于老掉牙的产品,他们编译出来的程序是16位操作系统dos下的程序,所以长度为16位,即两个字节。windows为了兼容dos,所以turbo c生成的文件也可以在windows中运行。
其他一般就都是4个字节了。      

操作系统16位的时候,int 2字节,操作系统32位的时候,int 4字节,由于32位系统之前占主流地位,实际现在就算是64位系统,出于兼容性考虑,int也是4字节的

Java基本类型

作者:沙漏哟

出处:计算机的未来在于连接

本文版权归作者和博客园共有,欢迎转载,请留下原文链接

微信随缘扩列,聊创业聊产品,偶尔搞搞技术