导航:首页 > 编程语言 > java长整形

java长整形

发布时间:2024-11-08 01:23:49

java语言有几种数据类型怎样申明和赋值

一、基本数据类型
整型:byte、short、int、long (在计算机中以二进制补码格式存储)

浮点型:float、double (在计算机中以IEEE754格式存储)

字符型:char (在计算机中以unicode码格式存储)

布尔型:boolean (只有true和false两个值)

二、 1.长整型:long

定义:long a=100;int b=a; (编译出错)

给a重新赋值:long a=2147483648; (编译出错)

定义:long a=2147483648L;(正确,说明此时可以是long型的取值范围)

说明在long型的数据后不加L/l时,数据仍为long型,但其取值范围却是int型的取值范围;数据后加L/l时,取值范围才是long型的取值范围。

2.浮点型:long

定义:float a=19; 输出a时为19.0

定义:float a=19.1; (编译出错)

定义:float a=19.1f; (正确)

说明在 float型的数据后不加F/f,则数据不能有小数位,但输出时,能够输出一位小数;若在float型的数据后加上F/f,则数据可以有小数位;

三、类型转换(注:boolean型不会发生类型转换,基本类型和复合类型不能相互转换)

1.自动转换

1)赋值转换:用于短字节的数据类型转换成长字节的数据类型(byte型的数据不能转换成char型,short型和char型数据也不能相互转换)

2)单目运算符提升

++、——运算符不会自动提升,+(正)、-(负)会将byte、short、char型的数据自动转换成int型的数据

3)双目运算符提升

如果有一个操作数是double型的,则把另一个转换成double型;否则如果有一个操作数是float型的,则把另一个转换成float型;否则 如果有一个操作数是long型的,则把另一个转换成long型;否则两个操作数都转换成int型。

4)三目运算符<op1> ? <op2> : <op3>其中op1必须是boolean型的,而op2和op3两操作数必须是能够自动转换成相同类型的数据,op2和op3会自动提升为两操作数中字节较长的一个,并且结果为提升后的类型。

如:byte a1=20;

short a2=10;

boolean b=true;

short c = b ?

a1 : a2;

结果为short型的数据c

2.强制转换

例子:

int a;

byte b=(byte)a;

定义:a=-126;

(分析:int形的数据有4个字节,而byte形的数据只有1个字节,所以只取int型数据的最后一个字节)

a的原码: 10000000,00000000,00000000,01111110

补码: 11111111,11111111,11111111,10000010

法一:r=(10000010)=130 (此时将 10000010 看成是纯的二进制数去计算,而不考虑它的符号位); byte型数据范围〔-128,127〕,由于 r>127,所以 r=r-M (若整型数据值域[-L,R],则M=L+R+1),如果r还不在byte型数据的取值范围内,则继续 r=r-M 直至r在其取值范围内,取得r后,即为byte型的 b .此处r=-126,所以输出b为-126.

法二:直接将int型数据的最后一个字节看成是byte型数据的补码形式,在将补码转换成原码,即得到 b

四、逻辑运算符

1.&&和|| (&&的优先级要高于||的)

特点:只要左操作数已经得出整个表达式的值,就不再计算右操作数的之值,左右操作数必须为boolean型的。

例子:

boolean test1= ++x==-1 && ++x==1 || ++x=2;
boolean test2= ++y==-1 || ++y==1 && ++y=2;
System.out.println(x+" "+test1);
System.out.println(y+" "+test2);
结果:1 false
2 true

2.&和| (逻辑位运算符)

特点:先把两个操作数的值计算出来,然后再进行逻辑运算

int x=-1,y=-1;
boolean test1= ++x==-1 & ++x==1 | ++x=2;
boolean test2= ++y==-1 | ++y==1 & ++y=2;
System.out.println(x+" "+test1);
System.out.println(y+" "+test2);
结果: 2 false
2 true

五、移位运算

<< (左移)高位丢失、低位以0填充

>> (右移) 低位丢失、高位以符号位填充

>>> (无符号位右移) 低位丢失、高位以0填充

此运算符不会对左右两操作数作算术提升,但会对左操作数进行单独提升,若为byte、short、char、int型,则得到结果为int型,若为long型,则结果为long型,但左右操作数均不能为浮点型,否则出错。

当左操作数为int型时,右操作数的低5位才有用,这样可以防止移位超过int型所具有的位数,当左操作数为long型时,右操作数的低6位才有用。

例子:

int a=-2;
short b=-10;
int c=a>>b;

b的补码:11111111,11111111,11111111,11110110

取b的最后5位, r=(10110)=22;

