JAVA学习笔记DAY3——菜鸟教程面向对象+数据结构部分

文章目录

部分示例代码来自 菜鸟教程

Java 继承

子类继承父类的特征和行为。

java 复制代码
class 父类{
}
class 子类 extends 父类{
}

继承的特性

  1. 范围:子类拥有父类非private的属性、方法。
  2. 子类可以用自己的方式实现父类的方法。
  3. Java不支持多继承,但支持多重继承。
  4. 提高了类之间的耦合性。(算是缺点)

继承关键字

extends/implements

  • extends 继承类,只能单继承
  • implements 继承接口interface,可以多继承 implements A,B
  • super 访问当前对象父类成员 super.
  • this 指向自己的引用 this.
  • final 最终的,声明类则为最终类不能被继承,修饰方法则不能被子类重写。

构造器

子类不继承父类的构造器,只调用(可隐式)。

若父类构造器带参数,则必须显式调用,通过super(A,B)传参。

重写(Override)与重载(Overload)

重写和重载是Java多态性的不同表现。重写是父类和子类之间多态性的表现。重载是一个类的多态性表现。

重写 Override

子类中定义了一个与父类中方法名称相同、参数列表相同、返回类型一般相同的方法,子类方法的实现覆盖了父类方法的实现。

重写规则

  1. 返回类型在java7后可以不同,但必须是父类返回值的派生类。
  2. 子类访问权限只高不低。
  3. 子类父类是否在同一个包中,会影响能够重写方法的范畴。
  4. static的方法不能被重写,但能够被再次声明。
  5. 构造方法不能被重写。
  6. 重写方法不能抛出更宽泛的强制性异常,非强制性异常则可以随意抛出。

重载 Overload

在同一个类中,方法名字相同,参数列表不同(参数的数量、类型、顺序)。返回类型随意。
不同类中也可以存在重载,子类可以重载父类的方法。

Java 多态

同一个行为具有多个不同表现形式或形态的能力。

同一个接口使用不同的实例执行不同操作。

虚函数

虚函数的存在是为了多态。

Java里的普通函数就相当与C++的虚函数。

final才是非虚函数。

多态的实现方式

  1. 重写
  2. 接口
  3. 抽象类和抽象方法

Java抽象类

abstract 关键字声明

不能实例化对象的类,必须被继承才能被使用。

抽象方法

只声明,没有定义,方法名后直接分号。

  • 有抽象方法的类必定是抽象类

Java 封装

用private修饰属性,用getter和setter提供访问接口。

Java接口

Intereface是抽象方法的集合。

接口特性

  • 接口中的方法是隐式抽象的,public abstract
  • 接口中的变量则隐式为,public static final
  • 接口中的方法不能在接口中实现。

抽象类和接口的区别

  1. 一个类可以继承多个接口,但只能继承一个抽象类。
  2. 抽象类的成员变量可以是各种类型的。
  3. 抽象类可以有静态方法。(JDK1.8之后接口也可以)
  4. 抽象类可以有方法体。(JDK1.8之后接口也可以)

接口的继承

  • extends 接口继承接口,允许多继承
  • implements 类继承接口,允许多继承

标记接口

没有包含任何方法的接口。

只是为了给类做标记。

两种目的:

  1. 建立一个公共的父接口
  2. 向一个类添加数据类型

Java 枚举(enum)

一个特殊的类,其中的枚举值都是public static final的。

java 复制代码
enum Color 
{ 
    RED, GREEN, BLUE; 
} 
  
public class Test 
{ 
    // 执行输出结果
    public static void main(String[] args) 
    { 
        Color c1 = Color.RED; 
        System.out.println(c1); 
    } 
}
//RED

values()返回全部值

oedinal()返回索引

valueOf()返回指定字符串值的枚举常量

java 复制代码
enum Color 
{ 
    RED, GREEN, BLUE; 
} 
  
