Java学习路线-29:反射机制与应用案例

简介: Java学习路线-29:反射机制与应用案例

第21 章 : 认识反射机制

99 反射机制简介

Java的精髓所在

动态获取信息以及动态调用对象方法的功能


所有技术实现的目标只有一点:重用性


正:类 -> 实例对象

反:实例对象 -> 类


找到对象的根源


Object.getClass()

100 Class类对象的三种实例化模式

public final class Class<T> implements java.io.Serializable,
                              GenericDeclaration,
                              Type,
                              AnnotatedElement

要实例化的类


class Person{}

1、Object类支持

Object类可以根据实例化对象获取Class对象


缺点:

如果想获得类对象,则必须产生指定类对象后才能获得


Person person = new Person();
Class cls = person.getClass();
System.out.println(cls.getName());
// Person

2、JVM直接支持

采用类.class 直接实例化

如果要采用这种模式,则必须导入程序所对应开发包

Class cls = Person.class;
System.out.println(cls.getName());
// Person

3、Class类支持

Class类中提供了static方法


public static Class<?> forName(String className)

特点:

直接使用字符串形式定义要使用的类型,

程序不需要编写import,不存在则抛出异常


Class cls = Class.forName("Person");
System.out.println(cls.getName());
// Person

第22 章 : 反射应用案例

101 反射实例化对象

获取Class对象意义:

Class对象提供有一个对象的反射实例化方法


1、JDK<1.9


public T newInstance()
// 等价于关键字new, 只能调用无参构造 JDK>=1.9之后弃用

示例


Class cls = Class.forName("Person");
System.out.println(cls.newInstance());
// Person@2503dbd3

2、JDK>=1.9


public Constructor<T> getDeclaredConstructor(Class<?>... parameterTypes)

示例


Class cls = Class.forName("Person");
System.out.println(cls.getDeclaredConstructor().newInstance());
// Person@2503dbd3

任何情况下如果要实例化对象则一定要调用类中的构造方法


102 反射与工厂设计模式

工厂设计模式:

通过工厂类获取指定接口实例化对象


接口的主要作用是为不同的层提供有一个操作的标准

如果直接将一个子类设置为接口实例化操作,那么一定会有耦合

工厂设计模式解决子类与客户端的耦合问题


1、静态工厂设计模式

如果子类增加,工厂类一定要做出修改

解决一个子类实例化


IMessage
    -NetMessage
    -CloudMessage
Factory // 通过传入的参数获取子类
Client
interface IMessage {
    public void send(String message);
}
class Message implements IMessage {
    @Override
    public void send(String message) {
        System.out.println("发送: " + message);
    }
}
class Factory {
    private Factory() {
    }
    public static IMessage getInstance(String className) {
        if ("Message".equalsIgnoreCase(className)) {
            return new Message();
        }
        return null;
    }
}
public class Demo {
    public static void main(String[] args) {
        IMessage message = Factory.getInstance("message");
        message.send("nihao");
    }
}

2、利用反射实现工厂设计模式

解决一个接口多个子类实例化


修改工厂类代码


