并发编程相关概念

一、并发编程相关概念

1、高并发系统设计的目标

1、高性能:性能体现了系统的并行处理能力,在有限的硬件投入下,提高性能意味着节省成本。同时,性能也反映了用户体验,响应时间分别是100毫秒和1秒,给用户的感受是完全不同的。
2、高可用:表示系统可以正常服务的时间。一个全年不停机、无故障;另一个隔三差五出线上事故、宕机,用户肯定选择前者。另外,如果系统只能做到90%可用,也会大大拖累业务。
3、高扩展:表示系统的扩展能力,流量高峰时能否在短时间内完成扩容,更平稳地承接峰值流量,比如双11活动、明星离婚等热点事件。

2、并发、并行与串行的区别

1)并发:同一时间段内,多个任务进行。单核环境上同一时间内只有一个任务进行,只能把CPU运行时间划分成若干个时间段,再将时间段分配给各个任务。
2)并行:同一时间点,多个任务同时进行。
3)串行:串行是指多个任务时,各个任务按顺序执行,完成一个之后才能进行下一个。
4)同步:就是顺序执行,执行完一个再执行下一个,需要等待、协调运行。
5)异步:就是彼此独立,在等待某事件的过程中继续做自己的事,不需要等待这一事件完成后再工作。

你可能感兴趣的:(高并发编程,c++)