您的位置:首页 > 编程语言 > Java开发

JAVA基础知识点总结(新手开发必备)

2017-09-20 17:24 274 查看

Java

配置开发环境:


安装JDK。

JDK:可以开发,编译及运行JAVA应用程序的工具。

JRE:可以运行JAVA应用程序的工具。

环境变量:不区分大小写,环境变量使用半角的分号分隔。

Path:JDK的bin路径。

Classpath:一个点

开始运行cmd

java -version

javac

Java版本

JavaSE(J2SE)

JavaEE(J2EE)

JavaME(J2ME)
Java编码规范

类名:首字母大写,其它均为小写。如果由多个单词组成,每个单词首字母大写,其它均为小写。Person,User

变量名:均为小写。如果由多个单词组成从第二个单词开始,每个单词首字母大写其它均为小写。userName,password

方法名:命名规则与变量名一致。selectEmpById();

包名:均为小写。oracle.jdbc.driver.OracleDriver

static final修饰的常量:均为大写,如果由多个单词组成,每个单词之间使用下划线分隔。

泛型名:一个大写字母。
Java基础部分

Java的数据类型:只有两种类型:基本数据类型、引用数据类型(应用数据类型都是对象)。

基本数据类型:8种

整数:Java中没有无符号的数字。Java可以表示十进制,八进制的整数 (用0开头),十六进制的整数(用0X或0x开关),用0b开头可以表示二进制,1.7版本加入的。

byte:1个字节,-27—27-1

short:2个字节,-215—215-1

int:4个字节,-231—231-1,Java中整数默认为int类型。

long:8个字节,-263—263-1,在整数的后面加L或l表示long。

浮点数:浮点数进行算术运算时会产生误差(缺点)。

float:4个字节,在浮点数的后面加F或f。

double:8个字节。Java中浮点数默认为double类型。

字符类型:char,值必须出现在单引号中。单引号中只能有一个字符。Java使用Unicode字符集。所有字符均为两个字节。

布尔类型:boolean。只有两个值:true/false。Java中boolean类型不能转换为其它类型。

变量

格式:数据类型 变量名[=值];

Java是强类型的语言(声明变量的时候必须给变量有类型)。

标识符(类名,变量名,方法名,包名等)命名规则:

标识符只能由字母,数字,下划线,美元符组成。

不能使用数字开头。

不能使用关键字(Java中关键字均为小写)。Goto,const都是java的关键字

当变量没有赋值时,变量不能使用。否则编译失败。

同一个范围中不能出现同名的变量。

常量(最终变量)

使用final关键修饰的变量。

常量:只能赋值一次。

基本数据类型的类型转换

基本数据类型比较大小:先比较精度(小数位),如果精度相同时,比较字节数。

自动转换:Java会自动将小类型的数据转换为大类型的类型。

手动转换:使用手动的方法将大类型的数据转换为小类型的数据。

运算符:

算术运算符:+,-,*,/,%(取余数),++,--

算术运算结果的类型:

当参与算术运算的元素类型相同时,结果的类型一定与参与运算元素的类型保持一致。

当参与算术运算的元素类型不相同时,结果的类型与参与运算元素中大类型的元素的类型相同。

++/--

++/--可以出现在变量的前面或后面。

无论++/--出现在变量的前面/后面,代码执行后变量一定会加1/减1。

++/--出现在后面时:先取值,再运算。

++/--出现在前面时:先运算,再取值。

比较运算符:>,>=,<,<=,==(判断是否相等),!=

比较运算的结果一定为boolean类型。

Java中不是所有的数据类型都可以使用比较运算符进行比较运算。如:基本数据类型与引用数据类型。boolean不能与其它类型进行比较运算。

逻辑运算符:结果一定为boolean类型。

逻辑与(&),逻辑或(|)

与运算
 或运算
元素1
元素2
结果
 元素1
元素2
结果
T
T
T
 T
T
T
T
F
F
 T
F
T
F
T
F
 F
T
T
F
F
F
 F
