java基础

Java8的接口方法可以有如下定义
only public, abstract, default, static and strictfp are permitted

在这里插入图片描述
equals与hashCode
1.equals()相等的两个对象他们的hashCode()肯定相等,也就是用equals()对比是绝对可靠的。

2.hashCode()相等的两个对象他们的equal()不一定相等,也就是hashCode()不是绝对可靠的。

java运行时,私有公有区别
java运行时内存分为“线程共享”和“线程私有”两部分
1.私有:java虚拟机栈,程序计数器,本地方法栈
2.共享:java堆,方法区

接口与抽象类区别

  • 接口
    接口方法默认被 public abstract修饰
    成员变量默认被public static final修饰
    jdk8之前不能有私有的方法或者变量,
    jdk8可以有default方法体,和静态方法
    以implements被实现
  • 抽象类
    可以有私有方法或者成员变量
    被abstract修饰的方法没有方法体
    以extends被继承

接口常用于功能的增删
抽象类更倾向于公共类的角色

静态代码块—>非静态代码块—>构造方法

在这里插入图片描述

HashMap 和 Hashtable 的区别

  1. 线程是否安全: HashMap 是非线程安全的,HashTable 是线程安全的;HashTable 内部的方法基本都经过
    synchronized 修饰。(如果你要保证线程安全的话就使用 ConcurrentHashMap 吧!);
  2. 效率: 因为线程安全的问题,HashMap 要比 HashTable 效率高一点。另外,HashTable 基本被淘汰,不要在代
    码中使用它;
  3. 对 Null key 和 Null value 的支持: HashMap 中,null 可以作为键,这样的键只有一个,可以有一个或多个键所
    对应的值为 null。。但是在 HashTable 中 put 进的键值只要有一个 null,直接抛出 NullPointerException。
  4. 初始容量大小和每次扩充容量大小的不同 :
    ①创建时如果不指定容量初始值,Hashtable 默认的初始大小为 11,之后每次扩充,容量变为原来的 2n+1。HashMap
    默认的初始化大小为 16。之后每次扩充,容量变为原来的 2 倍。
    ②创建时如果给定了容量初始值,那么 Hashtable 会直接使用你给定的大小,而 HashMap 会将其扩充为 2 的幂
    次方大小(HashMap 中的 tableSizeFor() 方法保证,下面给出了源代码)。也就是说 HashMap 总是使用 2 的幂作
    为哈希表的大小,后面会介绍到为什么是 2 的幂次方。
  5. 底层数据结构: JDK1.8 以后的 HashMap 在解决哈希冲突时有了较大的变化,当链表长度大于阈值(默认为 8)
    时,将链表转化为红黑树,以减少搜索时间。Hashtable 没有这样的机制
©️2020 CSDN 皮肤主题: 数字20 设计师:CSDN官方博客 返回首页