Linux_进程概念_冯诺依曼_进程概念_查看进程_获取进程pid_创建进程_进程状态_进程优先级_环境变量_获取环境变量三种方式_3
文章目录
- 一、硬件-冯诺依曼体系结构
- 二、软件-操作系统-进程概念
- 0.操作系统做什么的
- 1.什么叫做进程
- 2.查看进程
- 3.系统接口 获取进程pid- getpid
- 4.系统接口 获取父进程pid - getppid
- 5.系统接口 创建子进程 - fork
- 1、手册
- 2、返回值
- 3、fork做了什么
- 4、基本用法
- 6.进程的状态
- 1、进程的状态是什么
- 2、进程的状态
- 7.Linux下的进程状态
- 1、运行状态 - R
- 2、阻塞状态 - S (可中断)
- 3、阻塞状态 - D (不可中断)
- 4、僵尸状态- Z 和 死亡状态 - X
- 5.停止状态 - T / t
- 8.孤儿进程
- 9.进程优先级
- 1、什么是优先级 vs 权限 (是什么)
- 2、为何会存在优先级?(为什么)
- 3、Linux下的优先级的相关概念和操作(怎么办)
- 10.竞争性_独立性_并行_并发_进程间切换
- 三、环境变量
- 1.环境变量操作
- 2.让自己程序和命令一样执行
- 3.常见环境命令
- 4.环境变量的C、C++获取方式(代码如何获取环境变量)
- 1、mian函数参数获取环境变量
- 2、通过C语言提供的全局变量获取 - environ
- 3、获取环境变量函数 - getenv(const char* name)
一、硬件-冯诺依曼体系结构
我们常见的计算机,如笔记本。我们不常见的计算机,如服务器,大部分都遵守冯诺依曼体系。

输入:键盘,话筒,摄像机,磁盘,网卡…
输出:显卡,音响,磁盘,网卡,显卡…
(运算器+控制器)[cpu]:算术计算+逻辑计算
储存器:就是内存
为什么要有内存,直接将输入设备和cpu直接连接不可以吗?
a. 技术角度
cpu的运算速度>寄存器的速度>L1~L3Cache>内存>>外设(磁盘)>>光盘磁带
数据角度:外设不和CPU直接交互,而是和内存交互,CPU也是如此。
内存在我们看来,就是体系结构的一个大的缓存,适配外设和CPU速度不均的问题的!
b. 成本角度
造价成本:寄存器>>内存>>磁盘(外设)
几乎所有的硬件,只能被动的完成某种可能,不能主动的完成某种功能,一般都是配合软件完成的(OS+CPU)
二、软件-操作系统-进程概念
0.操作系统做什么的
操作系统是一款软件,搞管理的软件,什么叫做管理, 如何理解?
管理的本质:不是对被管理对象进行直接管理,而是只要拿到被管理对象的所有的相关数据,我们对数据的管理,就可以体现对人的管理————对数据做管理
数据是有多少的区分的如何管理好大量数据?
大量数据,就需要结构化,也就是对数据结构的管理。
管理的核心理念:先描述,再组织

1.什么叫做进程
进程是一个运行起来的程序
操作系统里面可能同时存在大量的进程!操作系统需要对进程管理,对进程管理本质就是对进程数据的管理,就需要先描述,再组织。
struct task_struct : 就是描述进程的,像这样描述进程的统称为进程控制块PCB( proccess ctrl block ),而task_struct就是其中一个具体实例。
进程 = 可执行程序 + 该进程对应的内核数据结构(PCB)
OS为什么给我们提供服务?
printf 向显示器打印,本质就是将数据写到硬件上,我们的c程序没有资格向硬件写入,计算机和os设计出来是为了给人提供服务的。
如何提供服务?
操作系统不相信如何人!不会直接暴露自己的任何数据结构,代码逻辑,其他数据相关的细节!!操作系统是通过系统调用的方式,对外提供接口服务的,Linux操作系统是用c语言写的,这里所谓的“接口”,本质就是c函数!我们学习系统编程—本质就是在学习这里的系统接口
2.查看进程
先写一个死循环程序编译运行:
#include<stdio.h>
int main()
{while(1){printf("I am a process!\n");}return 0;
}
查看进程方式1:
这是查看进程的第一种方式,也是最常用的。
ps ajx 进程名 | grep 进程名

