java人物_Java中形形色色的人物

770357ad25dc4cbc07faeaebd4a2466b.png

Java作为编程语言,一定是有其独特的基本类型作支撑。了解这些基本类型,对于今后的编程有很重要的意义。

Java中有以下几种基本数据类型,这些类型都是值类型。

类型值范围大小范围

booleantrue或false1位

charUnicode字符16位'\u0000'~'\uFFFF'

byte有符号整数8位-128~127

short有符号整数16位-32768~32767

int有符号整数32位-2^31~2^31-1

long有符号整数64位-2^63~2^63-1

floatIEEE 754浮点数32位1.4E-45~3.4028235e+38

doubleIEEE 754浮点数64位4.9E-324~1.7976931348623157E+308

布尔类型

boolean是布尔类型,用来表示逻辑真值,只有两个值,真和假。而且不能和其他基本类型进行类型转换,主要作用是在条件和判断语句中作为判断条件。

各种基本类型的值可以直接出现在程序中,这样的值叫做 字面量 。对于布尔类型来说,字面量只有true和false两个。

boolean condition = true;

if(condition) {

...

}

字符类型

char也就是字符类型,用来表示一个Unicode字符。除了可以使用普通字符外,还可以使用各种转义字符以及Unicode转义序列与一些非打印字符。字符类型的字面量,必须使用单引号'包裹起来。

char c = 'A';

char tab = '\t';

char nul = '\000';

转义字符含义

\b退格符

\t水平制表符

\n换行符

\f换页符

\r回车符

\"双引号

\'单引号

\\反斜杠

\xxxLatin-1字符,其中xxx是八进制数

\uxxxxUnicode字符,其中xxxx是十六进制数

char类型和其他数字类型可以互相转换。但是转换之后的意义可能会发生变化。另外需要说一点,在Java中,对于Unicode转义序列的处理和其他语言有些不同。在Java源代码中的任意位置,都可以使用Unicode转义序列,甚至是关键字都可以。

整数类型

Java中有byte、short、int、long四中整数类型,它们的主要区别在于表示范围的不同。由于现在计算机性能和存储空间都有了极大的增长,所以byte和short两种类型已经很少用了,一般情况下都使用int类型,只有当int类型不够的时候才使用long类型。

有过C语言学习经验的同学可能知道C语言中有一个unsigned关键字,表示无符号类型,但是在Java中没有这个关键字。这就意味着,Java中的所有整数,都是有符号整数。

byte b = 10;

short s = 50000;

int i = 12345678;

long l = 1234567890;

整数字面量含义

5000普通数字,看做int字面量

5000L后缀l或L,long字面量

0b0001前缀0b,二进制数字,即十进制的1

0007前缀0,八进制数字,即十进制的1

0xff前缀0x或0X,十六进制数字,即十进制的255

另外,在整数字面量中还可以使用下划线增强可读性,下划线会被程序忽略,不影响数字的值。由于八进制数字以0作为前缀,容易引起混淆,因此在程序中应避免使用。

在Java中使用整数类型,应注意其范围,避免产生溢出等情况。如果数据溢出,就会出现回绕情况。例如

byte a = 127;

byte b = 1;

byte sum = (byte)(a + b); //结果为-128,发生回绕

浮点数类型

浮点数即小数,由于在计算机中存储的时候位数是固定的,而小数点会发生移动,因此得名浮点数。在Java中有float和double两种类型。float是单精度浮点数,有至少6位有效数字。double是双精度浮点数,至少有15位有效数字。

float f = 12.34F;

double d = 123.456;

d = 1.23E5;

需要注意默认情况下浮点数被认为是double型字面量,如果想要使用float型字面量,需要添加f或F后缀。另外,还可以使用科学计数法表示浮点数。

注意,由于二进制数和十进制数无法进行精确转换,所以Java中的float和double都是近似的,在进行计算的时候需要格外小心,避免产生无法预料的后果。

类型转换

除了布尔类型之外,其余所有的基本类型之间都可以进行互相转换。在转换的时候需要注意数字的范围,如果由小范围向大范围转换,数字精度不会丢失,这样的转换就可以直接进行,称作隐式转换。如果由大范围向小范围转换,数字精度会丢失,这样的转换默认情况下不允许进行。这种情况下需要使用强制类型转换,在要转换的数字前面添加一对括号和要转换的类型,这叫做显式转换。

byte small = 12;

int big = 300;

big = small; //小范围向大范围转换

small = (byte) big; //大范围向小范围转换,需要强制类型转换

浮点数转换成整数的时候,小数部分会被直接截取。

int i = 10;

double d = 12.34;

i = (int) d; //现在是12,小数部分被丢弃

好了,今天就给大家讲这么多吧,喜欢我的内容可以关注或者分享(微信公众平台:tytedu)选择,不再孤军奋战,轻轻松松做IT高薪白领。太原达内培训带领有明确目标的学子迈向成功之路!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值