Java基础整理--equals、垃圾回收、内部类、泛型等

1.“==”与equals方法的区别

“==”代表比较双方是否相同。如果是基本类型则表示值相等,如果是引用类型则表示地址相等即是同一个对象。equals方法是Object类中定义的方法,提供定义“对象内容相等”的逻辑,默认判断地址是否相等,即判断是否为同一个对象。
在这里插入图片描述
String类中的equals方法重写了Object类中的方法
在这里插入图片描述

2.静态初始化块

静态初始化块执行顺序:上溯到Object类,即ChildClass->FatherClass->Object,先执行Object的静态初始化块,再向下执行子类的静态初始化块,直到我们的类的静态初始化块为止。构造方法的执行顺序和上面的顺序一致,也是一个上溯的过程。

3.抽象方法,抽象类和接口

(1)包含抽象方法的类(除了main方法)必须声明为abstract抽象类,其中可以有非抽象的方法;
(2)抽象类只能用来继承,不能实例化,抽象方法必须被子类实现;
(3)接口是抽象类的抽象,所有的方法都是抽象方法;
(4)接口的访问修饰符只能是public或默认;
(5)接口能够多继承,类只能单继承;
(6)接口中的属性只能是常量,总是public static final修饰的,不写也是;
(7)接口中的方法只能是public abstract,省略的话也是public abstract。

4.垃圾回收算法

  1. 引用计数法。堆中每个对象都有一个引用计数。被引用一次计数加1,被弓|用变量值变为null,则计数减1 ,直到计数为0 ,则表示变成无用对象。优点是算法简单,缺点是“循环引用的无用对象”无法被识别。
    在这里插入图片描述
    上图s1和s2互相引用对方,导致他们引用计数不为0,但是实际已经无用,但无法被识别。
  2. 可达性算法(根搜索算法)
    程序把所有的引用关系看做一张图,从一个节点GC ROOT开始,寻找对应的引用节点,找到这个节点以后,继续寻找这个节点的引用节点,当所有的引用节点寻找完毕之后,剩余的节点则被认为是没有被引用到的节点,即无用的节点。
    在这里插入图片描述
  3. 分代垃圾回收机制
    在 JDK 7 版本及JDK 7 版本之前,堆内存被通常被分为下面三部分:新生代,老年代和永生代,JDK1.8之后,永生代被彻底移除了,取而代之的是元空间。大部分情况,对象都会首先在 Eden 区域分配,在一次新生代垃圾回收后,如果对象还存活,则会进入 s0 或者 s1,并且对象的年龄还会加 1(Eden 区->Survivor 区后对象的初始年龄变为 1),当它的年龄增加到一定程度(默认为 15 岁),就会被晋升到老年代中。对象晋升到老年代的年龄阈值,可以通过参数 -XX:MaxTenuringThreshold 来设置。
  4. 垃圾回收过程
    在这里插入图片描述
    大部分情况,对象都会首先在 Eden 区域分配,在一次新生代垃圾回收后,如果对象还存活,则会进入 s0 或者 s1,并且对象的年龄还会加 1(Eden 区->Survivor 区后对象的初始年龄变为 1),当它的年龄增加到一定程度(默认为 15 岁),就会被晋升到老年代中。对象晋升到老年代的年龄阈值,可以通过参数 -XX:MaxTenuringThreshold 来设置。
    经过这次GC后,Eden区和"From"区已经被清空。这个时候,“From"和"To"会交换他们的角色,也就是新的"To"就是上次GC前的“From”,新的"From"就是上次GC前的"To”。不管怎样,都会保证名为To的Survivor区域是空的。Minor GC会一直重复这样的过程,直到“To”区被填满,"To"区被填满之后,会将所有对象移动到老年代中。

5.内部类

