第三章Java基本数据类型
Java是一种强类型语言,即Java中的每一个变量都必须有一个声明的类型。 在Java中,有两种类型:
基本类型(primitive type) 有八种
- 逻辑类 boolean - 文本类 char
- 整数类 byte, short, int, long - 浮点类 double, float
两类:数值型(numeric type)
布尔型(boolean type)
复合数据类型(reference type)。
三种:类类型(class type)、
接口类型(interface type)、 数组类型(array type)。
本章主要讲述基本数据类型。
一.逻辑类──boolean
与C语言不同,Java定义了专门的布尔类型。布尔类型的文字只有两个,它们是true和false。布尔类型的变量使用关键字boolean来定义。布尔型的文字和变量常常被用在条件判断语句中。
注意:在Java中,布尔型变量不是数值型变量,它不能被转换成任意一种类型。数值型变量也不能被当作布尔型变量使用。这一点和C语言完全不同。
以下是一个有关boolean类型变量的声明和初始化: boolean truth = true; 二.文本类──char和String
1、使用char类型可表示单个字符。一个char代表一个16-bit无符号的(不分正负的)Unicode字符。一个char文字必须包含在单引号内(‘’)。
‘a’
‘\\t’ 一个制表符
‘\%u????’ 一个特殊的Unicode字符。????应严格按照四个16进制数字进行替换 和在C语言中一样,Java也支持转义字符。Java中使用“\\”将转义字符与一般的字符区分开来。
Java中的转义字符 转义序列 \\b \\t \\n \\f \\r \\” \\’ \\\\ 含义 退格 水平制表 换行 换页 回车 双引号 单引号 反斜杠
2、String不是原始类型,而是一个类(class),它被用来表示字符序列。字符本身符合Unicode标准,且上述char类型的反斜线符号适用于String。与C和C++不同,String不能用 \\0作为结束。 String
- 不是一个原始数据类型,它是一个类 - 具有用双引号引用的文字
“The quick brown fox jumped over the lazy dog.” - 可按如下情形使用:
String greeting = “Good Morning!! \\n”; String err_meg = “ record not found !”;
三.整数类──byte, short, int, long
在Java编程语言中有四种整数类型,每种类型可使用关键字byte, short, int和long中的任意一个进行声明。
整数类型的文字可使用十进制、八进制和16进制表示,如下所示:
2 十进制值是2
047 首位的0表示这是一个八进制的数值 0xBBAC 首位的0x表示这是一个16进制的数值
注意──所有Java编程语言中的整数类型都是带符号的数字。
整数数据类型—范围
Integer Length Name or Type Range 8 bits byte -2 7 ... 2 7 -1 16 bits short -2 15 ... 2 15 -1 32 bit int -2 31 ... 2 31 -1 64 bits long -2 63 ... 2 63 -1
int是最常用的整数类型。但是如果你要表达很大的数,比如在地理信息系统中用整数地图上点的坐标,或表示国家财政预算,就需要用到长整型long。
整数类文字属int类型,除非在其后直接跟着一个字母“L”。L表示一个long值。请注意,在Java编程语言中使用大写或小写L同样都是有效的,但由于小写l与数字1容易混淆,因而,使用小写不是一个明智的选择。上述文字的
long的形式如下:
2L 十进制值是2,是一个long
077L 首位的0表示这是一个八进制的数值 0xBAACL 前缀0x表示这是一个16进制的数值 324932432023L 423432L
而短整型short和字节型byte常常用来处理一些底层的文件操作、网络传输,或者定义大数组。
Java的整数类型不依赖于具体的系统,每种类型在任何一种机器上占用同样的存储空间,比如,int总是32位,long总是64位。在C++中,整数类型的大小是和具体的机器有关的,在SPARC机上运行正常的C++程序到了Intel 586机上就可能会溢出,因为在SPARC机上,C++的int是64位的,而Intel 586机上的C++的int是32位的。但在Java中,这个问题不存在了,因为Java的整数类型不依赖于具体的系统。 四、浮点类──float和double - 缺省为double
浮点变量可用关键字float或double来声明
- 如果一个数字文字包括小数点或指数部分,或者在数字后带有字母F或f(float)、D或
d(double), 则该数字文字为浮点。 - 浮点文字包括小数点或下列各项之一
- E或e (增加指数值) - F或f (float)
- D或d (double) - 例如:
3.14 一个简单的浮点值(a double) 3.02E23 一个大浮点值
2.718F 一个简单的float长度值
123.4E+306D 一个大的带冗余D的double值 浮点数据类型具有下列范围:
浮点长度 名称或类型 32 bits float
64 bits double
注意──浮点文字除非明确声明为float,否则为double
如果您希望速度快一些,或者占用的空间少一些,您可以选择float型。
-
五 数据类型转换
按照Java的语言规范,转换是指隐式的把一个表达式的类型(或值)改变成该表达式的周围的上下文能够接受的类型。有时候这需要一个运行时期的操作,以检查转换是否有效,或者把表达式的运行时期值转换成适合新类型的形式。 转换规则:
1.两个操作数中有一个是double型,那么在运算前将另一个操作数也转换成double型。 2.两个操作数中有一个是float型,那么在运算前将另一个操作数也转换成float型。 3.两个操作数中有一个是long型,那么在运算前将另一个操作数也转换成long型。
显式的类型强制转换: double result; result=1.5+3/2;
结果是2.5 因为3/2按整数运算计算,结果是1。 强制转换:
result=1.5+(double)3/2; 结果是3。
能将任何一种类型强制转换成其他类型,但必须小心以免丢失数据信息。显然,将较长的整型数据转换为较短的整型数据很有可能丢失信息。如浮点类转化成整数一样。 当位数少的类型转化为位数多的类型时,自动类型转换 byte- short int long float double从前向后自动转换 当位数多的类型转化为位数少的类型时,强制类型转换
六 、变量、说明和赋值
变量是内存中的一种存储位置。它用标识符标识,您可以通过这个标识符来修改其中存储的值。变量有相应的类型,这个类型是编译时期类型。这种类型或者是基本类型,或者是复合类型。基本类型的变量总是拥有那个确定的基本类型的值。 1、 java变量的定义
在Java中,变量在使用之前必须要先定义。变量定义的格式如下:Java中的所有类型,除了null类型以外,都可以定义变量。 数据类型 标识符[,标识符];
数据类型是指定义何种类型的变量,它必须是有效的Java类型;标识符则是要定义的变量的名称,它必须是Java中合法的标识符。方括号表示可选,在一条变量定义语句中,您可以定义一个或多个变量,多个变量中间用逗号隔开。 下面给出了一些变量定义的例子:
byte recordSize; short salary;
int studentsOfPKU=80; long planetNumber; float scoreofStudent=45.23f; double distanceEarthToMoon; char firstNameOfChinesePeople; boolean isBoy;
注意:不能用Java中的关键字作为变量名。 2变量的初始化
Java程序中每个变量在使用前必须有一个值。Java中不能引用没有值的变量,程序给出了一个错误的例子。 class Test {