欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

谈谈Java中整数类型(short int long)的存储方式

程序员文章站 2024-03-31 19:24:34
在java中的整数类型有四种,分别是 byte  short int long 其中byte只有一个字节 0或1,在此不详细讲解。 其他的三种类型如下: 1、...

在java中的整数类型有四种,分别是 byte  short int long 其中byte只有一个字节 0或1,在此不详细讲解。

其他的三种类型如下:

1、
基本类型:short 二进制位数:16
包装类:java.lang.short
最小值:short.min_value=-32768 (-2的15此方)
最大值:short.max_value=32767 (2的15次方-1)

2、
基本类型:int 二进制位数:32
包装类:java.lang.integer
最小值:integer.min_value= -2147483648 (-2的31次方)
最大值:integer.max_value= 2147483647  (2的31次方-1)

3、
基本类型:long 二进制位数:64
包装类:java.lang.long
最小值:long.min_value=-9223372036854775808 (-2的63次方)
最大值:long.max_value=9223372036854775807 (2的63次方-1)

拿short类型举例:

  首先需要明白在计算机中最高位为符号位,0表示正数,1表示负数。在计算机中数据是使用其补码表示的,但正数补码是其本身,负数的补码是负数的源码取反加一得到的补码。

一、正数的原码、反码、补码都相等

    例:0000 1010(在十进制中表示+10,左数第一位为符号位)
    它的原码、反码、补码都是0000 1010

二、负数的原码是其本身,负数的反码是将符号不变,把符号后边的数取反,对于负数的补码 是把原码取反后加1

    例:1000 1010(在十进制中表示-10)
    它的原码是 1000 1010
    它的反码是 1111 0101
    它的补码是 1111 0110

    例如short类型: -1  二进制标示: 10000000 00000001(最大的负整数-1 )

          取反:          11111111 11111110  

          加1 补码:      11111111 11111111  (最大的负整数-1在计算机中的标示方法)

明白了 以上这些再说short的二进制标示:

    先看这个: 最小的负整数 -32768     计算机中二进制标示:10000000   00000000

          最大的负整数-1     计算机中二进制标示:11111111  11111111

          0           计算机中二进制标示:00000000  0000000

         最小的正整数 1               计算机中二进制标示: 00000000 00000001

         最大的正整数:32767  计算机中二进制标示: 01111111  11111111

最小的负数-32768加1之后计算机中二进制标示为:10000000  00000001 一直加1直到到 11111111 11111111(-1)达到最大的负整数,然后再加1变为:1 00000000  0000000   注意此处字节长度为 17位,而short类型只取 16位即:00000000  0000000   所以-1+1之后变为0 然后00000000 00000000再一直加1直到 01111111  11111111 达到最大正整数(32767),32767再加1变为:10000000   00000000 即为最小的负整数 -32768(2^15)

谈谈Java中整数类型(short int long)的存储方式

ps:数据类型之间的转换

1).简单类型数据间的转换,有两种方式:自动转换和强制转换,通常发生在表达式中或方法的参数传递时。

自动转换

具体地讲,当一个较"小"数据与一个较"大"的数据一起运算时,系统将自动将"小"数据转换成"大"数据,再进行运算。而在方法调用时,实际参数较"小",而被调用的方法的形式参数数据又较"大"时(若有匹配的,当然会直接调用匹配的方法),系统也将自动将"小"数据转换成"大"数据,再进行方法的调用,自然,对于多个同名的重载方法,会转换成最"接近"的"大"数据并进行调用。这些类型由"小"到"大"分别为 (byte,short,char)--int--long--float—double。这里我们所说的"大"与"小",并不是指占用字节的多少,而是指表示值的范围的大小。

①下面的语句可以在java中直接通过:

byte b;int i=b; long l=b; float f=b; double d=b;

②如果低级类型为char型,向高级类型(整型)转换时,会转换为对应ascii码值,例如

char c='c'; int i=c;

system.out.println("output:"+i);输出:output:99;

③对于byte,short,char三种类型而言,他们是平级的,因此不能相互自动转换,可以使用下述的强制类型转换。

short i=99 ; char c=(char)i; system.out.println("output:"+c);输出:output:c;

强制转换

将"大"数据转换为"小"数据时,你可以使用强制类型转换。即你必须采用下面这种语句格式: int n=(int)3.14159/2;可以想象,这种转换肯定可能会导致溢出或精度的下降。

