单线程与多线程使用场景

article/2025/10/2 17:41:38

多线程使用时机

出现CPU资源浪费(CPU空转)的时候才适用多线程,每个核心在同一时刻只能处理一个线程,而逻辑处理器则是通过CPU的并发来模拟出的核心

单线程与多线程使用情况

适用单线程的情况

CPU全力执行,没有产生算力浪费的情况下适用单线程,多线程需要额外花费算力执行其他工作

多线程消耗

每个线程在执行时只执行极短的时间,然后去执行其他线程,每次切换之前要记录本次执行的数据,会额外耗费资源和时间,所以会有消耗时间,而每个线程之间切换的速度越快,消耗的时间就越多,下图中切换执行3个线程的消耗时间是1+2+3 =6s,执行总时间是6+60=66s

在这里插入图片描述

单线程没有消耗

而如果不切换顺序执行的话由于不需要消耗时间只需要耗费60s的时间,在这种情况下单线程比多线程更有优势
在这里插入图片描述

适用多线程的情况

面试点:java请求数据库

当需要调用数据库时,java进程通过jdbc发送http请求到端口(通常是3306)传递SQL语句字符串到mysql进程

mysql进程一直监听着3306端口,当接收到http请求时解析出SQL语句,通过SQL语句的执行消耗一部分内存把存储在磁盘中想要操作的表文件(一个表就是一个文件)加载到mysql中

mysql进程通过解析java的SQL语句进行处理,得出java想要查询的数据后通过3306端口返回到java进程中

数据库原理:数据库是用c实现的,Navicat是c实现的可视化,上述过程换成c的话就是数据库的实现原理

消耗点

当mysql进程调用磁盘中存储的表文件时,由于磁盘读取速度限制,会消耗大量的时间在上面(通常单个表文件是几十ms),在等待读取的这段时间,CPU在打空转造成了资源浪费,所以如果是单线程调度时每次都要等待,这时使用多线程就可以在CPU等待磁盘调度时去执行其他线程

所有等待时间远大于执行时间的场景都可以使用多线程

如下列执行时间只要2ms,等待时间却要50ms,这时就可以使用多线程让等待的时间里也能处理其他的线程

image-20220617112229523

多线程执行图

当我们创建10个线程后不需要手动去切换线程,只需要全部点击start,CPU会自己进行切换

多线程使用场景

网络爬虫,数据库进行批量操作时

多线程分配

如果用10个线程分配10000个抓取任务,如果给每个线程分配1000个是不科学的,因为线程执行速度有快有慢

所以实际执行时是将10000个抓取任务放在一个队列中,10个线程谁执行完了就来领下一个

所以在代码设计时,就要new10个线程和一个队列,而线程池就简化了这一流程,只需要将线程数量和队列当做参数输入就可以创建


http://chatgpt.dhexx.cn/article/oiOwM85l.shtml

相关文章

多线程与并发 - 进程和线程的区别

进程和线程的由来: 进程是资源分配的最小单位,线程是CPU调度的最小单位 所有与进程相关的资源,都被记录在PCB中进程是抢占处理机的调度单位;线程属于某个进程,共享其资源线程只由堆栈寄存器、程序计数器和线程控制表&…

多线程并发和并行的区别

背景 对于java开发从业人员来说,并发编程是绕不开的话题,juc并发包下提供了一系列多线程场景解决方案。  随着jdk1.8的普及,多线程处理问题,除了使用使用线程池(ExecutorService),很多人选择了parallelStream() 并行流…

多线程与单线程理解

多线程与单线程理解 进程与线程的关系 进程是计算机程序执行一次过程的接班单位,即正在执行的程序(QQ),一个应用程序可以包含多个进程(QQ的不同页面信息) 线程是进程的基本单元,一个进程至少包…

线程和进程的区别与联系以及单线程多进程与单进程多线程的区别

线程和进程 概念 进程(process):是指具有已一定功能的独立程序,是系统资源分配的基本单位,在内存中有其完备的数据空间和代码空间,拥有完整的虚拟空间地址。一个进程所拥有的数据和变量只属于它自己。 线…

单线程与多线程的区别?

什么是进程? 当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源。 而一个进程又是由多个线程所组成的。 什么是线程? 线程是程序中的一个执行流,每个线程都有自己的专有寄存器…

单线程与多线程

目录 多线程的创建 方式一:继承Thread类 方式二:实现Runnablel接口 方式三:JDK5.0新增Callable接口 Thread的常用方法 线程安全 线程同步 线程通信 线程池【重点】 定时器 补充知识:并发、并行 生命周期 什么是线程&…

什么是单线程和多线程,单线程与多线程的区别