F
F
短路与(&&,当第一个表达式为false时,不执行第二个表达式,直接返回false)短路或(||,当第一个表达式为true时,不执行第二个表达式,直接返回true)

逻辑非:!,取反。

三元运算符:x ? y : z ;当x为true时,返回y的值。当x为false时,返回z的值。

接收用户输入:java.util.Scanner类。
流程控制

顺序结构,选择结构,循环结构

选择结构:if语句,switch语句

if语句

格式

if(条件){
代码;
}

if(条件){
代码;
}else{
代码;
}

if(条件){
代码;
}else if(条件){
代码;
} else if(条件){
代码;
}……
else{
代码;
}

if语句条件的结果必须为boolean类型。

一个if语句中可以有0个或多个else if语句。

一个if语句中可以有0个或1个else语句。

else语句必须出现在if语句的最后。

当if语句匹配到一个分支后,不再匹配其它的分支,直接跳转到if语句的结束。

if语句的大括号可以省略,如果省略if语句的作用范围只有一行Java代码。

switch语句

格式:

switch(变量){
case 值:
代码;
[break;]
case 值:
代码;
[break;]
……
[default:
代码;
[break;]
]
}

case后面的值不能重复。

case后面只能为常量或字面值。

case
14504
后面可以为表达式。

switch中的变量只能为byte,short,char,int。从JDK1.5开始可以使用枚举。从JDK1.7开始可以使用String。

当switch匹配到一个分支后,会从此分支开始自顶向下执行所有的分支,直到switch的结束或遇到第一个break为止。

default的功能与if中的else是一致的。

default可以出现在switch语句的任意位置。

无论default出现在哪,switch都会先匹配所有的case分支,当没有匹配到任何case分支时,switch才会匹配并执行default分支。

循环结构:while循环,do..while循环,for循环

while循环

格式:

while(条件){
代码;
}

while循环条件的结果必须为boolean类型。

通常,不确定循环次数时建议使用while循环。

while循环:先判断,再循环。

do..while循环

格式:

do{
代码
}while(循环条件);

循环条件的结果必须为boolean类型。

大括号不能省略,必须以分号表示结束。

do..while循环:先循环,再判断,至少会循环一次。

for循环

格式:

for([循环变量的初始化];[循环条件];[循环变量的自增/自减]){
代码;
}

for循环的三部分都可以省略。

第一部分声明的变量是循环中的局部变量,在循环外不能使用。

第一部分可以声明多个类型相同的变量。

当确定循环次数时,建议使用for循环。

中断循环:

break:不能单独使用,只能出现在switch或循环语句中。在循环中的作用:立即结束所在循环。

continue:不能单独使用,只能出现循环语句中。作用:使所在循环立即结束本次循环,直接执行下一次循环。

一维数组:

数组:多个类型相同数据的集合。

声明一维数组:在栈中开辟一个空间,用于保存数组的引用。声明数组时不能指定数组的长度。

格式:数据类型[] 数组名;/数据类型 数组名[];

创建一维数组:在堆中开辟连续的空间,用于保存数组的元素。创建数组时必须指定数组的长度。

int[] array = {10,20,30,40};
double array1[] = new double[10];
String[] array2 = new String[]{"abc","def","123"};

Java中数组都是引用数据类型。但数组中的元素可以为基本数据类型,也可以为引用数据类型

通过下标访问或设置数组中的元素。下标从0开始,最大下标:数组长度减1.

使用.length属性获得数组的长度。

数组的长度确定后不能修改。

数组的长度可以为0,但不能为负数。

数组的默认值:byte,short,int默认为0,long默认为0L,float默认为0.0F,double默认为0.0,char类型默认为’\u0000’(表示一个空字符),boolean默认为false,引用数据类型默认为null。

数组与循环

foreach循环:遍历集合,不能向集合中放数据,只能取数据。因为foreach没有下标。

格式:

for(数据类型 变量 : 集合 ){
代码;
}

通常用于从集合中取数据。

与数组相关的工具类:java.util.Arrays类
类与对象

类中的成员