public class Test 
{ 
    public static void main(String[] args) 
    { 
        // 调用 values() 
        Color[] arr = Color.values(); 
  
        // 迭代枚举
        for (Color col : arr) 
        { 
            // 查看索引
            System.out.println(col + " at index " + col.ordinal()); 
        } 
  
        // 使用 valueOf() 返回枚举常量,不存在的会报错 IllegalArgumentException 
        System.out.println(Color.valueOf("RED")); 
        // System.out.println(Color.valueOf("WHITE")); 
    } 
}

枚举类成员

可以有自己的变量、方法和构造函数。

构造函数会在调用时实现n次(n为枚举常量个数)

Java包(package)

类似于文件夹,用于区别类的命名空间。

把相互联系的【类、接口、枚举、注释】组织在同一个包中。

---------------------------------------------以上为面向对象部分---------------------------------------------------

数据结构

数组(Arrays)

插入和删除元素相对慢。

java 复制代码
int[ ] array = new int[5];

列表(Lists)

  • Arraylist
    动态数组,快速尾部插入
java 复制代码
List<String> arrayList = new ArrayList<>();
  • LinkedList
    双向链表
java 复制代码
List<Integer> linkedList = new LinkedList<>();

集合(Sets)

用于存储不重复的元素

  • HashSet
    无序集合,基于HashMap实现。
java 复制代码
Set<String> hashSet = new HashSet<>();
  • TreeSet
    基于红黑树实现,不允许重复元素。自动排序。

映射(Maps)

用于存储键值对

  • HashMap
    哈希表 无序
  • TreeMap
    红黑树 有序

栈 (Stack)

LIFO后进先出

java 复制代码
Stack<Integer> stack = new Stack<>();

队列(Queue)

FIFO先进先出

  • LinkedList
  • PriorityQueue

堆(Heap)

优先队列的基础,可实现最大堆和最小堆。

树(Trees)

TreeNode类型

图(Graphs)

Java没有内建的图类

其他

枚举Enumeration

位集合BitSet

向量Vector

动态数组

字典Dictionary

一个抽象类,键值对

哈希表HashTable

属性Properties

Java集合框架

没看进去,暂时跳过

Java ArrayList

Java LinkedList

链表

  • 单向链表
  • 双向链表

Java HashSet

  • 基于HashMap,不允许有重复元素
  • 允许有null
  • 无序
  • 不是线程安全的
  • 实现了Set接口

方法

  • add
  • contains
  • remove
  • clear
  • size

Java HashMap

散列表,键值对映射

实现了Map接口。

方法

  • put(key,value)
  • get(key)
相关推荐
web安全工具库2 分钟前
从课堂笔记到实践:深入理解Linux C函数库的奥秘
java·数据库·算法
ss2734 分钟前
手写MyBatis第104弹:SqlSession从工厂构建到执行器选择的深度剖析
java·开发语言·后端·mybatis
小张的博客之旅16 分钟前
2025年“羊城杯”网络安全大赛 线上初赛 (WriteUp)
python·学习·网络安全
周杰伦_Jay38 分钟前
【Java集合体系】全面解析:架构、原理与实战选型
java·开发语言·数据结构·链表·架构
Camel卡蒙40 分钟前
DDD架构——实体、聚合、值对象
java·开发语言·架构
青云交1 小时前
Java 大视界 -- 基于 Java 的大数据实时流处理在智能电网分布式电源接入与电力系统稳定性维护中的应用
java·分布式电源·智能电网·java 大数据·flink 实时流处理·kafka 数据采集·iec 61850 协议
失散131 小时前
分布式专题——41 RocketMQ集群高级特性
java·分布式·架构·rocketmq
失散131 小时前
分布式专题——42 MQ常见问题梳理
java·分布式·架构
~无忧花开~1 小时前
JavaScript学习笔记(二十八):JavaScript性能优化全攻略
开发语言·前端·javascript·笔记·学习·性能优化·js
机器学习之心1 小时前
PINN物理信息神经网络风电功率预测!引入物理先验知识嵌入学习的风电功率预测新范式!Matlab实现
神经网络·学习·matlab·风电功率预测·物理信息神经网络