同步,异步,阻塞,非阻塞,并发,并行

一直对于这些的理解都不深刻。

并发,并行:宏观概念, 并发,同时进行操作。并行,一个一个来。

同步,异步:微观概念,同步,一个一个来,调用者需要得到结果才继续执行。异步,同时进行操作 ,调用者无需结果继续执行。。

阻塞,非阻塞:同步--阻塞,异步--非阻塞。

效率: 同步--效率低,异步--效率高。

  1. 线程安全的类其方法是同步的,每次只能一个访问。是重量级对象,效率较低。   
  2. 对于非线程安全的类和接口,在多线程中需要程序员自己处理线程安全问题
 vector:就比arraylist多了个同步化机制(线程安全)。

  statck:堆栈类,先进后出。 

 hashtable:就比hashmap多了个线程安全。 

enumeration:枚举,相当于迭代器。

  除了这些之外,其他的都是非线程安全的类和接口。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
同步非阻塞异步非阻塞都是针对并发编程的不同策略,主要区别在于它们如何管理时间片以及在处理任务时的交互方式。 ### 同步非阻塞 (Synchronous Non-blocking) - **特点**: 系统能持续接收并处理新请求,即便是在处理较长耗时的操作期间也是如此。 - **工作流程**: 接收一个请求后,系统并不等待其完成,而是继续处理其他未完成的请求,并将当前请求放入等待队列中。当当前请求完成或超时时,系统会从等待队列中取出并继续处理。 - **优势**: 提高了并发性能和整体系统利用率。 - **劣势**: 开发和调试相对复杂,尤其是在多任务切换时需要更精细的控制。 ### 异步非阻塞 (Asynchronous Non-blocking) - **特点**: 更侧重于在处理I/O和其他耗时任务时不阻塞主线程或任何其他的任务流。 - **工作流程**: 当遇到I/O操作、数据库查询等需要等待的情况时,程序会立即返回给用户,而不是进入阻塞状态。这使得在等待结果的同时,系统能够处理更多的任务。 - **优势**: 显著提高并发处理能力,特别是面对大量轻量级任务时。 - **劣势**: 需要使用回调函数、事件循环或多路复用器等复杂的机制来组织和管理任务,增加了代码的复杂性和难度。 ### 主要区别总结 - **任务执行顺序与调度**: - **同步非阻塞**:保持任务按接收顺序执行,但在等待耗时操作时,可以并行处理其它任务。 - **异步非阻塞**:任务不受接收顺序限制,一旦遇到耗时操作即返回,直到结果准备好才再次运行。 - **核心目标**: - **同步非阻塞**:主要目标是提高整体系统性能和响应速度。 - **异步非阻塞**:着重于最大化I/O操作的效率,特别是在处理大量I/O密集型任务时。 - **实现方式**: - **同步非阻塞** 可以通过优化现有线程或进程的调度实现,例如通过多线程池、异步文件系统等技术。 - **异步非阻塞** 则更多依赖于事件驱动和回调机制,如通过异步IO、基于事件的网络服务器等技术。 ### 相关问题: 1. **异步编程与同步编程的主要区别是什么?** 2. **异步非阻塞编程在哪些场景下特别有效?** 3. **在选择同步非阻塞还是异步非阻塞时,应考虑哪些因素?** 以上介绍了这两种编程策略的核心差异及其应用场景,选择哪种取决于具体的业务需求、系统负载特性以及团队的技术栈和经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值