多线程的“并发”和“并行”区别

并发在单核和多核都可存在,就是同一时间有多个可以执行的进程
但是在单核中同一时刻只有一个进程获得CPU,虽然宏观上你认为多个进程都在进行。

并行是指同一时间多个进程在微观上都在真正的执行,这就只有在多核的情况下了。


多线程不是万能的.它是并发的,也就是说,它在创建和切换资源时还要额外消耗资源.
而线程1执行完后线程2才能执行,这样用多线程的效率是不如串行处理的.
多线程应用的领域一般是,
需要及时响应.比如你让一个线程处理大量数据.而在没处理完时可以用另一个线程来接收用户的指令.
 还有一个是当采用多线程编程可以让程序结构简化时也可以用.比如流水线式的程序.。
应用的最多的是C/S(不过其实很多S不是用多线程而是用多进程)

另外有多核时,多线程可以呈伪并行执行(多线程所实现的机制一般称并发)那就不是串行程序的效率能比的了.

另外还有分布式程序.不过那个就要复杂得多了.你水平上升后可以看看相关的书.

最后.推荐你看下<posix多线程编程>很经典.我以前是用它入门的.

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值