有头部提示:
ps ajx |head -1 && grep 进程名称

为什么会有两个?
我们自己写的代码,编译称为可执行程序,启动之后就是一个进程!
别人写的,启动之后也是一个进程!比如:ls pwd touch grep …
那么这些程序,在系统中的位置— /usr/bin
第二个进程就是查询程序的进程,第一个就是我们编写的程序的进程。

根目录里有一个目录proc,放内存文件系统,系统里放着当前系统实时的进程信息。查看目录里面的内容:

上面的蓝色就是进程的pid!
每一个进程在系统中,都会存在一个唯一的标识符(pid->process id)!就如每人都有一个身份证号。
查看运行进程目录其中有一个cwd:

cwd :current work directory 进程当前工作路径
当前路径??
当前进程所在路径,进程自己会维护
查看进程的方式2:
先查进程pid在再/proc里的进程目录查看详细信息。
那么上面所说的pid,当前路径等待,是进程的内部属性,程序运行放在哪里?
进程的进程控制块-PCB(task_struct)结构体中
3.系统接口 获取进程pid- getpid
命令行查看系统接口getpid:
man 2 getpid

#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
int main()
{printf("我的pid是 %d\n",getpid());return 0;
}

杀进程除了Ctrl+c还有一个方法:
另起一个页面,命令行输入kill -9 进程的pid
4.系统接口 获取父进程pid - getppid
命令行查看系统接口getppid:
man 2 getppid

注:
手册退出按q
#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
int main()
{printf("我的pid是 %d,ppid: %d\n",getpid(),getppid());return 0;
}
多次运行发现ppid不变

查看进程,发现父进程是一个bash:

为什么父进程不变?它是谁?
几乎我们在命令行上执行的所有的指令(你的cmd),都是bash进程的子进程!
5.系统接口 创建子进程 - fork
1、手册
man 2 fork

2、返回值
下面为手册中返回值解释:

fork函数是用来创建子进程的,它有两个返回值?
#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
int main()
{pid_t id = fork();printf("hello world,id: %d\n",id);return 0;
}

父进程返回子进程pid,子进程返回0
同一个id值,使用打印,没有修改,却打出来了不同的值?
现在无法解释,进程地址空间,才能解释!
c语言上,if和else 可以同时执行吗?
c语言中,有没有可能两个以上的死循环同时运行?
#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
int main()
{pid_t id = fork();if(id==0){while(1){printf("我是子进程,我的pid:%d,我的父进程是:%d\n",getpid(),getppid());sleep(1);}}else {while(1){printf("我是父进程,我的pid:%d,我的父进程是:%d\n",getpid(),getppid());sleep(1);}}printf("hello world,id: %d\n",id);return 0;
}