2)表达式的数据类型自动提升, 关于类型的自动提升,注意下面的规则。

①所有的byte,short,char型的值将被提升为int型;

②如果有一个操作数是long型,计算结果是long型;

③如果有一个操作数是float型,计算结果是float型;

④如果有一个操作数是double型,计算结果是double型;

例, byte b; b=3; b=(byte)(b*3);//必须声明byte。

3)包装类过渡类型转换

一般情况下,我们首先声明一个变量,然后生成一个对应的包装类,就可以利用包装类的各种方法进行类型转换了。例如:

①当希望把float型转换为double型时:

float f1=100.00f;
float f1=new float(f1);
double d1=f1.doublevalue();//f1.doublevalue()为float类的返回double值型的方法

②当希望把double型转换为int型时:

double d1=100.00;
double d1=new double(d1);
int i1=d1.intvalue();

简单类型的变量转换为相应的包装类,可以利用包装类的构造函数。即:boolean(boolean value)、character(char value)、integer(int value)、long(long value)、float(float value)、double(double value)

而在各个包装类中,总有形为××value()的方法,来得到其对应的简单类型数据。利用这种方法,也可以实现不同数值型变量间的转换,例如,对于一个双精度实型类,intvalue()可以得到其对应的整型变量,而doublevalue()可以得到其对应的双精度实型变量。

4)字符串与其它类型间的转换

其它类型向字符串的转换

①调用类的串转换方法:x.tostring();

②自动转换:x+"";

③使用string的方法:string.volueof(x);

字符串作为值,向其它类型的转换

①先转换成相应的封装器实例,再调用对应的方法转换成其它类型

例如,字符中"32.1"转换double型的值的格式为:new float("32.1").doublevalue()。也可以用:double.valueof("32.1").doublevalue()

②静态parsexxx方法

string s = "1";
byte b = byte.parsebyte( s );
short t = short.parseshort( s );
int i = integer.parseint( s );
long l = long.parselong( s );
float f = float.parsefloat( s );
double d = double.parsedouble( s );

③character的getnumericvalue(char ch)方法

5)date类与其它数据类型的相互转换

整型和date类之间并不存在直接的对应关系,只是你可以使用int型为分别表示年、月、日、时、分、秒,这样就在两者之间建立了一个对应关系,在作这种转换时,你可以使用date类构造函数的三种形式:

①date(int year, int month, int date):以int型表示年、月、日
②date(int year, int month, int date, int hrs, int min):以int型表示年、月、日、时、分
③date(int year, int month, int date, int hrs, int min, int sec):以int型表示年、月、日、时、分、秒

在长整型和date类之间有一个很有趣的对应关系,就是将一个时间表示为距离格林尼治标准时间1970年1月1日0时0分0秒的毫秒数。对于这种对应关系,date类也有其相应的构造函数:date(long date)。

获取date类中的年、月、日、时、分、秒以及星期你可以使用date类的getyear()、getmonth()、getdate()、gethours()、getminutes()、getseconds()、getday()方法,你也可以将其理解为将date类转换成int。

而date类的gettime()方法可以得到我们前面所说的一个时间对应的长整型数,与包装类一样,date类也有一个tostring()方法可以将其转换为string类。

有时我们希望得到date的特定格式,例如20020324,我们可以使用以下方法,首先在文件开始引入,

import java.text.simpledateformat;
import java.util.*;
java.util.date date = new java.util.date();
//如果希望得到yyyymmdd的格式
simpledateformat sy1=new simpledateformat("yyyymmdd");
string dateformat=sy1.format(date);
//如果希望分开得到年,月,日
simpledateformat sy=new simpledateformat("yyyy");
simpledateformat sm=new simpledateformat("mm");
simpledateformat sd=new simpledateformat("dd");
string syear=sy.format(date);
string smon=sm.format(date);
string sday=sd.format(date);

总结:只有boolean不参与数据类型的转换

(1).自动类型的转换:

a.常数在表数范围内是能够自动类型转换的

b.数据范围小的能够自动数据类型大的转换(注意特例)

int到float,long到float,long到double 是不会自动转换的,不然将会丢失精度

c.引用类型能够自动转换为父类的

d.基本类型和它们包装类型是能够互相转换的

(2).强制类型转换:用圆括号括起来目标类型,置于变量前