第一章
Java特性:
- 简单性
- 面向对象
- 网络技能
- 健壮性
- 安全性
- 体系结构中立
- 可移植性
- 解释型
- 高性能
- 多线程
- 动态性
面向对象是一种程序设计技术。它将重点放在数据和对象的接口上。
及时编译器可以监控经常执行哪些代码并优化这些代码以提高速度。更为复杂的优化是消除函数调用。及时编译器知道哪些类已经加载。如果基于当前加载的类集,且特定的函数不被覆盖的话就可以内嵌。必要时,还可以撤销优化。
Java是一种程序设计语言,XML使用描述数据的方式。
第三章 语法
基础
Java对大小写敏感。
关键字public称为访问修饰符,它用于控制程序的其他部分对这段代码的访问级别。
Java中类名必须以字母开头,后面可以跟字母和数字的任意组合,长度上基本没有限制,但是不能使用Java保留字作为类名。源代码的类名必须与公共类型的名字相同,并用.java
作为扩展名。
每个Java应用程序都必须有一个main方法,格式:
public class ClassName {
public static void main(String[] args) {
programa statements
}
}
Java调用的语法:
object.method(parameters)
在Java中,可以没有参数,也可以有一个或多个参数,对于一个方法,即使没有参数也需要使用空括号。
数据类型
Java是一种强类型语言。这就意味着必须为每一个变量声明一种类型。在Java中,一共有8个基本类型,其中有4中整型、2中浮点类型、一种用于表示Unicode编码的字符型char和一种用于表示诊治的boolean类型。
在Java中,整型的范围与运行Java代码的机器无关。长整型数值有一个后缀L,十六进制数值有一个前缀0x
,八进制有一个前缀O
。Java7开始可以为数值字面量下面加下划线如1_000_000
表示一百万。加上前缀0b
就可以写二进制数。
float类型的数值有一个后缀F,没有后缀F的浮点数值默认为double类型。
便是溢出和出错的三个特殊的浮点数值:
- 正无穷大
Double.POSITIVE_INFINITY
- 负无穷大
Double.NEGATIVE_INFINITY
- NaN(不是一个数字)
Double.NaN
浮点数不适合用于禁止出现舍入误差的金融计算中,其主要原因是浮点数值采用和二进制系统表示,而在二进制系统中无法精确的表示分数1/10。若果需要在计算中不含有任何舍入误差,就应该使用BigDecimal类
char类型用于表示单个字符,通常用来表示字符常量。
代码点是指与一个编码表中的某个字符对应的代码值。第一个代码级别称为基本的多语言级别,代码点从U+0000到U+FFFF,其余的16个附加级别,代码点从U+10000到U+10FFFF,其中包括了一些辅助字符。
强烈建议不要在程序中使用char类型,除非确实需要对UTF-16代码单元进行操作。最好将需要处理的字符串用抽象数据类型表示。
变量
逐一声明每一个变量可以提高程序的可读性。
在声明一个变量之后,必须用赋值语句对变量进行显示初始化,千万不要使用未初始化的变量。Java中可以将声明放在代码的任何地方。
关键字final表示这个变量只能被赋值一次,一旦被赋值之后,就不能够再更改了。习惯上,常量名使用全大写。
在Java中,通常希望某个常量可以在一个类中的多个方法中使用,通常将这些常量称为类常量,可以使用关键字static final
进行修饰。
整数被0除将会产生一个异常,而浮点数被0除将会得到无穷大会NaN结果。
在默认情况下,虚拟机设计者运行将中间计算结果采用扩展的精度,但是对于使用strictfp
关键字标记的方法必须使用严格的浮点计算来产生理想的结果。
>>>
运算符将用0填充高位;>>
运算符用符号位填充高位。
在Math类中,为了达到最快性能,所有的方法都使用计算机浮点单元中的例程。如果得到一个完全可以预测的结果比运行速度更重要的话,那么久应该使用StrictMath类。
隐式类型转换:
- 如果两个操作数中有一个是double类型,另一个操作数就会转换为double类型
- 否则,如果其中一个操作数是float类型,另一个操作数将会转换为float类型
- 否则,若果其中一个操作数是long类型,另一个操作数将会转换为long类型
- 否则,两个操作数都将被转换为int类型
强制类型转换(显示类型转换):
dounle x = 9.997;
int nx = (int) x;
如果想对浮点数进行舍入计算,以便得到最接近的整数,那就需要使用Math.round
方法。
round方法返回的结果为long类型,由于存在信息丢失的可能性,所有只有显示的强制类型转换才能够将long类型转换成int类型。
如果试图将一个数值从一种类型强制转换为另一种类型,而又超出了目标类型的表示范围,结果就会截断成一个完全不同的值。不要在boolean类型与任何数值类型枝江进行强制类型转换,这样可以防止发生错误。
将布尔类型转换为数值类型:
b? 1:0
字符串
String类的substring方法可以从一个较大的字符串提取出一个子串。substring方法的第二个参数是不想复制的第一个位置。优点:容易计算子串长度。
Java语言运行使用+
号连接两个字符串。
String类没有提供用于修改字符串的方法,并且其还是final类。不可变字符串的优点:编译器可以让字符串共享。如果复制一个字符串变量,原始字符串与复制的字符串共享相同的字符。Java的设计者认为共享带来的高效率远远胜过提取、拼接字符串带来的低效率。
可以使用equals方法检测两个字符串是否相等。如s.quals(t)
。要想检测两个字符串是否相等,而不区分大小写,可以使用equalsIgnoreCase方法。
使用==
运算符只能够确定两个字符串是否放置在同一个位置上。
实际上只有字符串常量是共享的,而+
或substring
等操作产生的结果并不是共享的。
空串是一个Java对象,有自己的串长度和内容。不过String变量还可以存放一个特殊的值,名为null,这表示没有任何对象与该变量关联。
大多数常用的Unicode字符使用一个代码单元就可以表示,而辅助字符需要一对代码单元表示。length方法将返回采用UTF-16编码表示的给定字符串所需的代码单元数量。
StringBuilder类的前身是StringBuffer,其效率稍低,但允许采用多线程方式执行添加或删除字符的操作。如果所有字符串在一个单线程中编辑,则应该用StringBuilder替代它,这两个类的API是相同的。
输入与输出
System.in
标准输入
System.out
标准输出
System.error
标准错误
控制台读取输入:
- 首先需要构造一个Scanner对象,并与“标准输入流”System.in关联。
Scanner in = new Scanner(System.in);
- 使用Scanner类的各种方法实现输入操作
因为输入是可见的,所以Scanner类不适用于从控制台读取密码。
可以使用s转换符格式化任意的对象,对于实现了Formattable接口的对象都将调用formatTo方法;否则将调用toString方法,他可以将对象转换为字符串。
许多格式化规则是本地环境特有的。
要想对文件进行读取,就需要一个用File对象构造一个Scanner对象。
要想写入文件,就需要构造一个PrintWriter对象。在构造其中,只需要提供文件名。
如果用一个不存在的文件构造一个Scanner,或者用一个不能被创建的文件名构造一个PrintWriter,那么就会发生异常。
控制流程
不能在嵌套的两个块中声明同名的变量。
在Java中,条件语句的格式为:
if (condition) {
statement;
}
或
if (condition){
statement;
} else {
statement;
}
while循环:
while (condition){
statement;
}
do/while循环:
do statement while(condition);
for循环的语句中3个部分应该对同一个计数器变量进行初始化、检测和更新。
for(循环变量;判断条件;改变内容)
如歌哦在for语句内部定义一个变量,这个变量就不能在循环体之外使用。
在switch语句中,如果没有相匹配的case标签,而有default子句,就执行这个子句。
case标签可以是:char、byte、short、int、及其包装器类型,枚举常量及字符串字面值
使用break跳出这一层的循环,使用continue继续下一次循环。使用带标签的break语句可以跳出多重嵌套循环。continue语句将控制转移到最内层循环的首部。
还有一种带标签的continue语句,将跳到与标签匹配的循环首部。
for-each循环,可以用来依次处理数组中的每个元素而不必为指定下标值而分心。
for(variable :collection) statement
第一一个变量用于暂存集合中的每一个元素,并执行相应的语句。collection这一集合表达式必须是一个数组或者是一个实现了Iterable接口的类对象。for-each循环语句的变量将会遍历数组中的每个元素,而不需要使用下标值。
数组
数组是一种数据结构,用来存储同一类型值的集合。通过一个整型下标可以访问数组中的没一个值。使用new运算符创建数组。创建一个数字数组时,所有元素都初始化为0,boolean数组的元素会初始化为false。对象数组的元素则会初始化为一个null。
数组拷贝时,如果长度小于原始数组的长度,则只拷贝最前面的数据元素。
Arrays.sort(a)
这个方法使用了优化的快速排序算法。
Math.random
方法将返回一个0到1(不包含1)的随机浮点数。
单层的for each循环语句不能自动处理二维数组的每一个元素,其是按照行进行处理的,也就是一维数组处理的。
Java实际上是没有多维素组,只有一维数组,多维数组被解释为”数组的数组“。