Java同步和异步,阻塞和非阻塞

Java同步和异步,阻塞和非阻塞

同步和异步、阻塞和非阻塞

同步和异步关注的是消息通信机制.

同步是指: 发送方发出数据后, 等待接收方发回响应后才发下一个数据包的通讯方式. 就是在发出一个调用时, 在没有得到结果之前, 该调用就不返回, 但是一旦调用返回, 就得到返回值了. 也就是由"调用者"主动等待这个"调用"的结果.

异步是指: 发送方发出数据后, 不等待接收方发回响应, 接着发送下个数据包的通讯方式. 当一个异步过程调用发出后, 调用者不会立刻得到结果. 而是在调用发出后, "被调用者"通过状态、通知来通知调用者, 或通过回调函数处理这个调用.

阻塞和非阻塞属于进程API执行动作的方式, 关注的是程序在等待调用结果时的状态.

阻塞是指: 调用结果返回之前, 当前线程会被挂起. 函数只有在得到结果之后才会返回, 线程需要等待结果.

非阻塞是指: 与阻塞的概念相对应, 指在不能立刻得到结果之前, 该函数不会阻塞当前线程, 而会立刻返回. 线程不需要等待结果.

Java中的同步和异步

定义: 任务A, 任务B

同步: 任务A和任务B之间有关联, 例如任务B中途要给任务A一个数字, 那么任务A或许需要等待任务B生产这个数, 任务A需要等待任务B的这个动作叫做同步.

异步: 事件A和事件B之间没有关联, 是相互独立的, 那么相互都不用管对方干了什么.

定义: 线程A和线程B, 分别在执行任务A和任务B

阻塞: 线程A需要等待线程B, 于是线程A在等待这个数的步骤上被挂起, 不能分到cpu, 不能执行, 这样被称为阻塞.

非阻塞: 线程同样需要线程B给一个数, 但是线程A仅仅告知线程B要给这个数, 并没有马上就要使用这个数, 此时线程A没有被挂起, 仍然能分到cpu, 仍然能执行, 这样被称为非阻塞.

下面给出Java代码的例子.

同步阻塞:

int i = System.in.read();
当命令终端没有输入时, 调用该方法的线程被阻塞 ,表现出和终端同步.

异步非阻塞:

Future future = threadPool.submit(Callable callable);
// doSomething
future.get();
callable内的任务结果没有马上需要的必要, 于是调用submit()方法马上返回一个实现Future的存根. callable任务对于当前线程是异步的, 不需要阻塞当前线程.

但是到左后县城需要callable任务的结果时, 就需要同步了, get()方法通过阻塞来实现.

同步非阻塞:

concurrentLinkedQueue.offer((T) t);
该过程一个元素需要入队列, 该并发队列为了让当前线程不阻塞而又能正确入队, 使用CAS算法实现的乐观锁循环尝试入队. offer()方法并没有阻塞当前线程, 而又希望同步, 于是通过循环来实现, 最终实现同步非阻塞.

异步阻塞:

没有例子. 阻塞就是用来实现同步的,这和同步阻塞有什么区别, 那实现它还有什么用呢?

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java同步异步阻塞非阻塞是常用的并发和网络编程概念。 同步异步涉及到代码的执行方式。同步指的是任务按照顺序执行,一个任务完成后才能执行下一个任务;而异步是指任务可以并发执行,不需要等待前一个任务完成。 阻塞非阻塞涉及到线程的等待状态。阻塞是指一个线程在执行某个操作时,如果这个操作没有完成,那么线程就会一直等待,不能执行其他操作;而非阻塞是指一个线程在执行某个操作时,执行该操作不会等待,可以立即执行其他操作。 在Java同步通常是通过synchronized关键字来实现的。同步可以确保多个线程按照指定的顺序访问共享资源,避免出现竞态条件。异步则可以通过线程池、Future、CompletableFuture等机制实现,可以提高程序的并发处理能力。 阻塞是指线程在执行某个操作时,如果该操作没有完成,线程会进入等待状态,不能执行其他操作。在Java阻塞通常发生在I/O操作上,如读写文件、网络通信等。非阻塞则是指线程执行某个操作时不会等待,而是立即返回结果,可以继续执行其他操作。在Java非阻塞通常与NIO相关,使用Selector和Channel来实现非阻塞的网络通信。 综上所述,同步异步阻塞非阻塞是并发编程重要的概念,它们分别从代码执行方式和线程等待状态的角度来描述程序的行为。在Java同步异步通常通过synchronized关键字和线程池等机制来实现,而阻塞非阻塞通常与I/O操作和NIO相关。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值