Java 指定线程执行顺序(三种方式)

博主地址:http://blog.csdn.net/difffate

*方法二 *方法三

     方法一:通过共享对象锁加上可见变量来实现。

  1. public class MyService {  
  2.   
  3.     private volatile int orderNum = 1;  
  4.   
  5.     public synchronized void methodA() {  
  6.         try {  
  7.             while (orderNum != 1) {  
  8.                 wait();  
  9.             }  
  10.             for (int i = 0; i < 2; i++) {  
  11.                 System.out.println(”AAAAA”);  
  12.             }  
  13.             orderNum = 2;  
  14.             notifyAll();  
  15.         } catch (InterruptedException e) {  
  16.             e.printStackTrace();  
  17.         }  
  18.     }  
  19.   
  20.     public synchronized void methodB() {  
  21.         try {  
  22.             while (orderNum != 2) {  
  23.                 wait();  
  24.             }  
  25.             for (int i = 0; i < 2; i++) {  
  26.                 System.out.println(”BBBBB”);  
  27.             }  
  28.             orderNum = 3;  
  29.             notifyAll();  
  30.         } catch (InterruptedException e) {  
  31.             e.printStackTrace();  
  32.         }  
  33.     }  
  34.   
  35.     public synchronized void methodC() {  
  36.         try {  
  37.             while (orderNum != 3) {  
  38.                 wait();  
  39.             }  
  40.             for (int i = 0; i < 2; i++) {  
  41.                 System.out.println(”CCCCC”);  
  42.             }  
  43.             orderNum = 1;  
  44.             notifyAll();  
  45.         } catch (InterruptedException e) {  
  46.             e.printStackTrace();  
  47.         }  
  48.     }  
  49. }  

  1. import service.MyService;  
  2. public class ThreadAA extends Thread {  
  3.   
  4.     private MyService dbtools;  
  5.   
  6.     public ThreadAA(MyService dbtools) {  
  7.         super();  
  8.         this.dbtools = dbtools;  
  9.     }  
  10.   
  11.     @Override  
  12.     public void run() {  
  13.         dbtools.methodA();  
  14.     }  
  15.   
  16. }  

  1. import service.MyService;  
  2. public class ThreadBB extends Thread {  
  3.   
  4.     private MyService dbtools;  
  5.   
  6.     public ThreadBB(MyService dbtools) {  
  7.         super();  
  8.         this.dbtools = dbtools;  
  9.     }  
  10.   
  11.     @Override  
  12.     public void run() {  
  13.         dbtools.methodB();  
  14.     }  
  15.   
  16. }  

  1. import service.MyService;  
  2. public class ThreadCC extends Thread {  
  3.   
  4.     private MyService dbtools;  
  5.   
  6.     public ThreadCC(MyService dbtools) {  
  7.         this.dbtools = dbtools;  
  8.     }  
  9.   
  10.     @Override  
  11.     public void run() {  
  12.         dbtools.methodC();  
  13.     }  
  14.   
  15. }  

  1. import extthread.ThreadCC;  
  2. import service.MyService;  
  3. import extthread.ThreadAA;  
  4. import extthread.ThreadBB;  
  5.   
  6. public class Run {  
  7.   
  8.     public static void main(String[] args) {  
  9.         MyService myService = new MyService();  
  10.         for (int i = 0; i < 2; i++) {  
  11.             ThreadBB output = new ThreadBB(myService);  
  12.             output.start();  
  13.             ThreadAA input = new ThreadAA(myService);  
  14.             input.start();  
  15.             ThreadCC threadCC = new ThreadCC(myService);  
  16.             threadCC.start();  
  17.         }  
  18.     }  
  19.   
  20. }  

执行结果:

