分享一个非常好用的Worker池——缓冲区和侦听模板(Java、提供源代码下载)

本人开发了一个通用的worker池,功能有二

1、如果你想异步的处理某件事,请将它封装成一个动作对象、丢给worker池就可以了

2、如果你想写一个侦听做某一件事,你只需要告诉worker池:侦听名称、轮询周期、线程数、以及该做什么(将它封装成一个动作对象即可),worker池会为你办好这件事。

worker池的优点是能充分的利用系统资源,集中管理线程,不需要每一个侦听都配置几个线程。将不变的逻辑封装起来,将可变部分(如:具体动作、周期、线程数等)作为参数传入。使用起来非常方便。

你使用的是多线程在处理事务,但你压根就不用和线程直接打交道。

 

啥也不说了,直接上代码,看怎么用的

package unit;

import com.linkage.bss.crm.asynlaunch.ALSwitch;
import com.linkage.bss.crm.asynlaunch.AsynItem;
import com.linkage.bss.crm.asynlaunch.AsynLaunch;
import com.linkage.bss.crm.monitor.BTask;
import com.linkage.bss.crm.monitor.ListenerMonitors;
import com.linkage.bss.crm.monitor.BTask.BExecutor;

public class TestMain {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//1.化同步为异步
		//A.同步方式
		saySomething("Hello World!");
		//B.修改为异步方式
		AsynItem item = new AsynItem() {
			public boolean launch() {
				saySomething("Hello World 2 !");
				return true;
			}
		};
		AsynLaunch.asynLaunch(item);
		//C.同步方式
		saySomething("Hello World 3 !");
		//此处输出结果:
		/*
		Hello World!
		Hello World 3 !
		Hello World 2 !
		*/
		
		//2.侦听功能
		//需求:每隔1000ms、5个线程同时 saySomething("Hello-" + 数字)
		BTask task = BTask.generate("saySomething Listener",1000,5,new BExecutor() {
			int[] arr = {1,2,3,4,5};
			public boolean execute() {
				int i = (int)(System.currentTimeMillis()%5);
				saySomething("Hello - " + arr[i]);
				return false;
			}
		});
		ListenerMonitors.put(task);
		
		Sleep(10000);
		//关闭缓冲池
		ALSwitch.stop();
	}

	private static void saySomething(String greek) {
		System.out.println(greek);
	}

	private static void Sleep(long ts){
		try {
			Thread.sleep(ts);
		} catch (Exception e) {
		}
	}
}


有问题请留言

源 码 下 载

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 很容易,只需要在Spring Boot项目中使用@EnableAutoConfiguration注解,然后使用@EnableWebMvc注解来激活Web MVC配置,最后使用@ServletComponentScan注解扫描子服务的Servlet,然后就可以通过指定的端口监听该服务了。 ### 回答2: 在Spring Boot中实现一个子服务监听一个端口的步骤如下: 1. 首先,创建一个Spring Boot项目,并添加相关的依赖,包括`spring-boot-starter-web`和`spring-boot-starter-tomcat`。 2. 在`application.properties`或`application.yml`配置文件中,设置该子服务的端口号。例如,使用`server.port=8081`来设置端口号为8081。 3. 创建一个新的Controller类,用于处理该子服务的请求。例如,创建一个名为`SubServiceController`的类,并添加相关的请求处理方法。 ```java @RestController @RequestMapping("/sub-service") public class SubServiceController { @GetMapping("/example") public String handleRequest() { return "This is a response from the sub-service!"; } } ``` 4. 运行Spring Boot应用程序,并访问`http://localhost:8081/sub-service/example`,应该能够看到返回的响应信息。 以上就是实现一个子服务侦听一个端口的简单步骤。可以根据需求进一步扩展该子服务,添加更多的请求处理方法和业务逻辑。 ### 回答3: 在Spring Boot中实现一个子服务侦听一个端口可以通过以下步骤完成: 1. 创建一个新的Spring Boot项目,并将其作为父项目。 2. 在父项目中创建一个模块作为子服务,可以通过Maven或Gradle进行管理。 3. 在子服务模块的pom.xml或build.gradle文件中添加Spring Boot的依赖。 4. 创建一个新的Spring Boot应用程序类作为子服务的入口点。 5. 在子服务应用程序类中使用`@SpringBootApplication`注解标记该类作为Spring Boot应用程序的入口。 6. 在子服务应用程序类中定义一个`@RestController`类或者`@Controller`类用于处理HTTP请求。 7. 在定义的控制器类中添加相应的请求处理方法,并使用`@RequestMapping`或其他相关注解进行映射。 8. 在子服务应用程序类中声明并初始化一个`EmbeddedServletContainerCustomizer` Bean对象,并实现接口中的`customize`方法。 9. 在`customize`方法中通过调用`container.setPort`方法设置子服务的监听端口。 10. 启动父项目,并访问子服务的URL加上设置的端口号即可访问该子服务。 以上是一个实现简单子服务侦听一个端口的步骤,根据具体需求,你还可以根据需要添加相关的配置和功能。希望可以对你有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值