java基础知识点总结(一)

java基础知识点总结(一)

  • java SE概览
  • 一、环境篇
    • 1. JDK和JRE
    • 2. 为什么要配置PATH环境变量
    • 3. classpath环境变量是什么,为什么已经不需要配置了
    • 4. %JAVA_HOME%是什么,必须设置吗?
  • 二、java五大特点
  • 三、八大基础数据类型
  • 四、继承、多态、封装
    • 1. 继承
      • 继承的特性:
    • 2. 封装
    • 3. 多态
  • 五、关键字
  • 六、抽象类和接口
  • 七、堆和栈
  • 八、拷贝
  • 九、java常用类
  • 十、异常
    • 1. 什么是异常
    • 2. 异常类型
    • 3. 异常捕获
    • 4. Throwable类的主要方法:
    • 5. 自定义异常
  • 十一、集合
  • 十二、数据结构
    • 1. 栈:
    • 2. 堆:
    • 3. 数组:
    • 4. 队列:
    • 5. 链表:
    • 6. 树:
    • 7. 图:
    • 8. 散列表(哈希表):

打算重新看看java基础,把开始学的时候模糊的概念理清楚,尤其我的好闺蜜也开始学java了,整理一份给她~ (不定时更新)

java SE概览

其实就是javaSE必须要掌握的知识点,见目录

一、环境篇

1. JDK和JRE

三个概念:
JDK: java development kit(java开发工具)
JRE: java runtime environment(java运行时环境)
JVM: java Virtual Machine(java虚拟机)

a. JDK:
JDK就是我们开发人员使用的开发工具,它里面包含了JRE、JVM和基础类库。所以编程的话只需要安装JDK,配置环境变量,path路径就可以了。
b. JRE:
JRE是运行环境,如果说我们写完的java程序需要部署到客户的服务器上运行,当然客户是不需要开发的,那我们仅安装JRE就可以,当然JRE里包含JVM,运行环境嘛,肯定要运行到JVM虚拟机上。JRE的lib目录中放了一些java类库的class文件。
c. JVM:
JVM:java虚拟机,JVM上会运行java编译的class文件,当然它在运行解释class时会调用类库还完成运行,也是因为JVM,我们的java才能完美的跨平台,因为它让java程序只需要在JVM上运行而不是操作系统平台本身。

2. 为什么要配置PATH环境变量

答:为了在命令行窗口下编译和运行Java程序!

为什么说在命令行窗口下呢,因为比如近几年喜欢用的IDEA,我们可以不配置环境变量,仅仅在IDEA的settings里面配置好jdk的安装目录,就可以运行使用了。但是如果不配置环境变量,我们在命令行窗口下是无法编译运行我们写好的java源文件(不在编译程序的文件夹下),为什么呢?

开发人员编写的java文件是无法被计算机识别的,需要JDK中的编译程序javac.exe来进行编译,那么除非我们将我们的源码放到编译程序所在目录下,否则不配置环境变量的情况下,系统根本无法找到我们的源码位置,所以编译程序也就无法完成编译。javac是不是很熟悉,开始学java的时候,老师教我们的判断环境变量部署是否成功,就可以输入javac,如果配置错误,会出现以下:java基础知识点总结(一)_第1张图片
这个就是经典的jdk安装成功但路径配置错误。
经过以上解释,我们配置环境变量的原因就是能够让我们在任何文件夹下都能用执行java命令,包括编译程序以及其他可执行文件。

3. classpath环境变量是什么,为什么已经不需要配置了

以前配置变量时,一个要配置PATH变量(指定java位置),另一个要配置classpath环境变量。那么这个变量又是来做什么的呢?跟PATH变量有何区别?

在PATH变量配置时,曾说过我们编写完源码,java要将它们编译成class文件,再之后就要执行程序了。也就是说需要把class文件读到JVM中,并转换为计算机能识别的语言来执行。而classpath变量,看名字也知道,是class文件的路径变量,我们需要指定一个路径,告诉JVM去这个路径下找class文件执行,如下图:
java基础知识点总结(一)_第2张图片
变量值前面的 “.” 就是告诉虚拟机要在当前路径下搜索,那通常也会把JDKbin文件下的dt.jar和tools.jar也放到classpath里面。dt.jar是环境运行的类库,tools.jar是工具类库,这两个类库支撑大部分java程序的运行。

但是很多人会发现,我们现在一般不会去配置classpath这个变量,这是因为JDK1.5版本之后,JRE可以自动检索当前文件夹下的class文件,并且自动加载上述两个工具类库,因此我们再也不需要配置classpath变量了。

4. %JAVA_HOME%是什么,必须设置吗?

在配置变量前,我们都会设置**%JAVA_HOME%变量**,设置值如下:
java基础知识点总结(一)_第3张图片
说白了它就是引用jdk的地址,可以把它想象一个变量名,变量值是JDK的安装路径。当然,在path里直接写到bin文件下也是可以的,但是我们推荐使用%JAVA_HOME%的原因,其一是jdk版本迭代是,只需要修改%JAVA_HOME%值即可,当然这只是很小的原因,毕竟也不会经常迭代,重要的是像一些插件或者服务器或者IDEA,都会通过这个变量名去找JDK的安装路径,为了减少不必要的麻烦,还是动动小手指添加一个%JAVA_HOME%吧。

