目录
-
一、基础类型
-
二、流程控制与数组
-
三、面向对象
-
四、基础类库
-
五、集合
-
六、泛型
-
七、异常
-
八、数据库
-
九、注释
-
十、输入输出
-
十一、网络
-
十二、类加载机制
-
十三、多线程
面向对象三大特性:封装、继承、多态
一、基础类型
-
char, int, short, long, byte, float, double, boolean
-
基本类型的类型转换(自动与强制、补码,反码与原码)
-
逻辑运算符(不短路与&,和&&; | 和|| 两个的只执行最少比较,单个的都比较)
-
运算符的优先级
二、流程控制与数组
-
if, while, for
-
break, continue, return
-
数组在内存中,初始化
-
java8增强工具类:Arrays
三、面向对象
-
类和对象;方法(值传递,基础·类型传递值到不同方法栈区,对象类型传递引用值,引用自内存堆的对象)
-
成员变量、局部变量的初始化和内存中的运行机制;
-
隐藏与封装:private、default、protected、public
-
构造器
-
继承:单继承
-
多态:编译时类型、运行时类型
-
instanceof前一个需要和后一个类有关系,否则编译错误。比如String instanceof Math,无法通过编译;
-
继承与组合:开销无差别,继承is-a;组合has-a
-
final、abstract、接口与抽象类
-
内部类(非静态内部类、静态内部类)
-
Lambda表达式
-
枚举类
-
对象与垃圾回收可达、可恢复、不可达System.gc(); Runtime.getRuntime().gc();finalize方法软、弱、虚引用
四、基础类库
-
Object,Java8增强Objects(大多是空指针安全的)
-
String、StringBuffer(线程安全,每个方法加了synchronized 关键字,和StringBuidler同继承自AbstractStringBuilder方法)、StringBuilder
-
Math库
-
Random、ThreadLocalRandom(Java7新增用于并发线程安全)
-
BigDecimal(double类型容易发生精度丢失:4.015*100=401.499999999994)
-
Date(不推荐)、Canlendar、Java8新增java.time包
-
正则表达式:\d \D \s \S \w \W;[]枚举 -范围 ^否 &&与 ;^开头 $结尾 \b边界 \B \A输入的开头 \G前一个匹配的结构 \Z输入的结尾,仅用于最后的结束符 \z输入的结尾;贪婪模式(匹配最多,默认)、勉强模式(匹配最少,?)、占有模式Pattern p = Pattern.compile("a*b");Mathcer m = p.matcher("aaaaab");boolean b = m.matches(); //返回true
-
SimpleDateFormat、Java8新增DateTimeFormatter
五、集合
Set:无序,下面实现类都是非线程安全的
-
HashSet:非同步、元素可以是null
-
LinkedHashSet:以插入顺序保存,遍历效率高
-
TreeSet:排序,红黑树排序
-
EnumSet:有序,以位向量存储,紧凑高效,占用内存小,对于批量操作非常快;不允许插入null
List:有序、可重复
-
ArrayList:线程不安全的,可以通过Collections工具类变成线程安全的;数组存储
-
Vector:线程安全,不过很老了,不推荐使用
-
LinkedList:也实现了Deque接口,可以作为双端队列或者栈;链表存储
Queue队列
-
PriorityQueue:按照元素大小重新排序
-
Deque(类似于双端队列,也可以作为栈的实现),ArrayDeque
Map
-
HashMap:线程不安全;允许放入null作为key或value;
-
Hashtable:古老,类似于Vector,不推荐使用,线程安全,不允许放入null;Properties是它的子类
-
LinkedHashMap
-
TreeMap,SortedMap
-
WeakHashMap
Hash的知识点:
-
容量(capacity,默认是10)、初始化容量(可以通过构造器传入)
-
尺寸(当前hash表中记录的数量)
-
负载因子,一般是0.75;超过时会发生rehashing,比较消耗
Collections:提供的集合工具类,操纵List、Set、Map
-
排序、查找、替换
-
同步控制List list = Collections.synchronizedList(new ArrayList()),可以获得线程安全的ArrayList
六、泛型
编译时不检查类型的异常,所以需要泛型
-
没有泛型类:Collections instanceof java.util.ArrayLsit<String>()这个是错误的
-
类型通配符
-
类型上限与下限,当从List<string>变成List时,发生了类型擦除,变成了上限Object
七、异常
-
finally
-
throw, throws,try catch
-
不要过度使用异常
-
不要使用过于庞大的try块
-
避免使用Catch All语句
-
不要忽略捕获到的异常
八、数据库
Class.forName(“com.mysql.jdbc.Driver”); try{ Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/select","root","xxxx"); Statement stat = conn.createStatement(); ResultSet rs = stat.execute("sql语句"); while(rs.hasnext){sysout(rs.getXX)} stat.executeUpdate("updateSql语句"); conn.commit(); }
-
连接池(DBCP数据源、C3P0数据源)
九、注释
-
@override,@Deprecated, @SuppressWarnings
-
@Retention,@Target, @Document
-
自定义注释(public @interface Test {}) 用法:@Test
-
只加注解是没有用的,结合反射使用 method.isAnnotationPresent方法来做处理
十、输入输出
-
File:不能访问文件本身,需要使用输入/输出流
-
字节流(8位字节,Inputstream、OutputStrem)、字符流(16位字符,Reader、Writer)
-
转换流(只提供了从字节流转换为字符流)
-
序列化(类实现了Serializable,所有的成员变量也都需要是可序列化的),通过transient指定序列化时可以无需理会(只能用于修饰实例变量)
-
NIO,从java1.4开始,放在java.nio包下;两个核心对象Channel、Buffer
-
NIO.2 Path、Paths、和Files核心API、FileVisitor
十一、网络
-
InetAddress代表ip地址
-
URLDecoder,URLEncoder
-
......太多了
十二、类加载机制
-
加载过程加载:将类的class文件读入内存,并为之创建一个java.lang.Class对象连接:验证、准备、解析初始化:虚拟机对类进行初始化
-
类加载器根类加载器 bootstrap扩展类加载器 extension系统类加载器 system
-
反射(由于对象存在编译时类型和运行时类型,程序需要在运行时发现对象和类的真实信息)获得Class对象:forName获取构造器 getConstructor方法getMthod, method.invoke();获取成员变量getField获取标注getAnnotation...等
-
使用反射生成JDK动态代理
十三、多线程
一、创建线程三种方式
继承Thread、实现Runnable、Callable接口
二、线程的生命周期
新建和就绪、运行和阻塞、死亡
三、控制线程
join、后台进程Daemon、睡眠Sleep、让步yield
-
synchronized关键字可以修饰方法、代码块,但是不能修饰构造器、成员变量等synchronized修饰的同步方法,因为该类的默认实例是this,就是同步监视器,所以可以直接调用Object的wati(), notify(),notifyAll()方法;synchronized修饰的是同步代码块,同步监视器就是synchronized括号后的对象,所以必须使用该队现改对象调用这三个方法。
-
java8提供了新型的StampedLock类,大多数场景中它可以替代传统的ReentrantReadWriteLock
-
ReentrantReadWriteLock为读写操作提供了三种锁模式:Writing、ReadingOptimistic、Reading
-
常用的是ReentrantLock(可重入锁)Private final ReentrantLock lock = new ReentrantLock();public void m(){ lock.lock(); try{ // 需要保障线程安全的代码} finally{lock.unlock();}}如果是用Lock,则使用Condition将wait,notify,nitifyAll分成不同对象private final Lock lock = new ReentrantLock();privat final Condition cond = lock.newCondition();lock.lock();cond.await();\ cond.signalAll();
-
使用阻塞队列(BlockingQueue)控制线程通信
线程组 ThreadGroup
线程池:从java5开始,提供了Executor工厂类
线程相关类:ThreadLocal
产生死锁的原因主要是:
(1) 因为系统资源不足。
(2) 进程运行推进的顺序不合适。
(3) 资源分配不当等。
产生死锁的四个必要条件:
(1) 互斥条件:一个资源每次只能被一个进程使用。
(2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。
(3) 不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。
(4) 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。