使用阻塞队列实现线程同步_线程可以并行执行吗

使用阻塞队列实现线程同步_线程可以并行执行吗一、串行,并行,并发1.名称解释串行:程序按顺序执行,同一时间只能执行一个程序,前一个执行完毕后才轮到后一个并行:多个程序可以同时执行,宏观和微观上看程序都是同时执行并发:同一时刻只有一条程序

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一、串行,并行,并发

1.名称解释

  • 串行:程序按顺序执行,同一时间只能执行一个程序,前一个执行完毕后才轮到后一个

  • 并行:多个程序可以同时执行,宏观和微观上看程序都是同时执行

  • 并发:同一时刻只有一条程序执行,但是多个进程被快速轮换执行,宏观上看是同时执行,微观上看只是把时间分成若干段,使多个进程快速交替的执行

并发与并行关注的是程序是否在同一时间内同时被执行

使用阻塞队列实现线程同步_线程可以并行执行吗

2.举个例子

  • 串行:你吃饭吃到一半,电话来了,你一直到吃完了以后才去接
  • 并发:你吃饭吃到一半,电话来了,你接了电话聊了两句,停下来吃了两口饭,又拿起电话聊了两句
  • 并行:你吃饭吃到一半,电话来了,你一边打电话一边吃饭

另外:

当有多个线程在操作时,如果系统只有一个 CPU,则它根本不可能真正同时进行一个以上的线程,它只能把 CPU 运行时间划分成若干个时间段,再将时间段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状态.这种方式我们称之为并发(Concurrent)。

当系统有一个以上 CPU 时,则线程的操作有可能非并发。当一个 CPU 执行一个线程时,另一个 CPU 可以执行另一个线程,两个线程互不抢占 CPU 资源,可以同时进行,这种方式我们称之为并行(Parallel)。

二、进程与线程

1.名称解释

  • 进程:程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础
  • 线程:有时被称为轻量级进程,是程序执行流的最小单元。线程是进程中的一个实体,是被系统独立调度和分派的基本单位

进程之间资源不共享,而线程之间资源共享(故引入锁以处理资源分配问题)

2.举个例子

  • 进程:你开了一个迅雷,又开了一个QQ,这分别是两个进程
  • 线程:你在QQ分别和好友a还有好友b聊天,这是QQ这个进程里的两个线程

三、同步与异步

1.名称解释

  • 同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。

  • 异步,当一个异步过程调用发出后,调用者不能立刻得到结果。实际处理这个调用的部件在完成后,通过状态、通知和回调来通知调用者。

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

2.举个例子

  • 同步:你去书店买本书,老板说帮你找一下,然后开始找,等到找到了再告诉你结果为止(返回结果)
  • 异步:你去书店买本书,老板说帮你找一下找到再给你打电话(不返回结果),等他找到的就打电话给你(回调)

四、阻塞和非阻塞

1.名词解释

  • 阻塞:是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回
  • 非阻塞:调用指在不能立刻得到结果之前,该调用不会阻塞当前线程

阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态

2.举个例子

  • 阻塞:你去书店买书,立即买到了,或者没有立刻就走了,这就是非阻塞
  • 非阻塞:你去书店买书,如果恰好书店没有,你就等一直等到书店有了这本书买到了才走,然后后排的人必须等你走了以后才能买书
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170824.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月16日 下午8:46
下一篇 2022年8月16日 下午8:46


相关推荐

  • JavaScript作用域和作用域链详解

    JavaScript作用域和作用域链详解JavaScript 作用域链详解一 JavaScript 作用域 JavaScript 作用域是什么 作用域范围二 JavaScript 作用域链作用域与执行上下文总结一 JavaScript 作用域 JavaScript 作用域是什么 作用域是在运行时代码中的某些特定部分中变量 函数和对象的可访问性 换句话说 作用域决定了代码区块中变量和其他资源的可见性 作用域范围块语句 大括号 中间的语句 如 if 和 switch 条件语句或 for 和 while 循环语句 不像函数 它们不会创建一个新的作用域

    2026年3月26日
    2
  • 心脏出血(Heartbleed)漏洞浅析、复现

    心脏出血(Heartbleed)漏洞浅析、复现一、漏洞介绍心脏出血(英语:Heartbleed),也简称为心血漏洞,是一个出现在加密程序库OpenSSL的安全漏洞,该程序库广泛用于实现互联网的传输层安全(TLS)协议。它于2012年被引入了软件中,2014年4月首次向公众披露。只要使用的是存在缺陷的OpenSSL实例,无论是服务器还是客户端,都可能因此而受到攻击。此问题的原因是在实现TLS的心跳扩展时没有对输入进行适当验证(缺少边界检查),因此漏洞的名称来源于“心跳”(heartbeat)。该程序错误属于缓冲区过读,即可以读取的数据比应该允许读取的还

    2022年7月16日
    167
  • linux 命令chmod 755的意思[通俗易懂]

    linux 命令chmod 755的意思[通俗易懂]chmod是Linux下设置文件权限的命令,后面的数字表示不同用户或用户组的权限。 一般是三个数字:第一个数字表示文件所有者的权限第二个数字表示与文件所有者同属一个用户组的其他用户的权限第三个数字表示其它用户组的权限。      权限分为三种:读(r=4),写(w=2),执行(x=1)。综合起来还有可读可执行(rx=5=4+1)、可读可写(rw=6=4+2)、可读可写可执行(…

    2022年7月16日
    35
  • 无线网络技术:wimax的发展史

    无线网络技术:wimax的发展史1wimax 简介全球微波接入互操作性 WorldInterop WiMAX WiMAX 的另一个名字是 802 16 IEEE802 16 标准 又称 WiMAX 或广带无线接入 BroadbandWir BWA 标准 它是一项无线城域网 WMAN 技术 是针对微波和毫米波频段提出的一种新的空中接口标准 它用于将 802 11a 无线接入热点连接到互联网 也可连结公司与家庭等环境至有线骨干线路 它可作为线缆和 DSL 的无线扩展

    2026年3月17日
    1
  • python对随机森林分类结果绘制roc曲线

    python对随机森林分类结果绘制roc曲线上图:附上代码:一个函数,传入三个参数…..传入参数,训练模型,然后:fit=model.fit(x_train,y_training)#ROCy_score=model.fit(x_train,y_training).predict_proba(x_test)#随机森林fpr,tpr,thresholds=roc_curve(y_test,…

    2022年5月17日
    84
  • 字符串 压缩 java_简单的java字符串压缩(原创)

    字符串 压缩 java_简单的java字符串压缩(原创)复制内容到剪贴板代码 packageorg test 面试题目 现有一个字符串 其内容仅仅包含 a z 现在要进行网络传输 故需要减少网络传输的 大小 如何将字符串空间缩小 以下为我给出的答案 可能不对 欢迎探讨 求最优方式 publicclassC publicstatic acdesfghsada

    2026年3月18日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号