下面是代码,不解释!
public class SequenceNumber {
// ①通过匿名内部类覆盖ThreadLocal的initialValue()方法,指定初始值
private static ThreadLocal<Integer> seqNum = new ThreadLocal<Integer>() {
public Integer initialValue() {
return 0;
}
};
// ②获取下一个序列值
public int getNextNum() {
seqNum.set(seqNum.get() + 1);
return seqNum.get();
}
public static void main(String[] args) {
SequenceNumber sn = new SequenceNumber();
// ③ 3个线程共享sn,各自产生序列号
TestClient t1 = new TestClient(sn);
TestClient t2 = new TestClient(sn);
TestClient t3 = new TestClient(sn);
t1.start();
t2.start();
t3.start();
}
private static class TestClient extends Thread {
private SequenceNumber sn;
public TestClient(SequenceNumber sn) {
this.sn = sn;
}
public void run() {
for (int i = 0; i < 3; i++) {// ④每个线程打出3个序列值
System.out.println("thread[" + Thread.currentThread().getName()
+ "] sn[" + sn.getNextNum() + "]");
}
}
}
}
运行的结果:
thread[Thread-2] sn[1]
thread[Thread-2] sn[2]
thread[Thread-2] sn[3]
thread[Thread-1] sn[1]
thread[Thread-1] sn[2]
thread[Thread-1] sn[3]
thread[Thread-0] sn[1]
thread[Thread-0] sn[2]
thread[Thread-0] sn[3]
分享到:
相关推荐
**线程局部变量(ThreadLocal)** 在Java编程中,`ThreadLocal`是一个非常重要的工具类,它用于在多线程环境中提供线程安全的局部变量。`ThreadLocal`并不是一个线程,而是一个线程局部变量的容器,每个线程都有自己...
Quartz 是一个开源的作业调度框架,用于在 Java 应用程序中安排任务。它提供了丰富的 API 和灵活性,使得开发者可以方便地...记得实践是检验真理的唯一标准,动手操作这些 demo,会让你对这些知识点有更深入的理解。
- `ThreadLocal`:为每个线程创建独立的变量副本,避免数据共享导致的并发问题。 通过上述知识点,"线程的各种使用方式Demo"可能涵盖了线程的创建、管理、同步、通信等多个方面,有助于开发者深入理解线程的使用,...
自定义多数据源类MultiplyDataSource(继承HikariDataSource),通过多线程类ThreadLocal控制当前需要使用的数据源id,实现多数据源动态切换查询功能(默认数据源和其他数据源都统一使用这一个,简化了配置)。...
8. **并发编程**:如果需要处理多个设备或多个并发请求,Java的并发库(如ExecutorService、Future、ThreadLocal等)将派上用场,确保系统的高效运行。 9. **安全性和性能优化**:考虑数据传输的安全性,可能需要...
在业务代码执行前,设置ThreadLocal变量,指示使用哪个数据源。 3. **MyBatis Plus集成** - 添加MyBatis Plus的依赖,并配置对应的Mapper扫描路径和实体类扫描路径。 - 针对每个数据源,创建一个`...
定义一个`ThreadLocal`变量来保存当前操作的数据源,然后在需要切换数据源的方法上添加自定义的注解,如`@DS("primary")`或`@DS("secondary")`。 - ** DataSource Router**:实现`AbstractRoutingDataSource`,这个...
创建一个ThreadLocal变量存储当前数据源,根据业务逻辑决定使用哪个数据源。 7. 编写Repository和Mapper:对于Mybatis-Plus,编写对应的Mapper接口和实体类,对于MongoDB,创建Repository接口继承MongoRepository,...
ThreadLocal<MessageConsumer> threadLocal = new ThreadLocal(); AtomicInteger count = new AtomicInteger(); public void init(){ try { connectionFactory = new ActiveMQConnectionFactory(USERNAME...
使用`ThreadLocal<T>`类,可以在每个线程中维护独立的数据副本,避免了线程间数据冲突。 9. **异常处理** 当线程中抛出未捕获的异常时,线程会终止。在多线程环境下,应确保每个线程都有适当的异常处理机制。 ...
使用`ThreadLocal<T>`类可以为每个线程创建独立的存储空间,即使多个线程访问相同的变量,也不会互相影响。 10. **死锁与活锁** 多线程编程中,线程可能因为资源竞争陷入死锁(无法继续执行),或因过于保守而...
在Spring中,`ThreadLocal`可以用来存储线程相关的数据,如事务、用户信息等。`RequestContextHolder`和`CurrentContext`可以帮助我们在多线程环境下保持请求和上下文信息。 9. **监控与调优** 使用`...
3. **线程局部变量**:`ThreadLocal`类可以为每个线程创建一个独立的变量副本,避免了线程间的数据共享,从而简化了线程安全问题。 4. **线程池**:`ExecutorService`和`ThreadPoolExecutor`等类提供了线程池管理,...
创建一个自定义的`ThreadLocal`变量来保存当前线程所使用的数据源信息。 - 创建一个切面,拦截特定的注解,如`@DS`(代表Data Source),根据注解的值来切换数据源。 3. **MyBatisPlus的多数据源整合**: - ...
`Demo_ThreadLocal.java`中展示了如何创建ThreadLocal变量,每个线程都可以独立设置和获取值。 ```java ThreadLocal<String> threadLocal = new ThreadLocal(); // 在每个线程中,可以使用threadLocal.set(value)和...
本文将详细介绍如何在MyBatis中实现多数据源配置,并通过提供的"mybatis-demo(多数据源配置).rar"压缩包文件进行示例说明。 首先,我们需要理解什么是多数据源配置。多数据源配置是指在一个应用中,可以同时连接...
这通常通过AOP(面向切面编程)和ThreadLocal实现。我们可以创建一个`DynamicDataSource`类,它继承自`AbstractRoutingDataSource`,并重写`determineCurrentLookupKey`方法。在这个方法里,我们可以根据业务逻辑...
16、Thread【实现方式、异步调用、join、synchronized、wait、notifyAll,死锁、同步互斥、通信、ThreadLocal、消费者与生产者模式】 17、POI 18、JVM简单实例【Heap溢出、Stack溢出】 19、Redis的简单实例 20、java...
并发和多线程是Java的一个重要特性,JavaDemo项目提供了相关实践,让你了解如何安全地在多个线程之间共享数据,使用synchronized关键字、Lock接口、ThreadLocal变量,以及并发集合如ConcurrentHashMap和...
private static final ThreadLocal<String> contextHolder = new ThreadLocal(); public static void setDataSource(String dataSource) { contextHolder.set(dataSource); } public static String get...