class Factory {
    private Factory() {
    }
    public static IMessage getInstance(String className) {
        IMessage message = null;
        try {
            message = (IMessage)Class.forName(className).getDeclaredConstructor().newInstance();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return message;
    }
}

3、泛型反射实现工厂设计模式

解决所有接口子类实例化


class Factory {
    private Factory() {
    }
    public static <T> T getInstance(String className, Class<T> clazz) {
        T instance = null;
        try {
            instance = (T)Class.forName(className).getDeclaredConstructor().newInstance();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return instance;
    }
}
public class Demo {
    public static void main(String[] args) {
        IMessage message = Factory.getInstance("Message", IMessage.class);
        message.send("nihao");
    }
}

103 反射与单例设计模式

单例设计模式:

类的构造函数私有化,通过static方法获取实例化对象

-懒汉式

-饿汉式


class Singleton{
    private static Singleton instance = null;
    private Singleton() {
    }
    public static Singleton getInstance(){
        if(instance == null){
            instance = new Singleton();
        }
        return instance;
    }
    public void print(){
        System.out.println("Singleton");
    }
}
class Demo{
    public static void main(String[] args) {
        Singleton instance = Singleton.getInstance();
        instance.print();
    }
}

多线程下执行,产生多个实例化对象


class Singleton{
    private static Singleton instance = null;
    private Singleton() {
        System.out.println("Singleton " + Thread.currentThread().getName());
    }
    public static Singleton getInstance(){
        if(instance == null){
            instance = new Singleton();
        }
        return instance;
    }
    public void print(){
        System.out.println("Singleton print");
    }
}
class Demo{
    public static void main(String[] args) {
        for (int i = 0; i < 3; i++) {
            new Thread(()->{
                Singleton instance = Singleton.getInstance();
                instance.print();
            }, "instance" + i).start();
        }
        /**
         * 输出结果
         * Singleton instance0
         * Singleton instance1
         * Singleton print
         * Singleton instance2
         * Singleton print
         * Singleton print
         */
    }
}

修改为同步处理


class Singleton{
    // volatile 不使用副本
    private static volatile Singleton instance = null;
    private Singleton() {
        System.out.println("Singleton " + Thread.currentThread().getName());
    }
    // synchronized不在函数上加,而是在内部代码块加,提高执行效率
    public static Singleton getInstance(){
        if(instance == null){
            synchronized (Singleton.class){
                if(instance == null) {
                    instance = new Singleton();
                }
            }
        }
        return instance;
    }
    public void print(){
        System.out.println("Singleton print");
    }
}
class Demo{
    public static void main(String[] args) {
        for (int i = 0; i < 3; i++) {
            new Thread(()->{
                Singleton instance = Singleton.getInstance();
                instance.print();
            }, "instance" + i).start();
        }
        /**
         * 输出结果
         * Singleton instance1
         * Singleton print
         * Singleton print
         * Singleton print
         */
    }
}

面试题:单例设计模式

1、实现饿汉式单例设计模式,构造函数私有化

2、Java中用到单例设计模式的类:

Runtime, Pattern, Spring框架

3、懒汉式单例设计模式的问题

相关文章
|
4月前
|
人工智能 算法 Java
Java与AI驱动区块链:构建智能合约与去中心化AI应用
区块链技术和人工智能的融合正在开创去中心化智能应用的新纪元。本文深入探讨如何使用Java构建AI驱动的区块链应用,涵盖智能合约开发、去中心化AI模型训练与推理、数据隐私保护以及通证经济激励等核心主题。我们将完整展示从区块链基础集成、智能合约编写、AI模型上链到去中心化应用(DApp)开发的全流程,为构建下一代可信、透明的智能去中心化系统提供完整技术方案。
373 3
|
4月前
|
消息中间件 缓存 Java
Spring框架优化:提高Java应用的性能与适应性
以上方法均旨在综合考虑Java Spring 应该程序设计原则, 数据库交互, 编码实践和系统架构布局等多角度因素, 旨在达到高效稳定运转目标同时也易于未来扩展.
290 8
|
5月前
|
IDE Java 关系型数据库
Java 初学者学习路线(含代码示例)
本教程为Java初学者设计,涵盖基础语法、面向对象、集合、异常处理、文件操作、多线程、JDBC、Servlet及MyBatis等内容,每阶段配核心代码示例,强调动手实践,助你循序渐进掌握Java编程。
705 3
|
5月前
|
人工智能 Java API
Java与大模型集成实战:构建智能Java应用的新范式
随着大型语言模型(LLM)的API化,将其强大的自然语言处理能力集成到现有Java应用中已成为提升应用智能水平的关键路径。本文旨在为Java开发者提供一份实用的集成指南。我们将深入探讨如何使用Spring Boot 3框架,通过HTTP客户端与OpenAI GPT(或兼容API)进行高效、安全的交互。内容涵盖项目依赖配置、异步非阻塞的API调用、请求与响应的结构化处理、异常管理以及一些面向生产环境的最佳实践,并附带完整的代码示例,助您快速将AI能力融入Java生态。
868 12
|
5月前
|
SQL Java 数据库
2025 年 Java 从零基础小白到编程高手的详细学习路线攻略
2025年Java学习路线涵盖基础语法、面向对象、数据库、JavaWeb、Spring全家桶、分布式、云原生与高并发技术,结合实战项目与源码分析,助力零基础学员系统掌握Java开发技能,从入门到精通,全面提升竞争力,顺利进阶编程高手。
1021 1
|
5月前
|
SQL 算法 Java
零基础到精通的史上最强 Java 学习路线图推荐
史上最全Java学习路线图,涵盖基础语法、面向对象、数据结构与算法、多线程、JVM、Spring框架、数据库及项目实战,助你从零基础到精通Java开发,附完整代码与工具推荐。
352 3
零基础到精通的史上最强 Java 学习路线图推荐
|
5月前
|
SQL 算法 Java
适合自学的史上最强 Java 学习路线图分享
本路线图系统讲解Java从入门到进阶的学习路径,涵盖基础语法、面向对象编程、数据结构与算法、多线程、JVM原理、主流框架如Spring、数据库操作及项目实战,助你全面掌握Java开发技能,适合零基础及进阶学习。
1108 0
|
5月前
|
Java API 数据库
2025 年最新 Java 实操学习路线,从入门到高级应用详细指南
2025年Java最新实操学习路线,涵盖从环境搭建到微服务、容器化部署的全流程实战内容,助你掌握Java 21核心特性、Spring Boot 3.2开发、云原生与微服务架构,提升企业级项目开发能力,适合从入门到高级应用的学习需求。
1799 0
|
5月前
|
安全 Java API
Java SE 与 Java EE 区别解析及应用场景对比
在Java编程世界中,Java SE(Java Standard Edition)和Java EE(Java Enterprise Edition)是两个重要的平台版本,它们各自有着独特的定位和应用场景。理解它们之间的差异,对于开发者选择合适的技术栈进行项目开发至关重要。
844 1
|
5月前
|
NoSQL Java 关系型数据库
超全 Java 学习路线,帮你系统掌握编程的超详细 Java 学习路线
本文为超全Java学习路线,涵盖基础语法、面向对象编程、数据结构与算法、多线程、JVM原理、主流框架(如Spring Boot)、数据库(MySQL、Redis)及项目实战等内容,助力从零基础到企业级开发高手的进阶之路。
432 1