二、java五大特点

  1. java概念简单,了解一些基本概念就可以编写应用程序。
  2. 面向对象,java是面向对象语言,万物皆对象,每个对象都有自己的类型,都可以实例化。
  3. 分布式,支持internet开发,提供用于网络应用编程的类库
  4. 安全,java提供安全机制以防恶意代码攻击。
  5. 健壮,java不支持指针,可以避免指针操作中的错误。还包括强类型和异常处理、废料自动回收等。

三、八大基础数据类型

这个没什么好说的,记住
java基础知识点总结(一)_第4张图片

四、继承、多态、封装

1. 继承

面向对象语言类和类关系的一种,继承就是子类继承父类的特征行为,使得子类对象(实例)具有父类的实例域和方法,或子类从父类继承方法,使得子类具有父类相同的行为。
简单来说就是为了避免重复代码,在父类定义一些方法,它的每个孩子都必须要继承的,但是子类自己的方法体内可以不同。

继承的特性:

  • 子类拥有父类非 private 的属性、方法。
  • 子类可以拥有自己的属性和方法,即子类可以对父类进行扩展。
  • 子类可以用自己的方式实现父类的方法。
  • Java 只能单继承,不能多继承,但是可以多重继承。
    java基础知识点总结(一)_第5张图片

2. 封装

封装,就是保护自己内部代码,将一些接口的实现细节包装隐藏。
举个例子,定义一个Person类,两个属性用private修饰,代表只有本类能访问,隐藏两个属性,但是对外提供获取和修改两个属性的方法。

3. 多态

多态就是,同一个接口,使用不同实例来执行不同的操作。
存在的三个条件:

  • 继承
  • 重写
  • 父类指向子类对象Parent p = new Child();

五、关键字

  1. extends:继承,单继承
  2. implements:实现,可以多实现
  3. super:引用当前对象的父类,实现对父类成员的访问
  4. this:指向自己的引用
  5. final:最终,final修饰的类不能被继承,修饰的方法不能被重写
  6. native:native充当JAVA语言与除JAVA之外的其他语言编写的代码块或库之间的链接,这可能取决于您操作的机器。如果将native关键字应用于一个方法,那么这意味着该方法将通过JNI(JAVA native interface)使用其他语言(如C或C++)编写的本机代码来实现。
  7. throw/throws:用于抛出异常,throw在方法体内使用,throws在方法末尾处使用
import java.io.*;
public class aaa
{
  public void method1(String param) throws Exception {
    // 方法体
  }
  public void method2(String param) {
	// 方法体
	throw new RemoteException();
  }
}
  1. abstract:抽象的 ,可以用来修饰的结构:类、方法。
  2. static:静态,静态对象不需要依赖任何对象就可以访问

六、抽象类和接口

抽象类的特点:

  1. abstract修饰类
  2. 不能被实例化
  3. 可以有抽象方法,也可以有普通方法,但是有抽象方法的类一定是抽象类,普通类不允许有抽象方法
  4. 如果非抽象类继承了抽象类,必须要实现抽象类内全部的抽象方法
  5. 抽象方法不能被static、final修饰

接口特点:
6. interface修饰类
7. 不能被实例化
8. 可以多实现
9. 接口内方法都是抽象方法,省略了public abstract,在java8后,接口里可以定义静态方法,静态方法有方法体。

七、堆和栈

JVM在运行时会在内存中开辟一片内存区域

  JVM内存:
   1.   寄存器
   2.   本地方法区
   3.   方法区
   4.   栈内存
   5.   堆内存。

栈内存: 栈内存存储的都是局部变量,一般来说先加载函数才能进行局部变量的定义,所以方法先进栈,然后再定义变量,一旦离开变量作用域,就会被释放。

堆内存: 存储的是对象,凡是new建立的都是在堆中,堆中存放的都是实体(对象)。实体用于封装数据,对象内的成员变量也存储在堆中。如果一个数据消失,这个实体也没有消失,还可以用,所以堆是不会随时释放的,但是会被Java的垃圾回收机制不定时的回收。

八、拷贝

有时候需要对一个对象进行处理,但是又不想改变原有的对象,那么就要将对象拷贝成一个新的对象并操作新对象。

方法:
实现Cloneable接口,重写clone方法
实现Serializable接口,序列化和反序列化,实现深克隆。
BeanUtils、apache和Spring都提供bean工具,都是浅克隆。
深克隆,既克隆基本类型变量,又克隆引用类型变量,浅克隆只克隆基本类型变量。

九、java常用类

Object、String、Math、Date
常用类博客:https://blog.csdn.net/sugar_no1/article/details/88016599

十、异常

1. 什么是异常

异常是程序中的一些错误,但并不是所有的错误都是异常,并且错误有时候是可以避免的。