什么是进程? 当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源。 而一个进程又是由多个线程所组成的。 什么是线程? 线程是程序中的一个执行流,每个线程都有自己的专有寄存器…

理解单线程和多线程的区别

单线程和多线程 首先我们都知道线程是隶属于进程的,单线程就是程序中只有一个线程,多线程就是程序中有多个线程.通过连个例子理解多线程和单线程. (一)单线程 创建包:package com.ffyc.javathread; 创建类:public class Sample { } package com.ffyc.javathread; public c…

ubuntu卸载已安装软件

1.查看已安装软件列表 dpkg -l dpkg -l | grep baidu # 软件包查询筛选# 另外,软件安装也使用dpkg命令 sudo dpkg -i xxxx.deb2.卸载指定软件包 sudo apt-get purge baidunetdisk # 卸载指定软件 sudo apt-get autoremove # 清理不需要的文件 sudo apt-get autoc…

Ubuntu20.04 卸载软件

Ubuntu20.04卸载软件相当的简单, 一 用命令行卸载 sudo apt-get remove --purge 软件名 这样不仅可以卸载掉软件,而且可以清理配置 二 在图形界面卸载软件 首先打开设置 打开应用程序 在其中找到你要卸载的软件 然后点击右上角的 在软件中打开 然后…

Linux bash卸载软件,Ubuntu卸载软件的4种方法

前言 本文重点介绍Ubuntu卸载软件的4种方法。他们分别是图形化界面的synaptic、自动解决依赖关系的apt-get,处理依赖关系更强大的aptitude,还有安装本地deb包的dpkg。 方法一: Ubuntu使用synaptic图形化界面管理软件 oucanrong@zcwyou:~$ sudo apt-get install synaptic -y 以…

Ubuntu卸载软件方式

1、终端输入: dpkg --list 显示出电脑上所有的软件包 左边就是软件名字,中间是版本名 2、在终端上输入命令sudo apt --purge remove 包名 例如我要卸载smartgit 即可

Ubuntu卸载软件

1、利用"软件中心"卸载 在Ubuntu收藏栏中打开软件中心,在已安装的软件中找到要卸载的软件,点击“移除”按钮即可。 提示:需要输入用户密码。 2、在终端中卸载 2.1、找到软件 有些软件在“软件中心”中是找不到的。还是需要用终端…

Ubuntu卸载软件相关命令

查看安装的软件 dpkg -l 查看软件版本 dpkg -l | grep xxx # xxx为软件名称,例如 virtualbox 查看包是否安装 dpkg-query -l *package-name* 例如 virtualbox dpkg -s package-name 例如 virtualbox 列出你系统中安装的所有包,同样可以通过grep…

Ubuntu命令卸载软件

1.打开一个终端,输入dpkg --list ,按下Enter键,终端输出以下内容,显示的是你电脑上安装的所有软件。 2.在终端中找到你需要卸载的软件的名称,列表是按照首字母排序的。 3.在终端上输入命令sudo apt-get --purge remove 包名…

A星算法优化(二)权重系数

本文接上一篇:A星算法优化(一)启发函数 B站详解视频:https://www.bilibili.com/video/BV1EF411W7Rw?spm_id_from333.999.0.0 将从以下5个点进行改进: 1、启发函数——曼哈顿距离等 2、权重系数——动态加权等 3、搜索…

A_star算法

A*算法 A* 搜索算法,即A star search algorithm,简称A* 算法。 是一种在图形平面上对于多个节点的路径求出最低通过成本的算法。是对图的遍历和最佳优先搜索算法,也是对BFS的改进。其思想在于为每个状态建立启发函数,用启发函数制…

A star算法

A star算法介绍 我们在解空间搜索问题的可行解或者最优解时常用宽度优先搜索(BFS)或者深度优先搜索(DFS),但是有时候会扩展出很多无用节点,搜索时间较长,而A*算法则是选择当前估计成本最低的节点进行扩展,图示如下: g(n)为从起始…

【A星算法】A星寻路算法详解(小白也可以看懂+C#代码+零基础学习A*)

1.问题背景 在制作RPG游戏角色和NPC移动时,需要角色自动避开障碍物,到达终点 怎么快速找到一条到达终点的路径? 使用a星寻路算法 2.A星算法的思路 绿色:起点;红色:终点 ;黑色:障碍…

A-star算法自学

搜索过程 广度优先搜索(BFS)算法与Dijsktra算法的结合,可以得出最短的路径。 将地图信息通过划分为方形或者其他多边形格子的方法进行表示,便于利用二维数组存放地图信息,每个格子有可行和不可行两种状态;…