JAVA一个接口多个实现逐个调用

简介: JAVA一个接口多个实现逐个调用

经测试确认,当一个接口有多个实现时,调用时只会执行一个

有时候需要多个实现调用,方法示例如下:

public interface TransCallbackInterface {


public void callback(String taskId, int code, String fixed);

}
@Component
public class TransCallbackDy implements  InitializingBean,TransCallbackInterface{

@Override
public void callback(String taskId, int code, String fixed) {
    System.out.println("TransCallback");
}

@Override
public void afterPropertiesSet() throws Exception {
// TODO Auto-generated method stub
System.out.println("callback registerCallbackProcessor .");

FileTransferShedule.registerCallbackProcessor(this);

}

}
@Component
public class TransCallbackDy implements  InitializingBean, TransCallbackInterface{

@Override
public void callback(String taskId, int code, String fixedInfo) {
    System.out.println("TransCallback");
}

@Override
public void afterPropertiesSet() throws Exception {
// TODO Auto-generated method stub
System.out.println("callback registerCallbackProcessor .");

FileTransferShedule.registerCallbackProcessor(this);
}

}
调用方式:

@Component
public class FileTransferShedule implements InitializingBean, DisposableBean {

@Override

public void afterPropertiesSet() throws Exception {
    
}

@Override

public void destroy() throws Exception {
    logger.debug("service closed");

}


private static List<TransCallbackInterface> processors = new ArrayList<TransCallbackInterface>();

public static void registerCallbackProcessor(
        TransCallbackInterface processor) {
    synchronized (processors) {
        processors.add(processor);
    }
}

public static void unregisterCallbackProcessor(
        TransCallbackInterface processor) {
    synchronized (processors) {
        processors.remove(processor);
    }
}

public void callback(HttpServletRequest request) {


    logger.debug("回调接口测试");
    try {
        Throwable t = null;
        synchronized (processors) {
            for (TestCallbackInterface processor : processors) {
                try {
                    processor.callback();
                } catch (Throwable e) {
                    t = e;
                }
            }
        }
        if (t != null) {
            throw new IOException(t);
        }
        System.out.println("test");

    } catch (Exception e) {
        e.printStackTrace();
    }
}

}

相关文章
|
9天前
|
JSON Java Apache
非常实用的Http应用框架,杜绝Java Http 接口对接繁琐编程
UniHttp 是一个声明式的 HTTP 接口对接框架,帮助开发者快速对接第三方 HTTP 接口。通过 @HttpApi 注解定义接口,使用 @GetHttpInterface 和 @PostHttpInterface 等注解配置请求方法和参数。支持自定义代理逻辑、全局请求参数、错误处理和连接池配置,提高代码的内聚性和可读性。
|
10天前
|
Java
java线程接口
Thread的构造方法创建对象的时候传入了Runnable接口的对象 ,Runnable接口对象重写run方法相当于指定线程任务,创建线程的时候绑定了该线程对象要干的任务。 Runnable的对象称之为:线程任务对象 不是线程对象 必须要交给Thread线程对象。 通过Thread的构造方法, 就可以把任务对象Runnable,绑定到Thread对象中, 将来执行start方法,就会自动执行Runable实现类对象中的run里面的内容。
24 1
|
15天前
|
Java 开发者
在Java多线程编程的世界里,Lock接口正逐渐成为高手们的首选,取代了传统的synchronized关键字
在Java多线程编程的世界里,Lock接口正逐渐成为高手们的首选,取代了传统的synchronized关键字
41 4
|
21天前
|
安全 Java
在 Java 中使用实现 Runnable 接口的方式创建线程
【10月更文挑战第22天】通过以上内容的介绍,相信你已经对在 Java 中如何使用实现 Runnable 接口的方式创建线程有了更深入的了解。在实际应用中,需要根据具体的需求和场景,合理选择线程创建方式,并注意线程安全、同步、通信等相关问题,以确保程序的正确性和稳定性。
|
20天前
|
Java
Java基础(13)抽象类、接口
本文介绍了Java面向对象编程中的抽象类和接口两个核心概念。抽象类不能被实例化,通常用于定义子类的通用方法和属性;接口则是完全抽象的类,允许声明一组方法但不实现它们。文章通过代码示例详细解析了抽象类和接口的定义及实现,并讨论了它们的区别和使用场景。
|
20天前
|
Java 测试技术 API
Java零基础-接口详解
【10月更文挑战第19天】Java零基础教学篇,手把手实践教学!
18 1
|
25天前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
19 3
|
25天前
|
Java
在Java多线程编程中,实现Runnable接口通常优于继承Thread类
【10月更文挑战第20天】在Java多线程编程中,实现Runnable接口通常优于继承Thread类。原因包括:1) Java只支持单继承,实现接口不受此限制;2) Runnable接口便于代码复用和线程池管理;3) 分离任务与线程,提高灵活性。因此,实现Runnable接口是更佳选择。
33 2
|
25天前
|
Java
Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口
【10月更文挑战第20天】《JAVA多线程深度解析:线程的创建之路》介绍了Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口。文章详细讲解了每种方式的实现方法、优缺点及适用场景,帮助读者更好地理解和掌握多线程编程技术,为复杂任务的高效处理奠定基础。
28 2
|
25天前
|
Java 开发者
Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点
【10月更文挑战第20天】Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点,重点解析为何实现Runnable接口更具灵活性、资源共享及易于管理的优势。
28 1