成员变量(全局变量,属性,字段,域等):在类中直接声明的变量。用于描述类的特征。

成员变量有默认值(与数组的默认值一致),所以成员变量可以直接使用。

new关键字:在堆中开辟空间,创建类的实例(对象)。

成员方法:用于描述类的行为(动作)。

基本格式:

访问权限 返回类型 方法名([参数列表]){
方法体;
}

如果方法不需要返回类型,使用void关键字表示。

return关键字:

结束方法。当方法没有返回类型时,也可以使用return关键字结束方法。

返回数据。

方法的重载:在类中有多个名字相同,但参数不同的方法。参数不同:个数不同,类型不同,顺序不同。

方法的重载与访问权限和返回类型无关。

方法参数的传递:实参会将栈中的内容传递给形参。

形参为基本数据类型:实参将栈中的值传递给形参。形参改变,实参不变。

形参为引用数据类型:实参将栈中的引用传递给形参。形参改变,实参通常都会改变。

构造方法(构造器)

构造方法的特点:

构造方法的名字与类名相同(普通方法的名字也可以与类名相同)。

构造方法没有返回类型,并且不能使用void关键字修饰。

类一定有构造方法。

当类中没有显式的构造方法时,JVM会为类添加默认的构造方法。

默认构造方法的格式:

访问权限与类相同 名字与类名相同(){
}

当类中存在显式的构造方法时,JVM不再为类添加默认的构造方法。

构造方法的作用:初始化类的成员变量。

构造方法通常只能在new关键字的后面调用。

构造方法可以重载。

面向对象的特征:封装,继承,多态,抽象。
类的封装:类中的成员变量为private的,为private的成员变量提供public的get()或set()。
static关键字:static修饰的成员可以通过类名(接口名)直接调用,也可以通过类的对象调用。

修饰成员变量:静态变量,类所有的对象共用一份静态变量。静态变量只在第一次使用类时初始化。实例变量(不使用static修饰的成员变量)在每次创建类的对象时,都需要初始化

修饰成员方法:静态方法,静态方法只能直接调用当前类中静态的成员,静态方法中不能使用this和super这两个关键字。非静态的方法可以直接调用当前类中静态的成员。Static不能修饰类(可以修饰内部类)

包(package)

包的本质:文件夹。

包的作用:

解决类的重名问题。

管理类。

当类位于某个包中时,类的首行(注释除外)必须为package语句。

类可以直接使用同包中的类。

使用其它包中的类时,需要使用import语句导入类(导包)。

eclipse中直接创建在src(default package)下的类无法使用import语句导入。

java.lang包中的元素JVM会自动导入,不需要手动添加import语句。

继承

Java单继承:一个类只能有一个直接或间接的父类。

extends关键字:表示继承。

类之间的关系:

继承:A is B

依赖:A has B(B是A方法是形参)

聚合:A+B=C(A和B是C的成员变量)

父类(根类,基类,超类)

子类可以继承父类所有的成员变量与成员方法。

子类可以继承父类private的成员,但不能使用。

子类不能继承父类的构造方法。

访问权限:普通类(顶层类)只能使用public与默认访问权限修饰。

 类本身
同包中的类
非同包中的子类
非同包中的非子类
private
Y
N
N
N
默认(包权限)
Y
Y
N
N
protected
Y
Y
Y
N
public
Y
Y
Y
Y
可变长参数:从JDK1.5开始出现

格式:数据类型… 参数名

可变长参数只能用于形参。

可变长参数的本质:一维数组。

如果方法有多个参数,可变长参数必须出现在最后。

方法的重写(方法的覆盖)

子类根据需要重写父类中的方法。

重写的方法要与被重写的方法具有相同的方法名,参数列表,返回类型。

重写方法的访问权限要大于等于被重写方法的访问权限。

重写方法抛出的异常必须小于等于被重写方法抛出的异常。父类的方法抛出了异常,子类重写的方法可以不抛出异常。如果子类重写的方法也抛出了异常,那么抛出的异常必须小于第于被重写方法抛出的异常。

