多线程下的并发理解

写多了多线程程序,对程序的串行与并行和操作系统的并发概念会有点混乱,现在整理一下概念。

并发:

  •   并发原本是处在操作系统层次上,讲的是处理器的逻辑核可以在同一个时间段处理多个任务
  •   在多个任务上采用比如:时间片轮转法,多级反馈优先队列,高响应比等的算法来协调对每个任务的处理时间。
  •   这里的任务是指运行在操作系统范围内的进程或者线程。对于执行实体在干什么并不关心。事实上,执行实体干的活就是程序的逻辑。

并行与串行:

  •   这两个概念应用在编程范围内比较恰当,当然也非常适用于硬件指令流水线。
  •   与并发最大的区别在于立足点不同,并发站在操作系统上看是不同进程实体代表的指令流的来回调度切换。
  •   并行站在程序逻辑上看是多个程序不相干指令流的走向或者逻辑结构,这一层并不考虑指令调度问题。更严谨的说是不考虑和其他程序的指令调度问题。
  •   并行指开启多个线程,执行多个不同的函数或任务,重点在执行的函数和任务上,对于线程运行在哪不关心,视不同情况可能会访问到共同的数据集,此处需要做互斥。
  •   串行在此指程序或任务的执行指令在任何一个时间点上只被一处执行且从程序执行开始到结束,当前活动空间内不存在其他并行的指令流,当然也就不存在数据竞争问题。

当前说法比较粗糙,再思考思考不断完善

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏JAVA高级架构

JAVA架构师面试题,如何成为架构师

经常面试一些候选人,整理了下我面试使用的题目,陆陆续续整理出来的题目很多,所以每次会抽一部分来问。答案会在后面的文章中逐渐发布出来。 基础题目 Java线程的...

60711

Apache CloudStack系统VM架构选择

最近我和一些人讨论了为什么现在有一个32位或64位系统虚拟机和CloudStack 4.3 (一个云计算平台)的选项。我提供了一个答案,并且回复了一些邮件列表...

1717
来自专栏Golang语言社区

Golang语言社区--游戏服务器端开发的一些建议(转载)

大家好,我是Golang语言社区(www.golang.ltd)主编彬哥,本篇给大家转载一篇关于游戏服务器开发的文章。

4347
来自专栏鸿的学习笔记

简单聊聊分布式系统的一致性问题

记得有人说过,分布式系统的所有问题归根结底都是一致性问题。前面文章提到的数据复制,分区以及事务面临的问题都是如何保证数据一致。而分布式系统不同于单机,它不...

591
来自专栏韩伟的专栏

经典游戏服务器端架构概述 (1)

现代电子游戏,基本上都会使用一定的网络功能。从验证正版,到多人交互等等,都需要架设一些专用的服务器,以及编写在服务器上的程序。因此,游戏服务器端软件的架构,本质...

4K1
来自专栏杨建荣的学习笔记

数据库无响应问题的紧急处理和分析 (r10笔记第42天)

黄金周里处理了一起紧急的问题,在外面幸亏有同事帮忙协助,等我赶回家去,赶紧继续处理。 首先问题是在晚饭时间左右开始发生,但是过了没多久又恢复了,所以这个问题暂时...

31412
来自专栏人工智能

使用Apache Spark的微服务的实时性能分析和分析

作为一种架构风格,微服务因其极高的灵活性,越来越受欢迎。应用程序在功能上分解为一组松散耦合的协作服务,通过定义良好的(REST)API进行交互。通过采用这些设计...

1965
来自专栏Vamei实验室

协议森林08 不放弃 (TCP协议与流通信)

TCP(Transportation Control Protocol)协议与IP协议是一同产生的。事实上,两者最初是一个协议,后来才被分拆成网络层的IP和传输...

1915
来自专栏Vamei实验室

协议森林11 涅槃 (TCP重新发送)

TCP协议是一个可靠的协议。它通过重新发送(retransmission)来实现TCP片段传输的可靠性。简单的说,TCP会不断重复发送TCP片段,直到片段被正确...

1716
来自专栏即时通讯技术

脑残式网络编程入门(二):我们在读写Socket时,究竟在读写什么?

本文接上篇《脑残式网络编程入门(一):跟着动画来学TCP三次握手和四次挥手》,继续脑残式的网络编程知识学习 ^_^。

662

扫描关注云+社区