JAVA SPI规范

最近看dubbo的源代码,发现很多对不同的容器,序列化方式提供了不同的实现,实现的机制是通过

JAVA SPI 来实现的,就是基于接口的服务发现,一个接口不同的实现底层,而当外部程序装配这个模块的时候,就能通过该jar包META-INF/services/里的配置文件找到具体的实现类名,并装载实例化,完成模块的注入

package com.ljq.code;

public interface JavaSPI {

	String fromWho();
}

 

实现:

package com.ljq.code;

public class American implements JavaSPI {

	public String fromWho() {
		return "FROM American";
	}

}

 

实现2:

package com.ljq.code;

public class China implements JavaSPI {

	@Override
	public String fromWho() {
		return "from china";
	}

}

 

在META-INF/services/下建立一个名称为com.ljq.code.JavaSPI 文件,接口的全限定名称

输入 类的实现全限定名

com.ljq.code.China

 

客户端调用:

package com.ljq.code;

import java.util.Iterator;
import java.util.ServiceLoader;

public class ClientSPI {

	public static void main(String[] args) {
		ServiceLoader s = ServiceLoader.load(JavaSPI.class);
		Iterator it = s.iterator();
		while (it.hasNext()) {
			System.out.println("------HELLO------");
			JavaSPI spi = it.next();
			System.out.println(spi.fromWho());
		}

	}
}

 

 

你可能感兴趣的:(分布式,java)