static不能产生重写。

继承中的构造方法

默认情况下,子类一定在自己构造方法的第一行使用super()调用父类无参的构造方法。

当父类没有无参的构造方法,而子类没有调用父类有参的构造方法时,编译失败。

多态及引用数据类型的类型转换

当两个类没有继承关系时,不能相互转换。

引用数据类型比较大小:父类大,子类小。

子类可以直接赋给父类(父类的引用指向子类的对象,永远是安全的)。

多态:父类声明,子类创建。

多态时只能访问父类的成员。

父类必须强转才能赋给子类。

父类只有强转为指向的子类类型才是安全的。否则运行时发生异常。

多态中的成员:

多态时调用的属性,一定是父类的。

多态调用的方法:

如果子类没有重写父类的方法,调用父类的方法。

如果子类重写了父类的方法,调用子类的方法(方法的动态绑定).

java.lang.Object类

Object类是JAVA中所有类的直接或间接的父类。

==与equals()

==:判断栈中的内容是否相等。基本数据类型比较的是值。引用数据类型比较引用。

equals():判断当对象与指定对象的内容(堆中的内容)是否相等。equals()最早出现在Object类中,Object类中的equals()仍然是比较栈中的内容是否相等。如果自定义的类需要判断是否相等,可以重写Object类中的equals()方法。

抽象:absrtact

修饰类:抽象类,抽象类不能实例化(不能new)。只能使用抽象类的子类。抽象类也有构造方法(子类需要调用父类的构造方法)。

修饰方法:抽象方法,抽象方法只有方法的声明没有方法实现。子类必须重写父类中所有的抽象方法(如果子类是抽象类时,可以不重写父类中的抽象方法或只重写父类一部分的抽象方法)。抽象方法所在的类必须是抽象类。

修饰接口

abstract不能与哪些关键字一起使用:private,static,final

final关键字:

修饰变量:只能赋值一次。

修饰类:类不能被继承。

修饰方法:方法不能被重写。

接口(interface)

接口的作用:使JAVA实现多继承。

接口是一组常量与抽象方法的集合:

常量:接口中的变量一定为public static final。static final修饰的常量声明时必须赋值。

抽象方法:接口中的方法一定为public abstract。

类与接口的关系是实现(implements)

一个类可以实现多个接口。

接口不是类。接口不能实例化(不能new),只能使用接口的实现类。

当类实现接口时,类必须重写接口中所有的抽象方法(如果实现类是抽象类时,可以不重写接口中的方法或只重写接口中部分的抽象方法)。

接口与接口的关系是继承

一个接口可以继承多个接口。

异常处理

异常结构

Throwable类:是JAVA中所有错误与异常的父类。

Error类:是编写程序时不应该捕获或处理的严重的问题。

Exception类:在编写程序时应该捕获与处理的异常。

非运行时异常:在编写程序时必须捕获或处理的异常,否则.java文件无法编译成.class文件。

RuntimeException及其子类:也称运行时异常,在编写程序时不需要捕获与处理的异常。

try..catch..finally

格式

try{
用于捕获异常,存放可能出现异常的代码。
}catch(异常类型){
用于处理异常,存放处理异常的代码。
}finally{
无论程序是否存在异常,一定执行的代码。
}

try块不能单独使用,必须与catch或finally一起使用。

一个try语句中可以出现0个或多个catch块。

当try块中的代码发生异常时,try会中止执行,程序跳转到对应的catch块中处理异常。

可以使用Exception捕获所有的异常。

Exception必须出现在最后一个catch块中。

工作中不建议在finally块中出现return语句。

throw与throws关键字:

throw:在方法体内手动执行一个异常。

throws:在方法声明的最后,声明调用此方法可能会发生哪些异常。

常用类

数字常用类:

大数字:

java.math.BigInteger:大整数

java.math.BigDecimal:大浮点数

日期常用类:

java.util.Date类:日期类。通常只用于获得当前时间。

java.util.Calendar类:日历类。抽象类。可以获得日期的详细信息,可以对日期进行计算。