可以看到线程的启动按顺序执行了。共享对象锁,可以保证每个方法只能同时有一个线程进入,配合wait和notifyall方法,可以启动或者唤醒线程。


     方法二:通过主线程Join()

  1. class T11 extends Thread {  
  2.     public void run() {  
  3.         System.out.println(”in T1”);  
  4.     }  
  5. }  
  6.   
  7. class T22 extends Thread {  
  8.     public void run() {  
  9.         System.out.println(”in T2”);  
  10.     }  
  11. }  
  12.   
  13. class T33 extends Thread {  
  14.     public void run() {  
  15.         System.out.println(”in T3”);  
  16.     }  
  17. }  
  18.   
  19. public class Test2 {  
  20.     public static void main(String[] args) throws InterruptedException {  
  21.         T11 t1 = new T11();  
  22.         T22 t2 = new T22();  
  23.         T33 t3 = new T33();  
  24.         t1.start();  
  25.         t1.join();  
  26.         t2.start();  
  27.         t2.join();  
  28.         t3.start();  
  29.     }  
  30. }  

   方法三:通过线程执行时Join()

  1. class T1 extends Thread {  
  2.     public void run(){  
  3.         Random random = new Random();  
  4.         try {  
  5.             Thread.sleep(random.nextInt(1000));  
  6.         } catch (InterruptedException e) {  
  7.             e.printStackTrace();  
  8.         }  
  9.         System.out.println(”in T1”);  
  10.     }  
  11. }  
  12.   
  13. class T2 extends Thread{  
  14.     private Thread thread;  
  15.     public T2(Thread thread) {  
  16.         this.thread = thread;  
  17.     }  
  18.   
  19.     public void run(){  
  20.         try {  
  21.             thread.join();  
  22.         } catch (InterruptedException e) {  
  23.             e.printStackTrace();  
  24.         }  
  25.         System.out.println(”in T2”);  
  26.     }  
  27. }  
  28.   
  29. class T3 extends Thread{  
  30.     private Thread thread;  
  31.     public T3(Thread thread) {  
  32.         this.thread = thread;  
  33.     }  
  34.   
  35.     public void run(){  
  36.         try {  
  37.             thread.join();  
  38.         } catch (InterruptedException e) {  
  39.             e.printStackTrace();  
  40.         }  
  41.         System.out.println(”in T3”);  
  42.     }  
  43. }  
  44.   
  45. public class Test {  
  46.     public static void main(String[] args) throws InterruptedException {  
  47.         T1 t1 = new T1();  
  48.         T2 t2 = new T2(t1);  
  49.         T3 t3 = new T3(t2);  
  50.         t2.start();  
  51.         t1.start();  
  52.         t3.start();  
  53.     }  
  54. }  



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用Java中的多线程技术来执行SQL语句。 可以使用Java中的JDBC API来执行SQL语句,并且通过创建多个线程并行执行SQL语句来提高执行效率。 不过,请注意在多线程环境中使用JDBC时需要特别注意线程安全性问题。因为JDBC API并不是线程安全的,因此需要通过特殊的方式来解决这个问题。 推荐使用数据库连接池,在每个线程中使用单独的数据库连接来执行SQL语句。这样可以保证线程安全并且提高执行效率。 ### 回答2: Java中可以使用多线程执行SQL语句的方式有几种。 一种是通过多线程调用JDBC(Java Database Connectivity)来执行SQL语句。JDBC是Java提供的用于与数据库进行连接和操作的API,可以通过多线程创建多个数据库连接,并使用不同的线程执行SQL语句。这种方式需要考虑线程安全的问题,可以通过使用锁或者连接池等机制来解决。 另一种方式是通过使用线程池来执行SQL语句。Java中提供了线程池的机制,可以通过创建线程池来管理多个线程的执行,将SQL语句封装成任务提交给线程池,线程池会自动分配线程执行任务。这种方式可以有效地利用线程资源,提高程序的执行效率。 还可以使用并发控制工具来执行SQL语句,如使用CountDownLatch或CyclicBarrier等工具控制多个线程同时执行SQL语句,或者使用Semaphore来控制并发执行的线程数量。这种方式可以根据需要灵活地控制并发执行的线程数量,以及线程执行顺序。 无论使用哪种方式,都需要注意线程安全的问题,避免多个线程同时访问和修改数据库的数据导致数据不一致的问题。可以使用事务或者加锁等机制来确保数据的一致性。此外,还需要考虑数据库的连接数限制和性能问题,根据实际情况合理配置连接池和线程池的大小,以及优化SQL语句的执行效率。 ### 回答3: 在Java中,可以使用多线程执行SQL语句以提高数据库操作的效率。实现多线程执行SQL语句可以通过以下步骤: 1. 创建数据库连接池:使用数据库连接池可以复用连接,减少连接数据库的开销。常见的数据库连接池有HikariCP、Druid等,可以根据需求选择合适的连接池。 2. 创建线程池:使用线程池可以管理线程的创建和销毁,提高线程的复用性。可以通过Java提供的Executors类创建线程池,指定线程数量等参数。 3. 创建Runnable任务:将要执行的SQL语句封装为Runnable任务,每个任务负责执行一条SQL语句。可以使用JDBC连接数据库,并使用Connection对象执行SQL语句,处理查询结果等。 4. 提交任务给线程池:将创建的Runnable任务提交给线程池执行。线程池会自动从线程池中获取一个线程来执行任务。 5. 获取执行结果:可以通过Future对象来获取每个任务的执行结果。在提交任务时,会返回一个Future对象,可以通过该对象的方法获取任务的执行状态和结果。 6. 关闭线程池和数据库连接池:在多线程执行SQL语句完成后,需要及时关闭线程池和数据库连接池,释放资源。 需要注意的是,在多线程执行SQL语句时,需要考虑线程安全和事务管理。可以通过加锁、使用事务等技术来保证数据的一致性和线程的安全性。 总而言之,通过使用数据库连接池和线程池,以及合适的多线程编程技术,可以在Java中实现多线程执行SQL语句,提高数据库操作的效率和性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值