为什么 fork 给父进程子进程的pid,给子进程 0?
父亲:儿子 = 1:n (n>=1)
为什么给父进程子进程的pid
父进程必须有标识子进程的方案,fork之后,给父进程返回子进程的pid!
为什么给子进程0?
子进程最重要的是要知道自己被创建成功了,因为子进程找父进程成本非常低getppid()
综上得出结论:
fork之后,父进程和子进程会共享代码,一般都会执行后续代码 — printf为什么会打印两次的问题
fork之后,父进程和子进程返回值不同,可以通过不同的返回值来判断,让父子执行不同的代码块!!
3、fork做了什么
fork之后,OS做了什么?
系统多了一个进程:
父进程:task_struct + 进程代码和数据
子进程:task_struct + 子进程的代码和数据
子进程的tastk_struct对象内部数据从哪里来?
基本是从父进程继承下来的
子进程执行代码,计算数据,子进程的代码从哪里来?
和父进程执行同样的代码,fork之后,父子进程代码共享,而数据要各自独立,根据不同的返回值,让不同的进程执行不同的代码(可以用if else 来分流)。
4、基本用法
#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
int main()
{pid_t id = fork();if(id==0){//子进程执行的代码}else {//父进程执行的代码}return 0;
}
6.进程的状态
1、进程的状态是什么
其实就是个整数 ,int status,在进程的task_struct(进程控制块)里。
int status:
#define RUN 1
#define STOP 2
#define SLEEP 3
2、进程的状态
运行态:进程只要是在运行队列中就叫做运行态,代表我已经准备好了,随时可以调度!!

注:runqueue就是运行队里
终止状态:进程还在,只不过永远不运行了,随时等待被释放!
进程都终止了,为什么不立马释放对应的资源,而是维护一个终止态?
释放要花时间,如果当前系统很忙,系统就没有办法立刻释放,就需要维护一个终止队列,告诉系统,我已经运行结束了,随时可以释放对应的资源,等到系统有空闲的时来释放我吧!
进程阻塞:进程等待某种资源(非CPU)资源没有就绪的时候,进程需要在该资源的等待队列中进行排队,此时进程的代码并没有运行,进程所处的状态就叫做阻塞!
1.一个进程,使用资源的时候,可不仅仅是申请CPU资源
2.进程可能申请更多的其他资源:磁盘,网卡,显卡,显示器资源,声卡/音响
如果申请CPU资源,暂时无法得到满足,需要排队的–运行队列
那么如果申请其他慢设备的资源?—也是需要排队的!

当访问某些资源(磁盘网卡),该资源如果没有准备好,或者正在给其他进程提供服务,此时:
1.当前进程从runqueue中移除
2.将当前进程放入对应设备的描述结构体中的等待队列
进程等待外部资源的时候,该进程的代码不会被执行,也就是我的进程卡住了就是进程阻塞
进程挂起:短期内不会被调度(你等的资源,短期内不会就绪)进程,OS就会把该进程的代码和数据置换到磁盘上

如果内存不足怎么办?
操作系统就会帮我们进行辗转腾挪,短期内不会被调度(你等的资源,短期内不会就绪)进程,它的代码和数据依旧在内存中,就是白白浪费空间,OS就会把该进程的代码和数据置换到磁盘上!
往往内存不足的时候,伴随
7.Linux下的进程状态
Linux内核源码:
/*
* The task state array is a strange "bitmap" of
* reasons to sleep. Thus "running" is zero, and
* you can test for combinations of others with
* simple bit tests.
*/
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 */
};
1、运行状态 - R
#include<stdio.h>
#include<unistd.h>int main()
{while(1){printf("hello wordl!\n");sleep(1);}return 0;
}
运行并查看进程:

虽然进程一直在执行,但大部分都在sleep.
#include<stdio.h>
#include<unistd.h>int main()
{while(1){printf("hello wordl!\n");// sleep(1);}return 0;
}
运行并查看进程:

原因是这一句 printf(“hello wordl!\n”);,进程大部分时间在等显示器就绪,就绪就打印。
2、阻塞状态 - S (可中断)
“S (sleeping)” 阻塞状态
一般把S状态叫做:浅度睡眠,可中断睡眠
#include<stdio.h>
#include<unistd.h>int main()
{while(1){}return 0;
}
运行并查看进程:

这个进程没有访问外设,在访问cpu资源,大概率就是R状态。
“R (running)” 运行态
3、阻塞状态 - D (不可中断)
D (disk sleep)" 阻塞态
D : 深度睡眠,不可被中断睡眠
一般而言,Liunx中,如果我们等待的是磁盘资源,进程阻塞所处的状态就是D。(此时进程在等待外设,切程序不可被中断,如果可以中断,磁盘写入失败,磁盘会把写入失败结果告诉进程时,发现进程已经没了,就会造成数据)
4、僵尸状态- Z 和 死亡状态 - X
X:死亡状态
Z(zombie):僵尸状态
当一个Linux中的进程退出的时候,一般不会进入X状态(死亡,资源可以立马回收),而是进入Z状态。
进程为什么被创建出来?
一定是因为要有任务让这个进程执行,当该进程退出的时候,我们怎么知道,这个进程把任务给我们完成的如何了呢??一般需要将进程的执行结构告诉给父进程 OS
进程进入Z状态,就是为了维护退出信息,可以让父进程或者OS读取的!通过进程等待来进行读取的!
如何模拟僵尸状态?
如果创建子进程,子进程退出了,父进程不退出,也不等待子进程,子进程退出之后所处的状态就是Z。
#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
int main()
{pid_t id = fork();if(id==0){//childint cnt = 5;while(cnt){printf("我是子进程,我还剩下%d s\n",cnt--);sleep(1);}exit(0);}else{//fatherwhile(1){sleep(1);}}return 0;
}
编译运行并查看进程:
while :; do ps axj|head -1&&ps axj|grep test|grep -v grep;sleep 1; don

长时间僵尸,有什么问题?
如果没有人回收子进程的僵尸,该状态会一直维护!该进程的相关资源(task_struct)不会被释放,内存泄漏!一般必须要求父进程进行回收(后面说)。
5.停止状态 - T / t
将进程暂停:
方法一:
运行程序,按Ctrl+z。
方法二:

发送暂停信号给进程
kill -19 pid

t状态用gdb调试进程,就会出现t状态。
8.孤儿进程
#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
int main()
{pid_t id = fork();if(id==0){//childint cnt = 5;while(cnt){printf("我是子进程,我还剩下%d s\n",cnt--);sleep(1);}exit(0);}else{//fatherwhile(1){int cnt = 3;while(cnt){printf("我是父进程,我还剩下%d s\n",cnt--);sleep(1);}exit(0);}}return 0;
}

上面现象:
前三秒,父进程还没退出,当父进程退出后,子进程的父进程变成了1号进程,再过两秒,子进程退出,被1号进程回收。
结论:
如果父进程提前退出,子进程还在运行,子进程会被1号进程(操作系统)领养,像这样被领养的进程,就叫做孤儿进程。
子进程状态从S+变成S表示什么?
带+号的表示前台进程,可以使用Ctrl+c来杀掉前台进程。
但后台进程就无法用Ctrl+c来杀掉,只能用发送信号来杀掉进程:
kill -9 后台进程的pid
9.进程优先级
1、什么是优先级 vs 权限 (是什么)
优先级是进程获取资源的先后顺序。
权限是能还是不能的问题。
2、为何会存在优先级?(为什么)
排队的本质叫做确定优先级,那为什么要排队------资源不够
系统里面永远都是,进程占大多数,而资源是少数,进程竞争资源是常态,有竞争就需要确认先后,所以要存在优先级。
3、Linux下的优先级的相关概念和操作(怎么办)
查看进程:
ps -al

优先级由两部分构成:
PRI:priority
NI :nice 进程优先级的修改数据
默认进程优先级是80,数字越小优先级越高
要更改进程优先级,需要更改不是pri,而是Ni。
更改优先级:
命令行输入top->r->输入要更改进程的pid->回车->输入nice的值(范围-20~19一共40个级别)->回车。

naic的取值范围[-20,19]
priority的取值范围[60,99]
10.竞争性_独立性_并行_并发_进程间切换
竞争性: 系统进程数目众多,而CPU资源只有少量,甚至1个,所以进程之间是具有竞争属性的。为了高效完成任务,更合理竞争相关资源,便具有了优先级
独立性: 多进程运行,需要独享各种资源,多进程运行期间互不干扰,不会因为一个进程挂掉或者异常,而导致其他进程出现问题
并行: 多个进程在多个CPU下分别,同时进行运行,这称之为并行
并发: 多个进程在一个CPU下采用进程切换的方式,在一段时间之内,让多个进程都得以推进,称之为并发
多个进程都在你的系统中运行!= 多个进程都在你的系统中同时运行
不要以为进程一旦占用CPU,就会一直执行到结束,才会释放CPU资源!我们遇到的大部分操作系统都是分时的!操作系统会给每一个进程,再一次调度周期中,赋予一个时间片的概念,在一个是时间段,多个进程都会通过切换交叉的方式,让多个进程代码,在一段时间内都得到推进,这个现象,我们叫做并发。
操作系统,就是简单的根据队列来进行先后调度的吗?如何突然来一个优先级更高的进程?
抢占式内核,正在运行的低优先级进程,如果来个优先级更高的进程,我们的调度会直接把进程从CPU上剥离,放上优先级更高的进程,进程抢占。
进程间切换:
CPU的寄存器是:可以临时的存储数据,非常少,但非常重要。
当进程再被执行的过程中,一定会存在大量是临时数据,会暂时存在CPU内的寄存器中。
我们把进程在运行中产生的各种寄存器数据,叫做进程的上下文数据。
当进程被剥离:需要保存上下文数据
当进程恢复的时候:需要将曾经保存的上下文数据恢复到寄存器中
上下文在哪里保存?
task_struct
三、环境变量
为什么代码运行要带路径,而系统的指令不用带路径?
执行一个可执行程序,前提是要先找到它!
系统中是存在相关的环境变量(PATH),保存了程序的搜索路径的!
1.环境变量操作
查看所有环境变量:
env
显示某一个环境变量:
echo $变量名
echo $PATH

命令行定义本地变量:
a=100
查看本地变量:
set 变量(本地变量和环境变量都可以查到)
set a
注:本地变量不能被env查到
导出环境变量:
export bbbb=223
可以被env查到:
env |grep bbbb

取消环境变量:
unset 环境变量
总结:
查看环境变量: env
查看变量(可以是环境变量也可以是环境变量):set
查看某一个环境命令:eche $环境变量
导出环境变量:export 环境变量
取消环境变量:unset 环境变量
命令行变量分两种:
1.普通变量
2.环境变量(全局)
2.让自己程序和命令一样执行
如何让自己的程序不用带路径?
系统会在环境变量PATH你找可执行程序,如果存在就会执行,例如:cd,ls,touch…也就是说,我们将程序的路径导入PATH里,就可以像系统命令一样执行。
先查找当前程序路径,在导入路径到PATH:
pwd
export PATH=$PATH:路径
: 是路径的分隔符。

注:这只是暂时的,重新远程登陆,环境变量就会被重置,导致失效。如果想永久实现这个效果,需要修改配置文件,但不建议,会污染命令池。
3.常见环境命令
PATH : 指定命令的搜索路径
HOME : 指定用户的主工作目录(即用户登陆到Linux系统中时,默认的目录)
SHELL : 当前Shell,它的值通常是/bin/bash。
4.环境变量的C、C++获取方式(代码如何获取环境变量)
1、mian函数参数获取环境变量
main函数可以带参数吗?最多可以带多少?
#include<stdio.h>
int main(int argc,char* argv[])
{int i = 0;for(i=0;i<argc;i++){printf("argv[%d]:%s\n",i,argv[i]);}return 0;
}

我们给main函数传递的agrc,char* argv[],命令行参数传递的是,命令行中输入的程序名和选项!那么意义是什么?
同一个程序,通过传递不同的参数,让同一个程序有不同的执行逻辑,执行结果。Linux系统中会根据不同的选项,让不同的命令,可以有不同的表现!指令中那么多选项的由来和起作用的方式。下面有小实例演示:
想实现命令行计数器:
./myproc -a 10 20
10+20=30
./myproc -s 10 20
10-20=-10
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
void usage()
{printf("输入有误,命令使用规则:\n");printf("加法:./myproc -a 参数1 参数2\n");printf("减法:./myproc -s 参数1 参数2\n");
}
int main(int argc,char* argv[])
{if(argc!=4){usage();}else {if(strcmp(argv[1],"-a")==0){int a = atoi(argv[2]);int b =atoi(argv[3]);printf("%d+%d=%d\n",a,b,a+b);}else if(strcmp(argv[1],"-s")==0){int a =atoi(argv[2]);int b =atoi(argv[3]);printf("%d-%d=%d\n",a,b,a-b);}else {usage();}}return 0;
}

回到第一问,main函数可以带几个参数?
可以带三个,一个进程是会被传入环境变量参数的!
#include<stdio.h>
int main(int agrc,char* argv[],char*env[])
{ for(int i = 0;env[i];i++){printf("env[%d]:%s\n",i,env[i]);}return 0;
}

扩展:
一个函数在声明是时候没有带参数,可以给这个函数传参吗?
可以。只有fun(void)传参数才会报错。下面演示:
#include<stdio.h>
void fun()
{prinf("hello world!\n");
}
int main()
{fun(10,29.3,20);return 0;
}

2、通过C语言提供的全局变量获取 - environ
#include<stdio.h>
int main()
{extern char** environ;for(int i =0;environ[i];i++){printf("%d:%s\n",i,environ[i]);}return 0;
}

3、获取环境变量函数 - getenv(const char* name)
查看接口:

#include<stdio.h>
#include<stdlib.h>
int main()
{const char* s = getenv("PATH");printf("%s\n",s);return 0;
}

为什么要获取环境变量?
一定有特殊用途,比如说:程序可以通过获取环境变量,获取用户信息来确定是否有权限执行。
环境变量是谁给的?
1.命令行启动程序父进程都是bash
2.环境变量是会被子进程继承下去的
3.环境变量是全局变量。
所谓的本地变量,本质就是在bash内部定义的变量,不会被子进程继承下去!
Linux下大部分命令都是通过子进程的方式执行的!
但是,还有一部分命令,不通过子进程的方式执行,而是由bash自己执行(调用自己的对应的函数来完成特定的功能),我们把这种命令叫做内建命令。
相关文章:
Linux_进程概念_冯诺依曼_进程概念_查看进程_获取进程pid_创建进程_进程状态_进程优先级_环境变量_获取环境变量三种方式_3
文章目录 一、硬件-冯诺依曼体系结构二、软件-操作系统-进程概念0.操作系统做什么的1.什么叫做进程2.查看进程3.系统接口 获取进程pid- getpid4.系统接口 获取父进程pid - getppid5.系统接口 创建子进程 - fork1、手册2、返回值3、fork做了什么4、基本用法 6.进程的状态1、进程…...
Set A Light 3D Studio中文--- 打造专业级3D照明效果
Set A Light 3D Studio是一款专业的灯光模拟软件,专为摄影师和电影制片人打造。它允许用户在计算机上模拟并预览各种布光效果,助力拍摄出真实、精准且具有艺术感的作品。软件提供了丰富的灯光和场景模型,用户可以灵活调整光源参数,…...
【深度学习】基于机器学习的无机钙钛矿材料形成能预测,预测形成能,神经网络,回归问题
文章目录 任务分析数据处理处理离散数值处理缺失值处理不同范围的数据其他注意事项 我们的数据处理模型训练网页web代码、指导 任务分析 简单来说,就是一行就是一个样本,要用绿色的9个数值,预测出红色的那1个数值。 数据处理 在进行深度数…...
20240321-2-Adaboost 算法介绍
Adaboost 算法介绍 1. 集成学习 集成学习(ensemble learning)通过构建并结合多个学习器(learner)来完成学习任务,通常可获得比单一学习器更良好的泛化性能(特别是在集成弱学习器(weak learner…...
python第三方库的安装,卸载和更新,以及在cmd下pip install安装的包在pycharm不可用问题的解决
目录 第三方库pip安装,卸载更新 1.安装: 2.卸载 3.更新 一、第三方库pip安装,卸载更新 1.安装 pip install 模块名 加镜像下载:pip install -i 镜像网址模块名 常用的是加清华镜像,如 pip install -i https://pyp…...
Python第三次作业
周六 1. 求一个十进制的数值的二进制的0、1的个数 def er(x):a bin(x)b str(a).count("1")c str(a).count("0") - 1print(f"{a},count 1:{b},count 0:{c}")x int(input("enter a number:")) er(x) 2. 实现一个用户管理系统&…...
ai写作软件选哪个?这5款风靡全球的工具不容错过!
从去年到现在,ai 人工智能的发展一直是许多人关注的重点,每隔一段时间新诞生的 ai 工具软件,总会成为人们茶余饭后谈论的焦点。不过在种类繁多的 ai 工具软件中,ai 写作软件是最常被使用的 ai 工具类别,它的使用门槛较…...
信号处理与分析——matlab记录
一、绘制信号分析频谱 1.代码 % 生成测试信号 Fs 3000; % 采样频率 t 0:1/Fs:1-1/Fs; % 时间向量 x1 1*sin(2*pi*50*t) 1*sin(2*pi*60*t); % 信号1 x2 1*sin(2*pi*150*t)1*sin(2*pi*270*t); % 信号2% 绘制信号图 subplot(2,2,1); plot(t,x1); title(信号x1 1*sin(…...
Android Databinding 使用教程
Android Databinding 使用教程 一、介绍 Android Databinding 是 Android Jetpack 的一部分,它允许你直接在 XML 布局文件中绑定 UI 组件到数据源。通过这种方式,你可以更简洁、更直观地更新 UI,而无需编写大量的 findViewById 和 setText/…...
【每日跟读】常用英语500句(200~300)
【每日跟读】常用英语500句 Home sweet home. 到家了 show it to me. 给我看看 Come on sit. 过来坐 That should do nicely. 这样就很好了 Get dressed now. 现在就穿衣服 If I were you. 我要是你 Close your eyes. 闭上眼睛 I don’t remember. 我忘了 I’m not su…...
【Java开发过程中的流程图】
流程图由一系列的图形符号和箭头组成,每个符号代表一个特定的操作或决策。下面是一些常见的流程图符号及其含义: 开始/结束符号(圆形):表示程序的开始和结束点。 过程/操作符号(矩形)ÿ…...
蓝桥杯刷题-day5-动态规划
文章目录 使用最小花费爬楼梯解码方法 使用最小花费爬楼梯 【题目描述】 给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。 你可以选择从下标为 0 或下标为 1 的台阶…...
新概念英语1:Lesson7内容详解
新概念英语1:Lesson7内容详解 如何询问人的个人信息 本课里有两个关于个人信息的问句,一个是问国籍,一个是问工作,句型如下: what nationality are you?询问国籍 回复一般就是我是哪国人,I’m Chinese…...
FASTAPI系列 14-使用JSONResponse 返回JSON内容
FASTAPI系列 14-使用JSONResponse 返回JSON内容 文章目录 FASTAPI系列 14-使用JSONResponse 返回JSON内容前言一、默认返回的JSON格式二、JSONResponse 自定义返回三、自定义返回 headers 和 media_type总结 前言 当你创建一个 FastAPI 接口时,可以正常返回以下任意…...
【版本控制】git使用指南
Git 是一个免费、开源的分布式版本控制系统,最初由 Linus Torvalds 于2005年创建。它旨在管理项目的源代码,并提供了跟踪更改、协作开发、版本控制、分支管理等功能。 一、版本控制概念 版本控制系统(Version Control System,VC…...
Flask 与小程序 的图片数据交互 过程及探讨研究学习
今天不知道怎么的,之前拿编程浪子地作品抄过来粘上用好好的,昨天开始照片突的就不显示了。 今天不妨再耐味地细细探究一下微信小程序wxml 和flask服务器端是怎么jpg图片数据交互的。 mina/pages/food/index.wxml <!--index.wxml--> <!--1px …...
【JavaEE】初识线程,线程与进程的区别
文章目录 ✍线程是什么?✍线程和进程的区别✍线程的创建1.继承 Thread 类2.实现Runnable接口3.匿名内部类4.匿名内部类创建 Runnable ⼦类对象5.lambda 表达式创建 Runnable ⼦类对象 ✍线程是什么? ⼀个线程就是⼀个 “执行流”. 每个线程之间都可以按…...
Kafka高级面试题-2024
Kafka中的Topic和Partition有什么关系? 在Kafka中,Topic和Partition是两个密切相关的概念。 Topic是Kafka中消息的逻辑分类,可以看作是一个消息的存储类别。它是按照不同的主题对消息进行分类,并且可以用于区分和筛选数据。每个…...
Qt——Qt文本读写之QFile与QTextStream的使用总结(打开文本文件,修改内容后保存至该文件中)
【系列专栏】:博主结合工作实践输出的,解决实际问题的专栏,朋友们看过来! 《项目案例分享》 《极客DIY开源分享》 《嵌入式通用开发实战》 《C++语言开发基础总结》 《从0到1学习嵌入式Linux开发》 《QT开发实战》 《Android开发实战》...
掌握Java中的super关键字
super 是 Java 中的一个关键字,它在继承的上下文中特别有用。super 引用了当前对象的直接父类,它可以用来访问父类中的属性、方法和构造函数。以下是 super 的几个主要用途: 1. 调用父类的构造函数 在子类的构造函数中,你可以使…...
第19节 Node.js Express 框架
Express 是一个为Node.js设计的web开发框架,它基于nodejs平台。 Express 简介 Express是一个简洁而灵活的node.js Web应用框架, 提供了一系列强大特性帮助你创建各种Web应用,和丰富的HTTP工具。 使用Express可以快速地搭建一个完整功能的网站。 Expre…...
Docker 离线安装指南
参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性,不同版本的Docker对内核版本有不同要求。例如,Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本,Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...
在软件开发中正确使用MySQL日期时间类型的深度解析
在日常软件开发场景中,时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志,到供应链系统的物流节点时间戳,时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库,其日期时间类型的…...
日语AI面试高效通关秘籍:专业解读与青柚面试智能助攻
在如今就业市场竞争日益激烈的背景下,越来越多的求职者将目光投向了日本及中日双语岗位。但是,一场日语面试往往让许多人感到步履维艰。你是否也曾因为面试官抛出的“刁钻问题”而心生畏惧?面对生疏的日语交流环境,即便提前恶补了…...
练习(含atoi的模拟实现,自定义类型等练习)
一、结构体大小的计算及位段 (结构体大小计算及位段 详解请看:自定义类型:结构体进阶-CSDN博客) 1.在32位系统环境,编译选项为4字节对齐,那么sizeof(A)和sizeof(B)是多少? #pragma pack(4)st…...
23-Oracle 23 ai 区块链表(Blockchain Table)
小伙伴有没有在金融强合规的领域中遇见,必须要保持数据不可变,管理员都无法修改和留痕的要求。比如医疗的电子病历中,影像检查检验结果不可篡改行的,药品追溯过程中数据只可插入无法删除的特性需求;登录日志、修改日志…...
UDP(Echoserver)
网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...
在 Nginx Stream 层“改写”MQTT ngx_stream_mqtt_filter_module
1、为什么要修改 CONNECT 报文? 多租户隔离:自动为接入设备追加租户前缀,后端按 ClientID 拆分队列。零代码鉴权:将入站用户名替换为 OAuth Access-Token,后端 Broker 统一校验。灰度发布:根据 IP/地理位写…...
从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...
k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...