a的补码:11111111,11111111,11111111,11111110

将a向右移动22位,再在高位补上1,得到 11111111,11111111,11111111,11111111 ,转换成原码得到 c=-1

六、赋值运算

1.简单赋值运算

表达式: <变量>=<表达式>

左操作数可以事先没有赋值

表达式的类型必须和变量的类型相同,或能赋值转换成变量的类型,

2.组合赋值运算

表达式:<变量> op= <表达式>

int a=10;

double b=23.3;

a*=b;

左操作数事先一定要赋值

左边的类型和右边的类型不一定要相同,此处a*b得到的是double型的,组合运算符会自动把double型的值转换成int型的值存入变量a中。

㈡ Java中的8种数据类型详解

Java数据类型包括基本数据类型和引用数据类型。基本数据类型主要有:整型、长整型、双精度浮点型、浮点型、短整型、字符型、字节型和布尔型。

整型:大小为4个字节,取值范围为-2147483648到2147483647,对应的包装类为Integer。如果赋值超出此范围,会报错。

长整型:大小为8个字节,取值范围为-9223372036854775808到9223372036854775807,对应的包装类为Long。定义时需注意默认数字是int型,需明确指定。

双精度浮点型:大小为8个字节,取值范围广泛,适用于大范围数值运算。对应的包装类为Double。注意事项是尽量使用double类型以避免精度损失。

浮点型:大小为4个字节,遵循IEEE 754标准,精度范围较小。对应的包装类为Float。建议在工程中使用double类型。

短整型:大小为2个字节,取值范围为-32768到32767,对应的包装类为Short。

字符型:大小为2个字节,采用Unicode编码,可赋值给汉字。在编译时若出现编码格式不对的情况,需在javac编译时加上特定参数解决。

字节型:大小为1个字节,取值范围为-128到127,对应的包装类为Byte。超出范围会报错,可通过强制类型转换赋值。

布尔型:大小无明确规定,有的认为一个字节,有的认为一个比特位,取值只有true或false,对应的包装类为Boolean。注意事项是不能与其他基本类型相互转换,且0不表示false,非零不表示true。

注意事项包括类型之间的转换规则、范围限制以及编码兼容性等问题。正确理解并应用这些数据类型是Java编程的基础。

㈢ java中long是什么意思

是整型的一种,而且是表示范围最大的那种。
java里面整型一共4种,byte, short, int, long,按字节长度算分别是1, 2, 4, 8个字节。

㈣ java中长整型和整型的区别

相同点:
两者都是整数
不同点:
长整形取值范围比整型取值范围大。
长整形最大值:9223372036854775807
整型最大值:2147483647

㈤ java中长整型定义

java整型有四种分贝是:byte(1字节)、short(2字节)、int(4字节)、long(8字节)

0x100080000000超出范围,其实不是long不能保存这么大,而是这个数是个int型数。它超出的其实是int的范围(The literal 0x100080000000 of type int is out of range),在整数赋值时。

可以将赋值语言修改如下,指定它的类型为long型就可以了:

long y=0x100080000000l;//

(5)java长整形扩展阅读

java整形与长整型之间的转换可以借助Long类或字串

1、借助Long类:

int new_a = new Long(a).intValue();

2、借助字串:

int new_a = Integer.parseInt(String.valueOf(y));

java整形、长整型、浮点型 边界值:

int型边界最大值:Integer.MAX_VALUE

int型边界最小值:Integer.MIN_VALUE

long型边界最大值:Long.MAX_VALUE

long型边界最小值:Long.MIN_VALUE

float型边界最大值:Float.MAX_VALUE

float型边界最小值:Float.MIN_VALUE


阅读全文

与java长整形相关的资料

热点内容
本地文件如何上传linux服务器 浏览:14
传奇资源网站源码 浏览:375
f26app怎么下载 浏览:118
程序员与酒 浏览:437
php政府网站源码 浏览:910
前端面试常问算法 浏览:151
pythonopen可以打开文件夹吗 浏览:633
不锈钢加密网带厂家 浏览:345
哪一年除夕不算法定节假日 浏览:40
程序员对键盘的需求 浏览:603
程序员的峥嵘岁月 浏览:56
python调用类里面的函数 浏览:473
pre加密头发医院 浏览:547
优先级高服务算法 浏览:840
抖音最火解压游戏名字 浏览:952
java打jar包命令 浏览:174
阿里云服务器可以当挂机宝用吗 浏览:200
oppo微信加密图案如何取消 浏览:146
上海开车上班20公里源码 浏览:312
cab自解压注册 浏览:927