java.text.DateFormat类及其子类:对Date与String类型进行类型转换。

DateFormatdf = DateFormat.getDateInstance();
//将Date转换为String
Strings =df.format(date);
System.out.println(s);

s = "1997-7-1";
//将String转换为Date类型
try {
date = df.parse(s);
System.out.println(date);
}catch (ParseExceptione) {
System.out.println("日期格式不正确!!!");
}
//--------------------------------------------
Date date =new Date();
SimpleDateFormat sdf =new SimpleDateFormat("yyyy/MM/dd");
String s =sdf.format(date);
System.out.println(s);
s ="1997/7/1";
try {
date =sdf.parse(s);
System.out.println(date);
} catch (ParseExceptione) {
System.out.println("日期格式不正确!!!");
}

包装类:8个,Byte,Short,Long,Float,Double,Boolean,Integer,Character

装箱:将基本数据类型转换为包装类。

拆箱:将包装类转换为基本数据类型。

从JDK1.5开始可以自动装箱与拆箱。

使用包装类的parseXXX()可以将String转换为对应的基本数据类型。

使用包装类的valueOf()可以将String转换为对应的包装类。

字符串:

java.lang.String类:是JAVA中不可变的字符序列。

每次对String的操作都会产生新的String对象。所以如果需要大量修改字符串时,不建议使用String类。

String重写了Object类中的equals(),用于判断字符串的内容是否相等。

String的方法不会改变自身的内容。

java.lang.StringBuffer类与java.lang.StringBuilder类:是JAVA中可变的字符序列。

每次对StringBuffer与StringBuilder的操作不会产生的新的字符串对象。如果需要大量修改字符串时,建议使用StringBuffer或StringBuilder。

StringBuffer是线程安全的。

StringBuilder是线程不安全的,速度快。

StringBuffer与StringBuilder的方法会改变自身的内容。

StringBuffer与StringBuilder没有重写Object的equals()方法,不能使用equals()判断内容是否相等。

集合

常用集合的结构

常用集合的特点:

Set集合:不能保存重复值,不保存元素加入的顺序。

List集合:保存重复值,可以保存元素加入的顺序。

Map集合:保存一对键与值(Key-Value),键不能重复,值可以重复。

Set集合:

java.util.TreeSet:创建集合时不能指定集合的长度,集合长度不够时不会根据比例增加集合的长度。集合内的元素升序排序。

java.util.HashSet:创建集合时可以指定集合的长度,集合的长度不够时会根据比例增加集合的长度。集合内的元素根据哈希算法排序。

List集合

java.util.ArrayList类:线性的数据结构。根据索引查询元素时效率高,添加与删除元素时效率低。创建集合时可以指定集合的长度,长度不够根据比例增加长度。

java.util.LinkedList类:链表的数据结构。添加与删除元素时效率高,根据索引查询元素时效率低。创建集合时不能指定集合的长度,长度不够不根据比较增加长度。

java.util.Vector类:功能与ArrayList一致,Vector是线程安全的,ArrayList是线程不安全的。

Map集合

java.util.Hashtable:线程安全的。不允许使用null作为键或值。

java.util.HashMap:线程不安全的。允许使用null作为键或值。

泛型

从JDK1.5开始出现。

泛型的作用:后期绑定数据类型。

当不指定泛型时,泛型默认为Object类型。

为泛型添加约束条件:extends 类

I/O流

流的分类:

方向:输入流(读),输出流(写)

单位:字节流,字符流

 字节流
字符流
输入流
InputStream
Reader
输出流
OutputStream
Writer
功能:节点流,处理流(管道流)管道流速度快但是不安全。节点流速度慢,但是很稳定安全。

输入流与输出流的区别

当文件或目录不存在时输入流会抛出异常。

无论文件是否存在,输出流都会重新创建文件。当目录不存在时,输出流才会抛出异常。

输出流有flush()方法,输入流没有。

只有中文或日文用字符流,含有表情图片等要用字节流。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: