当前位置: 首页 > news >正文

【Linux】进程状态

文章目录

  • 1. 阻塞
    • 1. 举例
    • 2. 为什么要阻塞?
    • 3.操作系统层面上如何理解进程等待某种资源就绪呢?
      • 资源
      • 进程
    • 4. 总结
  • 2.挂起
  • 3.Linux进程状态
    • 1. R状态
      • 进程只要是R状态,就一定是在CPU运行吗?
      • 证明当前进程运行状态
        • 生成程序
        • 查看进程
    • 2. S休眠状态——可中断休眠
    • 3.D休眠状态 ——不可中断休眠
    • 4.T状态——暂停状态
      • 使用kill命令,向指定的进程发信号
      • 暂停进程
      • 继续进程
      • 带加号的问题
    • 5. X状态(死亡状态)&&Z状态(僵尸状态)
      • 查看当前进程退出码
      • 对于Z状态的理解
        • 举例
      • 验证Z状态
      • 僵尸状态危害

1. 阻塞

进程因为等待某种条件就绪,而导致的一种不推进的状态

1. 举例

  • 有时候电脑卡,是因为开启了太多软件,为什么启动太多程序会卡呢?
  • 启动了太多的程序相当于启动了太多的进程,操作系统在用你的cpu调度时,调度不过来了,当前正在调度的在运行,没有调度的相当于卡了
  • 阻塞就是进程卡住了

2. 为什么要阻塞?

  • 进程要通过等待的方式,等具体的资源被别人使用完成后,再被自己使用
  • 阻塞:进程等待某种资源就绪的过程
  • 以硬件为例,资源可以看作磁盘、网卡、显卡等外设,
    比如去银行存钱,存钱申请的单子没了,直接去存,工作人员就会说因为存钱的单子没有就绪所以不能存,再去等一会,等有单子了再来存
  • 没有继续执行存钱的行为,当前所处状态为阻塞状态

3.操作系统层面上如何理解进程等待某种资源就绪呢?

资源

操作系统对于磁盘、网卡、显卡等 资源通过 先描述,在组织进行管理,把设备用结构体描述起来,再用链表组织起来
管理的本质具体解释点击这里

进程

存在大量的进程,操作系统要进行管理,也要先描述,在组织,就存在了大量的task_struct的结构体,每一个进程都是由task_struct定义出来的对象
进程组成的理解点击这里
在这里插入图片描述

  • 将dev结构体内添加一个队列指针,若进程需要在设备资源等待,则把task_struct链接到设备资源队列的尾部

4. 总结

阻塞:阻塞就是不被调度
一定是因为当前进程等待某种资源就绪
一定是进程task_struct结构体需要在某种操作系统管理的资源下进行排队

2.挂起

在这里插入图片描述

  • 当进程被CPU调度时进行下载,由于网断了,导致下载终止,从而使进程链接到网卡设备队列的尾部,造成阻塞
    从而使CPU调用其他进程

在这里插入图片描述

  • 若系统中内存的资源特别紧张,把占有内存的并且闲置的数据和代码,交换到磁盘当中,把内存中这部分的代码和数据释放,当该进程等待的资源就绪时,再把存入磁盘的数据和代码换入内存中,并把进程放入CPU中运行
  • 把代码和数据暂时性由操作系统交换到磁盘时,此时的进程称之为挂起状态

3.Linux进程状态


static const char * const task_state_array[] = {
"R (running)", /* 0 */
"S (sleeping)", /* 1 */
"D (disk sleep)", /* 2 */
"T (stopped)", /* 4 */
"t (tracing stop)", /* 8 */
"X (dead)", /* 16 */
"Z (zombie)", /* 32 */
}; 
  • Linux源码当中进程所对应的状态

struct task_struct
{
int status;//0代表R状态  1代表s状态 4代表T状态
//....
}

task_struct 是一个结构体,内部会包含各种属性,就有状态,通过0、1、2等数字找到对应的进程状态

1. R状态

进程只要是R状态,就一定是在CPU运行吗?

不一定

在这里插入图片描述

  • 每个进程当中有自己的运行队列,只要该进程在队列中进行排队,运行的进程就会在运行的队列中排队,CPU调度进程时,从队列中挑选指定的进程运行就可以了,这种运行状态就叫做R状态

  • R状态不直接代表进程在运行,代表该进程在运行队列中排队

证明当前进程运行状态

生成程序

创建makefile并输入如下内容

   1 mytest:test.c//nakefile2   gcc -o mytest test.c 3 .PHONY:clean 4 clean:5  rm -f mytest  

创建test.c并输入如下内容

#include<stdio.h>//test.c2 int main()3 {4   while(1)5   {6     printf("我在运行吗\n");                                                                                                                                            7   }                                                                                                                         8   return 0;                                                                                                                 9 }                                                                                                                               

[yzq@VM-8-8-centos my]$ make
gcc -o mytest test.c 
[yzq@VM-8-8-centos my]$ ./mytest

make产生可执行程序mytest,./mytest执行可执行程序

查看进程

赋值SSH渠道生成终端2
在保证终端1中的mytest运行的情况下,在终端2中输入指令
ps axj | head -1 && ps axj | grep mytest | grep -v grep

创建终端的方法及指令具体含义点击这里

[yzq@VM-8-8-centos my]$ ps axj | head -1 && ps axj | grep mytest | grep -v grepPPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
25615 30533 30533 25615 pts/0    30533 S+    1002   0:00 ./mytest

发现此时进程状态为S+ (+号后面会说)
S称为休眠状态,不是R状态


test.c代码修改如下

 #include<stdio.h>//test.c2 int main()3 {4   while(1)5   {6    // printf("我在运行吗\n");                                                                                                                                        7   }                   8   return 0;           9 }                     

在保证终端1中的mytest运行的情况下,在终端2中再次输入指令ps axj | head -1 && ps axj | grep mytest | grep -v grep

[yzq@VM-8-8-centos my]$ ps axj | head -1 && ps axj | grep mytest | grep -v grepPPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
25615 31695 31695 25615 pts/0    31695 R+    1002   0:10 ./mytest
  • 发现进程状态由S+变为R+
  • printf循环打印,就代表要频繁访问显示器设备,循环中的printf本质就是向外设打印消息,当CPU执行printf代码时,频繁打印外设不一定就绪,进程可能在外设中排队,等资源就绪时,再把进程放入CPU上把结果写入外设中
  • 说明第一次查到的S状态是阻塞状态的一种,是以休眠状态进行阻塞的

2. S休眠状态——可中断休眠

本质是一种阻塞状态

修改test.c代码如下

 1 #include<stdio.h>2 int main()3 {4   while(1)5   {6    int b=0;7    scanf("%d",&b);8    printf("%d\n",b);9   }                                                                                                                                                                  10   return 0;                                                                                                                11 }     
  • ./mytest运行,并输入10 10

在保证终端1中的mytest运行的情况下,在终端2中再次输入指令
ps axj | head -1 && ps axj | grep mytest | grep -v grep

[yzq@VM-8-8-centos my]$  ps axj | head -1 && ps axj | grep mytest | grep -v grepPPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
25615  5793  5793 25615 pts/0     5793 S+    1002   0:00 ./mytest
  • 进程状态为S,进程没有被调度,等键盘资源 即在键盘中输入数据

[yzq@VM-8-8-centos my]$ ./mytest
10
10
^C//可以被终止
  • 在终端1中ctrl c,终止mytest运行,S状态被终止

3.D休眠状态 ——不可中断休眠

想要往磁盘写入100MB的数据,由于磁盘写入数据很慢,所以进程把自己设置成阻塞状态,若内存资源特别紧张,操作系统就想要把这个阻塞状态的进程干掉,可是此时磁盘依旧还在写入数据,这样做就会使磁盘写入数据失败,最终就会使100MB的数据丢失

  • 若该进程的休眠状态为D状态,使操作系统无法干掉进程,就能解决这个问题

4.T状态——暂停状态

使用kill命令,向指定的进程发信号

[yzq@VM-8-8-centos my]$ kill -l1) SIGHUP     2) SIGINT     3) SIGQUIT     4) SIGILL     5) SIGTRAP6) SIGABRT     7) SIGBUS     8) SIGFPE     9) SIGKILL    10) SIGUSR1
11) SIGSEGV    12) SIGUSR2    13) SIGPIPE    14) SIGALRM    15) SIGTERM
16) SIGSTKFLT    17) SIGCHLD    18) SIGCONT    19) SIGSTOP    20) SIGTSTP
  • 9号信号SIGKILL 表示干掉 进程
  • 18号信号 SIGCONT 表示让当前进程继续运行
  • 19号信号 SIGSTOP 表示暂停一个进程

暂停进程

test.c内容如下

1 #include<stdio.h>
#include<unistd.h>2 int main()3 {4   int count=0;5   while(1)6   {                                                                                                                                                                  7    printf("还在运行吗:%d\n",count++);sleep(1);8   }                                  9   return 0;10 }          

保证在保证终端1中的mytest运行的情况下,在终端2中再次输入指令ps axj | head -1 && ps axj | grep mytest | grep -v grep 并输入 kill-19+PID值,终端1自动停止运行

在这里插入图片描述


[yzq@VM-8-8-centos my]$ ps axj | head -1 && ps axj | grep mytest | grep -v grepPPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
25615 14791 14791 25615 pts/0    14791 S+    1002   0:00 ./mytest

再次在终端2中查询进程,发现进程状态由S+变为T

继续进程

若想让进程继续运行,在终端2中使用 kill -18 +PID值
在这里插入图片描述

带加号的问题

yzq@VM-8-8-centos my]$ ps axj | head -1 && ps axj | grep mytest | grep -v grepPPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
25615 14791 14791 25615 pts/0    25615 S     1002   0:00 ./mytest
  • 在暂停进程,又继续进程后,当前进程状态 为S,不带加号了
  • 在终端1使用ctrl c,程序不停止了

  • 进程状态带+,进程是在前台运行的,可以使用ctrl c 终止

  • 进程状态不带+,进程是在后台运行的,可以正常执行shell指令,但在后台继续还会执行自己的代码

  • 此时若想终止进程,使用 kill -9 +PID值 干掉进程

5. X状态(死亡状态)&&Z状态(僵尸状态)

  • X死亡状态只是一个返回状态,你不会在任务列表里看到这个状态,所以这里这是举例时提及,但不会验证
  • 我们创建进程,是为了进程帮我们办事,同时也关心结果,而main函数的返回值是进程的退出码

查看当前进程退出码

用于判定进程结果是否正确 echo $?

修改test.c的内容如下

include<stdio.h>2 #include<unistd.h>3 int main()4 {5   int count=2;6   if(count==2)7   {8     return 0;9   }10   else 11   {12     return 4;13   }                                                                            14 }
~

使用make生成可执行程序mytest,./mytest执行可执行程序

[yzq@VM-8-8-centos my]$ make
gcc -o mytest test.c 
[yzq@VM-8-8-centos my]$ ./mytest
[yzq@VM-8-8-centos my]$ echo $?
0
  • 说明mytest进程的退出码是0,进程结果正确

对于Z状态的理解

如果一个进程退出了,立马X状态,立马退出,你作为父进程,有没有机会拿到退出结果呢?

  • linux当进程退出的时候,一般进程不会立即彻底退出,而是要维持一个状态叫做Z状态,也叫做僵尸状态
  • 方便后续父进程读取子进程退出的退出结果

如何让我们看到僵尸状态呢?

  • 子进程退出,但是不要回收子进程

举例

  • 假设你在某一天看到路上有一个人躺着,你报了警,警察来了后,先封锁现场,再来人确认躺者是否死亡,法医确认这个人的死因,然后通知家属等一系列事情才能进行
  • 被120、法医检查时,这个人所处的状态就叫僵尸状态
  • 为了方便别人从他的残留信息中甄别他死亡的原因是什么

验证Z状态

修改test.c内容如下

#include<stdio.h>2 #include<unistd.h>3 int main()4 {5   pid_t id=fork();6   if(id==0)7   {8     //子进程9     while(1)10     {11       printf("我是子进程,我在运行,pid:%d,ppid:%d",getpid(),getppid());12       sleep(1);13     }14   }15   else if(id>0)16   {17     //父进程18     while(1)19     {20       printf("我是父进程,我在运行,pid:%d,ppid:%d",getpid(),getppid());21       sleep(1);22   }                                                                          23   }}

保证在保证终端1中的mytest运行的情况下,在终端2中再次输入指令ps axj | head -1 && ps axj | grep mytest | grep -v grep

[yzq@VM-8-8-centos my]$ ps axj | head -1 && ps axj | grep mytest | grep -v grepPPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
25615 18251 18251 25615 pts/0    18251 S+    1002   0:00 ./mytest
18251 18252 18251 25615 pts/0    18251 S+    1002   0:00 ./mytest
[yzq@VM-8-8-centos my]$ kill -9 18252
[yzq@VM-8-8-centos my]$ ps axj | head -1 && ps axj | grep mytest | grep -v grepPPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
25615 18251 18251 25615 pts/0    18251 S+    1002   0:00 ./mytest
18251 18252 18251 25615 pts/0    18251 Z+    1002   0:00 [mytest] <defunct>
  • 当父子进程都运行时,两者进程状态都为S+
  • 当使用 kill - 9 +PID值将子进程干掉后,再次使用指令查询进程,发现子进程为僵尸状态,父进程为S+

僵尸状态危害

  • 在父子进程中,若父进程一直不读取,子进程就会处于Z状态
  • 在父子进程中,若子进程一直处于僵尸状态(即退出子进程,但不回收子进程),就会在内存中一直保留该进程
  • 若父进程创建多个子进程,就是不回收,就会造成内存资源的浪费

相关文章:

【Linux】进程状态

文章目录1. 阻塞1. 举例2. 为什么要阻塞&#xff1f;3.操作系统层面上如何理解进程等待某种资源就绪呢&#xff1f;资源进程4. 总结2.挂起3.Linux进程状态1. R状态进程只要是R状态&#xff0c;就一定是在CPU运行吗&#xff1f;证明当前进程运行状态生成程序查看进程2. S休眠状态…...

2023河南省第二届职业技能大赛郑州市选拔赛“网络安全”项目比赛样题任务书

2023河南省第二届职业技能大赛郑州市选拔赛“网络安全” 项目比赛样题任务书 一、竞赛时间 共计360分钟。 竞赛任务书内容 2023河南省第二届职业技能大赛郑州市选拔赛“网络安全” 项目比赛样题任务书 A模块基础设施设置/安全加固&#xff08;200分&#xff09; A-1&…...

pygame8 扫雷游戏

一、游戏规则&#xff1a; 1、点击方格&#xff0c;如果是地雷&#xff0c;游戏失败&#xff0c;找到所有地雷游戏胜利 2、如果方块上出现数字&#xff0c;则表示在其周围的八个方块中共有多少颗地雷 二、游戏主逻辑&#xff1a; 主要逻辑即调用run_game, 然后循环检测事件…...

c/c++开发,无可避免的模板编程实践(篇四)

一、容器与模板 前文就说到&#xff0c;标准库基于模板编程&#xff0c;定义了许多容器类以及一系列泛型算法&#xff0c;使程序员可以更简洁、抽象和有效地编写程序。C标准库中有大量的标准容器&#xff0c;这些容器通常包含一组数据或对象的集合&#xff0c;几乎可以和任何类…...

c++11 标准模板(STL)(std::unordered_set)(二)

定义于头文件 <unordered_set> template< class Key, class Hash std::hash<Key>, class KeyEqual std::equal_to<Key>, class Allocator std::allocator<Key> > class unordered_set;(1)(C11 起)namespace pmr { templ…...

GEE学习笔记 七十二:【GEE之Python版教程六】命令行简介

这篇开始就要讲解GEE相关的内容&#xff0c;首先聊一下命令行的内容&#xff0c;这个在官方文档中有详细的介绍&#xff0c;这里我简单说一下常用的几个命令&#xff0c;剩余的大家在使用过程中如果又需要可以随时查看相关官方文档的介绍。官方文档地址&#xff1a;https://dev…...

DDD单根 聚合根 实体 值对象

前言2004年Eric Evans 发表Domain-Driven Design –Tackling Complexity in the Heart of Software &#xff08;领域驱动设计&#xff09;&#xff0c;简称Evans DDD。快二十年的时间&#xff0c;领域驱动设计在不断地发展&#xff0c;后微服务时代强调的东西&#xff0c;在国…...

SpringMvc介绍。

目录 1、SpringMvc概述 1、基本介绍 2、工作流程 3、bean加载控制 二、请求 1、请求映射路径 2、请求方式 3、请求参数 4、请求参数&#xff08;传递json数据&#xff09; 5、日期类型参数传递 三、响应 四、REST风格 1、REST简介 2、RESTful入门案例 3、RESTfu…...

华为OD机试 - 最小传递延迟(JS)

最小传递延迟 题目 通讯网络中有N个网络节点 用1 ~ N进行标识 网络通过一个有向无环图进行表示 其中图的边的值,表示节点之间的消息传递延迟 现给定相连节点之间的延时列表times[i]={u,v,w} 其中u表示源节点,v表示目的节点,w表示u和v之间的消息传递延时 请计算给定源节点到…...

学生信息管理系统(通讯录)----------通俗易懂、附源码、C语言实现

绪论&#xff1a; 本篇文章使结构体章节后的习题&#xff0c;如果你对C语言有问题&#xff0c;或者结构体有什么问题不妨看看我之前所写的文章&#xff08;章回体&#xff09;,对于文件管理和内存分配问题我将在后面补上&#xff0c;对于这个学生信息管理系统我用了多种方法和…...

Python抽奖系统

#免费源码见文末公众号# 抽奖系统① def choujiang1():def write():with open(d:\\抽奖系统\\抽奖1.1.pickle,rb) as file:lst1pickle.load(file)namevar1.get()if name not in lst1 and name!录入成功&#xff01; and name!录入失败&#xff01; and name!:lst1.append(name)…...

真实景观渲染技巧【Three.js】

受到一些很棒的 three.js 演示、与 covid 相关的旅行禁令以及可能在 pinterest 上花太多时间看美丽的旅行照片的启发——我开始看看我是否可以使用 three.js 和r3f在浏览器中渲染一个令人信服的风景场景。 推荐&#xff1a;将 NSDT场景编辑器 加入你的3D开发工具链。 在过去一个…...

MySQL知识汇总:MySQL函数CASE WHEN用法详解

Case When的两种简单用法 用法一&#xff1a; CASE seasonWHEN Spring THEN 春天 WHEN Summer THEN 夏天 WHEN autumn THEN 秋天 else 冬天 end 用法二&#xff1a; CASE WHEN season Spring THEN 春天WHEN season Summer THEN 夏天WHEN season autumn THEN 秋天 els…...

Python学习-----模块1.0(模块的简介、定义与使用)

目录 前言&#xff1a; 1.什么是模块 2.模块的分类 &#xff08;1&#xff09;内置模块 &#xff08;2&#xff09;第三方模块 &#xff08;3&#xff09;自定义模块 3.模块的使用 4.自定义模块 5.模块和执行文件的判断 前言&#xff1a; 今天就开始讲Python中的模块篇…...

Linux进程学习【二】

✨个人主页&#xff1a; Yohifo &#x1f389;所属专栏&#xff1a; Linux学习之旅 &#x1f38a;每篇一句&#xff1a; 图片来源 &#x1f383;操作环境&#xff1a; CentOS 7.6 阿里云远程服务器 Perseverance is not a long race; it is many short races one after another…...

我问chatGPT,在JavaScript中构造函数和类的区别

问&#xff1a;构造器函数和面向中的类是同样的东西吗|&#xff1f; 答&#xff1a;构造器函数和面向对象中的类并不是同样的东西&#xff0c;它们之间有些许不同。 在面向对象编程中&#xff0c;类是一种抽象的概念&#xff0c;它描述了一类具有相同属性和行为的对象。类可以…...

软考高级-信息系统管理师之沟通管理(最新版)

项目沟通管理 1、项目沟通管理基础项目沟通管理的重要性项目沟通管理相关理论2、规划沟通管理3、管理沟通4、控制沟通项目沟通管理的技术和工具1、项目沟通管理基础 项目沟通管理的重要性 1、与1T项目成功有关的最重要的四个因素是:主管层的支持、用户参与、有经验的项目经理…...

PyQt5 自定义富文本编辑器

介绍 一款使用PyQt5和网页端框架wangEditor集成的富文本编辑器 代码片段 PyQt5客户端 与网页端建立连接def create_connect(self):self.web_view QWebEngineView()self.bridge JSBridge(self.web_view.page())self.web_view.load(QUrl.fromLocalFile(self.editor_path))w…...

【高可用系统架构设计】SLA服务可用性4个9是什么意思?如何保证服务的高可用性 HA(High Availability)?...

如何保证服务的高可用性 HA&#xff08;High Availability&#xff09;?高可用HA&#xff08;High Availability&#xff09;是分布式系统架构设计中必须考虑的因素之一&#xff0c;它通常是指&#xff0c;通过设计减少系统不能提供服务的时间。方法论上&#xff0c;高可用是通…...

微服务架构设计模式-(14)面向生产环境

生产环境要求 应用安全 数据权限 服务可配置性 不同环境的配置不一样&#xff0c;不能写死代码&#xff0c;所以要配置 可观测性 需要日志系统 应用安全 四个方面 身份验证 验证主体的身份解决方案 单体 cookie 微服务中 API Gateway 访问令牌 不透明令牌透明令牌&#xff…...

RestClient

什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端&#xff0c;它允许HTTP与Elasticsearch 集群通信&#xff0c;而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级&#xff…...

SciencePlots——绘制论文中的图片

文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了&#xff1a;一行…...

Python实现prophet 理论及参数优化

文章目录 Prophet理论及模型参数介绍Python代码完整实现prophet 添加外部数据进行模型优化 之前初步学习prophet的时候&#xff0c;写过一篇简单实现&#xff0c;后期随着对该模型的深入研究&#xff0c;本次记录涉及到prophet 的公式以及参数调优&#xff0c;从公式可以更直观…...

10-Oracle 23 ai Vector Search 概述和参数

一、Oracle AI Vector Search 概述 企业和个人都在尝试各种AI&#xff0c;使用客户端或是内部自己搭建集成大模型的终端&#xff0c;加速与大型语言模型&#xff08;LLM&#xff09;的结合&#xff0c;同时使用检索增强生成&#xff08;Retrieval Augmented Generation &#…...

基于IDIG-GAN的小样本电机轴承故障诊断

目录 🔍 核心问题 一、IDIG-GAN模型原理 1. 整体架构 2. 核心创新点 (1) ​梯度归一化(Gradient Normalization)​​ (2) ​判别器梯度间隙正则化(Discriminator Gradient Gap Regularization)​​ (3) ​自注意力机制(Self-Attention)​​ 3. 完整损失函数 二…...

逻辑回归暴力训练预测金融欺诈

简述 「使用逻辑回归暴力预测金融欺诈&#xff0c;并不断增加特征维度持续测试」的做法&#xff0c;体现了一种逐步建模与迭代验证的实验思路&#xff0c;在金融欺诈检测中非常有价值&#xff0c;本文作为一篇回顾性记录了早年间公司给某行做反欺诈预测用到的技术和思路。百度…...

「全栈技术解析」推客小程序系统开发:从架构设计到裂变增长的完整解决方案

在移动互联网营销竞争白热化的当下&#xff0c;推客小程序系统凭借其裂变传播、精准营销等特性&#xff0c;成为企业抢占市场的利器。本文将深度解析推客小程序系统开发的核心技术与实现路径&#xff0c;助力开发者打造具有市场竞争力的营销工具。​ 一、系统核心功能架构&…...

在树莓派上添加音频输入设备的几种方法

在树莓派上添加音频输入设备可以通过以下步骤完成&#xff0c;具体方法取决于设备类型&#xff08;如USB麦克风、3.5mm接口麦克风或HDMI音频输入&#xff09;。以下是详细指南&#xff1a; 1. 连接音频输入设备 USB麦克风/声卡&#xff1a;直接插入树莓派的USB接口。3.5mm麦克…...

嵌入式学习之系统编程(九)OSI模型、TCP/IP模型、UDP协议网络相关编程(6.3)

目录 一、网络编程--OSI模型 二、网络编程--TCP/IP模型 三、网络接口 四、UDP网络相关编程及主要函数 ​编辑​编辑 UDP的特征 socke函数 bind函数 recvfrom函数&#xff08;接收函数&#xff09; sendto函数&#xff08;发送函数&#xff09; 五、网络编程之 UDP 用…...

若依登录用户名和密码加密

/*** 获取公钥&#xff1a;前端用来密码加密* return*/GetMapping("/getPublicKey")public RSAUtil.RSAKeyPair getPublicKey() {return RSAUtil.rsaKeyPair();}新建RSAUti.Java package com.ruoyi.common.utils;import org.apache.commons.codec.binary.Base64; im…...