Java 线程同步异步学习

Java中实现多线程

1.继承Thread,重写里面的run方法

2.实现runnable接口

Java同步机制的实现方式

ThreadLocal,synchronized,wait,notify,volatile

ThreadLocal 保证不同线程拥有不同实例,相同线程一定拥有相同的实例,即为每一个使用该变量的线程提供一个该变量值得副本,每个线程都可以独立改变自己的副本,而不是与其他线程的副本冲突.。

   优势:提供了线程安全的共享对象与其它同步机制的区别:同步机制是为了同步多个线程对相同资源的并发访问,是为了多个线程之就进行通信;而ThreadLocal是隔离多个线程的数据共享,从根本上就不在多个线程之间共享资源

volatile 修饰的成员变量在每次被线程访问时,都强迫从共享内存中重读该成员变量的值。

synchronized 代码块中,或者常量时,不必使用

下面先线程同步的例子


线程B运行十次,线程A运行一次
public class ThreadRunA {

 public static void main(String[] args) {
  ThreadRunB b = new ThreadRunB();
  b.start();
  synchronized(b) {
   try {
    b.wait();
    for (int j = 0;j <10;j++ ) {
     b.notify();
     if (j != 9) {
      b.wait();
     }
    
    }
   } catch (InterruptedException e) {
    e.printStackTrace();
   }
   
   
  }
 }
}



public class ThreadRunB extends Thread {

 public void run() {
  synchronized (this) {
   for (int i = 0; i < 100; i++) {
    if (i != 0 && i % 10 == 0) {
     notify();
     try {
      wait();
     } catch (InterruptedException e) {
      e.printStackTrace();
     }
    }
   }
  }
 }
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java中的线程同步异步指的是线程间如何协作。 同步(Synchronization)是指线程之间的协调,确保每一个时刻只有一个线程执行某段代码。 异步(Asynchronization)是指线程之间不需要协调,多个线程可以同时执行某段代码。 简单来说,同步线程之间互相等待,异步线程之间互不干扰。 ### 回答2: Java线程同步异步是两种不同的多线程编程概念。 线程同步是指多个线程之间按照一定的顺序来共享数据和执行任务,以保证数据的一致性和正确性。在同步过程中,一个线程执行到某一点时,其他想要访问该点的线程必须等待,直到执行完毕才能继续执行。同步机制通过synchronized关键字、ReentrantLock等机制来实现,可以避免多个线程同时修改共享数据而导致的数据不一致问题。 而线程异步则是指多个线程之间独立运行,并不按照特定顺序来共享数据和执行任务。每个线程独立执行自己的任务,彼此之间无需等待。线程异步可以提高程序的并发性和性能,但同时也会增加编程复杂度和出错可能性。在异步处理中,通常使用线程池或者Future接口等机制来实现异步执行。 综上所述,线程同步异步的区别在于线程之间的执行顺序和数据访问方式。同步机制可以保证数据的一致性和正确性,但可能会造成性能问题;而异步机制可以提高并发性和性能,但可能会引发编程复杂度和出错可能性。根据具体的应用场景和需求,选择合适的线程同步异步方式来实现多线程编程。 ### 回答3: Java线程同步异步是两种不同的处理机制。 线程同步是指多个线程按照一定的顺序执行,其中一个线程完成了特定的任务后,其他线程才能继续执行。在Java中,可以通过关键字synchronized和Lock来实现线程同步。使用同步机制可以有效地避免多个线程对共享资源的竞争,保证数据的一致性和正确性。然而,线程同步也有一些缺点,比如可能会引起死锁和性能下降。 线程异步是指多个线程可以独立执行,彼此之间不需要等待。每个线程可以以不同的顺序和速度执行任务,因此具有更高的并发性。在Java中,可以使用线程池和CompletableFuture等机制来实现线程异步执行。异步编程可以提高程序的响应速度和吞吐量,并提高系统的并发性能。然而,异步编程在处理共享资源时需要额外的注意,因为多个线程可能会并发地访问和修改共享资源,可能引发数据的不一致和竞争条件。 综上所述,线程同步异步是不同的线程处理机制。线程同步保证了多个线程按照一定的顺序执行,避免了竞争条件和数据的不一致;而线程异步则可以独立执行,提高了并发性能,但需要额外注意共享资源的并发访问和修改。在实际开发中,需要根据具体的需求和场景来选择合适的处理机制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值