在Java中内部类主要分为成员内部类(静态内部类、非静态内部类)、匿名内部类、局部内部类。成员内部类(可以使用private,default, protected,public任意进行修饰。
(1)非静态内部类,通过外部类对象创建内部类对象
在这里插入图片描述
i.非静态内部类必须寄存在一个外部类对象里。因此,如果有一个非静态内部类对象那么一定存在
对应的外部类对象。非静态内部类对象单独属于外部类的某个对象。
ii.非静态内部类可以直接访问外部类的成员。但是外部类不能直接访问非静态内部类成员。
iii. 非静态内部类不能有静态方法、静态属性和静态初始化块。
iv.外部类的静态方法、静态代码块不能访问非静态内部类,包括不能使用非静态内部类定义变
量、创建实例。

(2)静态内部类
1.当一个静态内部类对象存在,并不一定存在对应的外部类对象。因此,静态内部类的实例方法
不能直接访问外部类的实例方法。
2.静态内部类看做外部类的一个静态成员。因此,外部类的方法中可以通过:“静态内部类名
字”的方式访问静态内部类的静态成员,通过new静态内部类0访问静态内部类的实例。

静态内部类的访问

class Outer{
	//相当于外部类的一个静态成员
	static class Inner{
	}
}
public class TestStaticInnerClass{
	public static void main(String[] args){
		//通过new外部类名,内部类名()来创建内部类对象
		Outer.Inner inner = new Outer.Inner();
	}
}

(3)匿名内部类
将匿名内部类写成参数的形式传递给函数使用在这里插入图片描述
(4)局部内部类
局部内部类是定义在方法内部的,作用域只限于本方法。局部内部类和成员内部类一样被编译,只是它的作用域发生了改变,它只能在该方法中被使用,出了该方法就会失效。

public class Test2{
	public void show(){
		class Inner{
			public void fun(){
				System.out.println("helloworld");
			}
		}
		new Inner().fun();
		}
		public static void main(String[] args){
			new Test2().show();
		}

6.枚举类型

enum Season {
	SPRING, SUMMER, AUTUMN, WINTER
}

所有的枚举类型隐性地继承自java.lang.Enum。枚举实质上还是类!而每个被枚举的成员实质就是一个枚举类型的实例,他们默认都是public static final修饰的。可以直接通过枚举类型名使用它们。

7.泛型

泛型是JDK1.5之后增加的,它可以帮助我们建立类型安全的集合。泛型的本质是“数据类型的参数化”。我们可以把“泛型”理解为数据类型的一个占位符(形式参数),即告诉编译器,在调用泛型时必须传入实际类型。

泛型示例:
在这里插入图片描述

8.迭代器

(1)List使用迭代器
在这里插入图片描述
(2)Map使用迭代器
在这里插入图片描述
(3)遍历List、Set、Map方法汇总

在这里插入图片描述
在这里插入图片描述

9.Collections工具类

类java.util.Collections提供了对Set、List、 Map进行排序、 填充、查找元素的辅助方法。

  1. void sort(List) //对List容器内的元素排序,排序的规则是按照升序进行排序。
  2. void shuffle(List) //对List容器内的元素进行随机排列。
  3. void reverse(List) //对List容器内的元素进行逆续排列。
  4. void fll(List, Object) //用一个特定的对象重写整个List容器。
  5. int binarySearch(List, Object)/对于顺序的List容器,采用折半查找的方法查找特定对象。
  • 30
    点赞
  • 182
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 覆盖和equals是面向对象编程中的两个重要概念。 覆盖指的是子类重写父类的方法,使得子类可以根据自己的需求来实现该方法。在覆盖时需要注意方法名、参数列表和返回值类必须与父类方法一致,否则会编译错误。覆盖可以提高代码的复用性和可维护性。 equals是Object类中的一个方法,用于比较两个对象是否相等。默认情况下,equals方法比较的是两个对象的引用是否相等,即是否指向同一个内存地址。如果需要比较两个对象的内容是否相等,就需要在类中重写equals方法,并根据类的属性来比较对象的内容。在重写equals方法时,需要满足自反性、对称性、传递性和一致性等条件,否则可能会导致程序出错。 总之,覆盖和equals都是面向对象编程中非常重要的概念,掌握它们可以提高代码的质量和效率。 ### 回答2: 覆盖与equals是Java中面向对象编程的两个基础概念,它们的正确应用非常重要。 覆盖(Override)是指子类重写(覆盖)父类的方法。在Java中,子类可以重写其父类的方法,子类的方法名、参数类和返回值类必须与父类方法一致。通过覆盖,我们可以实现灵活的代码复用和更高效的代码运行。 在实际开发中,我们需要注意覆盖的一些规则:首先,被覆盖的方法必须有相同的方法名、参数列表和返回值类;其次,覆盖的方法修饰符不能比被覆盖的方法更严格;最后,被覆盖的方法不能是final类的。 equals是Java中的一个方法,它用于比较两个对象是否相等。在默认情况下,equals方法比较的是两个对象的引用地址,但是我们可以重写equals方法,来使其比较对象的内容是否相等。 当我们需要比较自定义的对象时,必须重写equals方法,因为默认的equals方法不能满足我们的需求。在自定义equals方法时,需要遵循几个规则:首先,比较对象时需要保证其一致性、反射性、对称性和传递性;其次,equals方法必须是自反的,并且不能与其他对象类(如String类)相等;最后,equals方法必须与hashCode方法一致。 总之,覆盖和equals方法是Java中面向对象编程的非常基础的概念,我们需要在实际开发中灵活应用,以实现更高效、更灵活和更安全的代码编写。 ### 回答3: 覆盖是指子类可以覆盖父类中的某些方法,使得子类在调用这些方法时,执行的是自己的实现而不是父类的实现。而equals()方法是用来比较两个对象是否相等的方法,它是Object类中的一个方法,在子类中也可以重写。 在覆盖中,子类通过重写父类中的某些方法,可以添加或修改方法中的行为。在Java中,子类中必须要实现父类中的抽象方法,否则子类就必须声明为抽象类。同时,子类通过super关键字可以调用父类中被覆盖的方法,从而实现在子类中添加新的行为。 在equals()方法中,如果不重写,则会默认调用Object类中的equals()方法,这种比较方式只比较两个对象的引用是否相等,而不是对象的值是否相等。因此,在比较两个对象的值时,需要在子类中重写equals()方法,并根据实际需求来实现比较两个对象的值是否相等。 在重写equals()方法时,需要遵循以下几点原则: 1. 自反性:对于任何非 null 的对象 x,x.equals(x) 必须返回 true。 2. 对称性:对于任何非 null 的对象 x 和 y,如果 x.equals(y) 返回 true,则 y.equals(x) 必须返回 true。 3. 传递性:对于任何非 null 的对象 x、y 和 z,如果 x.equals(y) 返回 true,y.equals(z) 返回 true,则 x.equals(z) 必须返回 true。 4. 一致性:对于任何非 null 的对象 x 和 y,只要对象的状态没有发生改变,则 x.equals(y) 多次调用时必须返回相同的结果。 5. 非空性:对于任何非 null 的对象 x,x.equals(null) 必须返回 false。 综上所述,覆盖和equals()方法都是非常重要的Java基础概念,对于Java程序员来说,熟练掌握这两个概念可以帮助我们更好地进行Java开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值