2. 异常类型

  • 检查性异常: 最具代表的检查性异常是用户错误或问题引起的异常,这是程序员无法预见的。例如要打开一个不存在文件时,一个异常就发生了,这些异常在编译时不能被简单地忽略。
  • 运行时异常: 运行时异常是可能被程序员避免的异常。与检查性异常相反,运行时异常可以在编译时被忽略。
  • 错误: 错误不是异常,而是脱离程序员控制的问题。错误在代码中通常被忽略。例如,当栈溢出时,一个错误就发生了,它们在编译也检查不到的。

java中所有的异常都是Exception的子类,而Exception和Error都继承了Throwable类。
Exception区别于Error,Error是脱离人为控制的存在,在代码中通常被忽略,比如JVM 内存溢出,Error是运行时出现的错误,java通常不捕获错误。
java基础知识点总结(一)_第6张图片

3. 异常捕获

异常用 try catch来捕获
多重捕获:

try{
   // 程序代码
}catch(IOException e1){
  // 程序代码
}catch(NullPointerException e2){
  // 程序代码
}catch(异常类型3 异常的变量名3){
  // 程序代码
}

4. Throwable类的主要方法:

java基础知识点总结(一)_第7张图片

5. 自定义异常

如果要写一个检查性异常类,需要继承 Exception 类。如果要写一个运行时异常类,需要继承 RuntimeException 类。

class MyException extends Exception{
	// 属性
	// 方法体
}

十一、集合

java的集合框架主要包括两种类型的容器,CollectionMap。Collection来存储元素集合,Map来存储键值对。简单来说集合就是长度可变的容器,用来存储对象的。
java基础知识点总结(一)_第8张图片
接口部分:

  • Iterator:集合的输出接口,用于遍历集合中的元素,也就是迭代器。
  • Collection:一般不直接用Collection,存储一组不唯一无序的对象。
  • List:最常用的接口,可以通过索引访问元素,存储一组不唯一有序的对象,类似数组。
  • Set:无序的Collection,存储唯一无序的对象。
  • Queue:队列,类似List
  • Map:存储键值对象,key->value形式存储

接口实现类部分:

  • ArrayList:最常用的list,查询快,插入删除慢,有序、非线程安全,支持序列化,底层实现数组
  • LinkedList:顺序访问速度快,但是随即访问速度慢,有序、非线程安全,底层实现链表,插入删除快,查询慢
  • vector:类似ArrayList,线程安全,底层数组,查询快,增删慢,效率低
  • HashMap:最常用的Map,用Hash算法存取对象,jdk1.8后底层是数组+链表+红黑树
  • TreeMap:可对对象排序,底层红黑树
  • Hashtable:同步,线程安全
  • HashSet:优化了查询速度,基于HashMap实现
  • TreeSet:是一个有序的Set,底层实现二叉树

十二、数据结构

集合里每个实现类底层都有自己实现的数据结构,这里简单介绍几种数据结构:

1. 栈:

先进后出,入口出口在同一侧,(像矿泉水瓶,只有一个口),入栈数据:123,出栈数据:321

2. 堆:

二叉树的两种结构,一种是链式结构,一种就是顺序结构,普通二叉树其实是不适合用数组来存储数据,因为会造成大量空间的浪费,但完全二叉树似乎更合适于顺序结构存储,我们通常把堆(完全二叉树) 使用顺序数组来存储。
https://blog.csdn.net/weixin_45350120/article/details/108614291

3. 数组:

数组地址是连续的,长度固定,通过数组的首地址找到对应的数组,然后用索引来查找数组中的元素,但是如果想对数组进行增/删操作,必须创建一个新的数组,把原来的数据复制过来,形成新数组后,销毁原数组,所以查询快,增删慢

4. 队列:

不同于栈,队列是先进先出,入口出口分布在集合的两侧,存储数据:123,取出数据:123,(类似排队安检)

5. 链表:

跟数组相反,链表中的地址不连续,每次查询元素都需要从头开始查询,但是增删对整体结构无影响,所以查询慢,增删快

链表中每个元素称为一个节点,节点包括自己的地址、数据本身、下一个节点的地址
java基础知识点总结(一)_第9张图片

6. 树:

树详解https://zhuanlan.zhihu.com/p/74141967

7. 图:

感兴趣的可以看看
图简介https://wenku.baidu.com/view/028083711db91a37f111f18583d049649b660eb1.html

8. 散列表(哈希表):

哈希表(Hash table,也叫散列表),是根据关键码值(Key value)而直接进行访问的数据结构。也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度。这个映射函数叫做散列函数,存放记录的数组叫做散列表。
哈希表原理详解https://blog.csdn.net/yyyljw/article/details/80903391

注意:
内存中的堆栈和数据结构堆栈不是一个概念,内存里的堆栈是真实存在的,数据结构是抽象的

数据结构原理:https://www.cnblogs.com/javastack/p/13474377.html

下一博客:
java基础知识点总结(二)泛型、IO流、多线程

你可能感兴趣的:(java基础,java基础,环境)