学习记录——day23 多进程编程

news2025/1/13 7:39:29

目录

一、多进程引入

1.1、引入目的

1.2、进程的概念

1.3、进程的种类

1.4、进程号的概念        

1.5、特殊进程 0号 1号 2号 孤儿 僵尸

1.6、进程的相关命令

        1)查看进程信息的命令:ps             跟不同的选项,执行不同的状态

        2)top/htop       

         3)ptree:展示进程树,可以显示进程的父子关系

        4)查看给定进程的进程号:pidof 进程名

        5)kill:向进程发送信号

1.7、进程的状态

二、 多进程编程

2.1fork进程的创建函数

2.2 进程号的获取   getpid  getppid

2.3进程的退出    exit   _exit

2.4 进程资源的回收     

作业


一、多进程引入

1.1、引入目的

        程序员写程序时,一个程序可能由多个认为组成,如果使用的时单线程,或单任务,那么当该任务执行阻塞时,其他任务就无法执行,必须等到该任务接触阻塞后,才能执行其他任务。

        多线程或多进程。可以解决同一个程序中多个任务并发执行的情况。

1.2、进程的概念

        1)进程时程序的一次执行过程;

        2)进程是程序资源分配的基本单位,系统会给每个进程分配4G的虚拟内存,分为0--3G的用                户空间和3-4G的内核空间,多个进程共享内核空间,用户空间相互独立

        3)进程是一个动态的过程,有生命周期的概念,分为创建态、就绪态、运行态、阻塞态、死                亡态

        4)进程在内核空间中存储在一个名为task struct的结构体中(PCB)

进程描述符:task_struct包含了描述一个进程所需的所有信息。
进程状态:包括运行、就绪、阻塞等状态。
进程标识符:如进程ID(PID)。
进程调度信息:如优先级、调度策略等。
内存管理信息:如虚拟地址空间、页表等。
文件系统信息:如打开的文件、文件系统根目录等。
信号处理:包括待处理信号和信号处理函数。
进程间通信:如消息队列、共享内存等IPC机制相关信息。
时间和定时器:如进程创建时间、CPU使用时间等。
线程信息:在Linux中,线程被视为轻量级进程,也用task_struct表示。

         5)单核cpu处理多任务是,一般使用的是时间片轮询机制

         6)进程宇程序的区别:

                程序时静态的,是存储在磁盘上的二进制代码

                进程是动态的,有生命周期的

        7)进程的组成:进程控制块(PCB)、数据段、程序段

1.3、进程的种类

        进程分为三大类:交互进程、批处理进程、守护进程

        1)交互进程:他是由shell控制,用于直接跟用户进行交互的进程。例如:vim编辑器、文本编辑器

        2)批处理进程:本质上维护了一个队列,被放入队列中的进程会统一被调度。例如gcc编译器的一步到位的编译

        3)守护进程:脱了了终端而存在的进程,随着系统的启动而开始,随着系统的结束而终止。例如:服务进程

1.4、进程号的概念        

        每个进程在系统中都有一个唯一的标识位,用一个整数表示这就是该进程的进程号(PID)

        1、PID(processID):当前进程的进程号

        2、PPID(parent processID):当前进程的父进程的进程号

        3、每个进程都是由其父进程进行拷贝赋值出来的

        4、/proc目录中的每个数字都是现在正在执行的一个进程

1.5、特殊进程 0号 1号 2号 孤儿 僵尸

        1、0号进程:也称其为 idel进程,他是操作系统启动后执行的第一个进程,这个进程也叫空闲进程,当没有其他进程执行时会默认执行该进程。1号进程和2号进程都是由0号进程创建出来的

        2、1号进程:也称init进程,该进程由0号进程产生,主要完成系统创建时一些软件硬件的初始化工作。当其他进程的父进程死亡后,会托管其子进程

        3、2号进程:也称kthreadd,该进程由0号进程产生,也称为调度进程,当某个就绪进程时间片轮到时,该进程负责进程的调度工

        4、孤儿进程:当前进程的父进程死亡后,但是当前进程还没有结束,那么当前进程称为孤儿进程,孤儿进程会由1号进程收养

        5、僵尸进程:当前进程已经死亡,但是其父进程没有为其收尸(回收其进程的资源),那么该进程为僵尸进程

1.6、进程的相关命令

        1)查看进程信息的命令:ps             跟不同的选项,执行不同的状态

                        ps -ef :显示进程之间的关系

UID         PID   PPID  C STIME TTY          TIME CMD
root          1      0  0 七月25 ?     00:00:20 /sbin/init splash
root          2      0  0 七月25 ?     00:00:00 [kthreadd]
root          3      2  0 七月25 ?     00:00:00 [rcu_gp]
root          4      2  0 七月25 ?     00:00:00 [rcu_par_gp]
root          6      2  0 七月25 ?     00:00:00 [kworker/0:0H-kb]
root          9      2  0 七月25 ?     00:00:00 [mm_percpu_wq]
root         10      2  0 七月25 ?     00:00:06 [ksoftirqd/0]
root         11      2  0 七月25 ?     00:01:11 [rcu_sched]
UID:用户ID
PID:当前进程的id号
PPID:当前进程的父进程PID号
C:不用管
STIME、TIME:创建时间
TTY:如果该值为问号,说明不依赖于终端而存在的进程
CMD:进程名称

                 ps -ajx:可显示进程的状态

  PPID    PID   PGID    SID TTY       TPGID STAT   UID   TIME COMMAND
     0      1            1        1      ?            -1 Ss      0   0:20 /sbin/init splash
     0      2            0        0      ?            -1 S        0   0:00 [kthreadd]
     2      3            0        0      ?            -1 I<       0   0:00 [rcu_gp]
     2      4            0        0      ?            -1 I<       0   0:00 [rcu_par_gp]
     2      6            0        0      ?            -1 I<       0   0:00 [kworker/0:0H-kb]

PPID:当前进程的父进程PID号

PID:当前进程的id号

PGID:组id号
SID:会话组id
STAT:当前进程的状态

         ps -aux:可以查看资源使用情况

USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root          1  0.0  0.2 160076  4676 ?        Ss   七月25   0:20 /sbin/init splash
root          2  0.0  0.0      0     0 ?        S    七月25   0:00 [kthreadd]
root          3  0.0  0.0      0     0 ?        I<   七月25   0:00 [rcu_gp]
root          4  0.0  0.0      0     0 ?        I<   七月25   0:00 [rcu_par_gp]
root          6  0.0  0.0      0     0 ?        I<   七月25   0:00 [kworker/0:0H-kb]
%CPU:cpu的占用率
%MEM :内存的占用率

        2)top/htop       

        top:动态显示资源使用情况

top - 11:51:17 up 5 days, 13:55,  1 user,  load average: 0.01, 0.02, 0.00
任务: 327 total,   3 running, 260 sleeping,   0 stopped,   0 zombie
%Cpu(s):  3.5 us,  1.8 sy,  0.0 ni, 94.7 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  2005964 total,    67820 free,  1168168 used,   769976 buff/cache
KiB Swap:   969960 total,    88160 free,   881800 used.   654624 avail Mem 

进程 USER      PR  NI    VIRT    RES    SHR � %CPU %MEM     TIME+ COMMAND                                                          
  1872 ubuntu    20   0  640144  59872   5056 S  4.0  3.0  12:54.43 Xorg                                                             
  2057 ubuntu    20   0 3057424 149072  31884 S  3.0  7.4  27:58.69 gnome-shell                                                      
 89961 ubuntu    20   0  949248  69268  23020 S  2.7  3.5   3:17.13 terminator                                                       
  2193 ubuntu    20   0  809364   5568   2120 S  0.3  0.3   2:22.89 gsd-color                                                        
111256 ubuntu    20   0   51380   4456   3616 R  0.3  0.2   0:00.21 top                                                              
     1 root      20   0  160076   4676   2652 S  0.0  0.2   0:20.90 systemd                                                          
     2 root      20   0       0      0      0 S  0.0  0.0   0:00.02 kthreadd     

        htop:动态显示资源使用情况(彩色)

         3)ptree:展示进程树,可以显示进程的父子关系

        4)查看给定进程的进程号:pidof 进程名

        5)kill:向进程发送信号

                        格式: kill -信号名(号)     进程号

                        能够发送的信号号有:可以通过指令 kil -查看

 1) SIGHUP     2) SIGINT     3) SIGQUIT     4) SIGILL     5) SIGTRAP
 6) 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
21) SIGTTIN    22) SIGTTOU    23) SIGURG    24) SIGXCPU    25) SIGXFSZ
26) SIGVTALRM    27) SIGPROF    28) SIGWINCH    29) SIGIO    30) SIGPWR
31) SIGSYS    34) SIGRTMIN    35) SIGRTMIN+1    36) SIGRTMIN+2    37) SIGRTMIN+3
38) SIGRTMIN+4    39) SIGRTMIN+5    40) SIGRTMIN+6    41) SIGRTMIN+7    42) SIGRTMIN+8
43) SIGRTMIN+9    44) SIGRTMIN+10    45) SIGRTMIN+11    46) SIGRTMIN+12    47) SIGRTMIN+13
48) SIGRTMIN+14    49) SIGRTMIN+15    50) SIGRTMAX-14    51) SIGRTMAX-13    52) SIGRTMAX-12
53) SIGRTMAX-11    54) SIGRTMAX-10    55) SIGRTMAX-9    56) SIGRTMAX-8    57) SIGRTMAX-7
58) SIGRTMAX-6    59) SIGRTMAX-5    60) SIGRTMAX-4    61) SIGRTMAX-3    62) SIGRTMAX-2
63) SIGRTMAX-1    64) SIGRTMAX    

共计62个

前32个属于稳定信号

SIGHUP
        当进程所在的终端关闭时,该终端会向运行在该终端上的所有进程发送该信号,让其结束进程

SIGINT

        当终端键入 ctrl+c时,终端向指定进程发送的就是该信号,表示中断进程

SIGOUIT

        当终端键入 ctrl + \时,表示终端要终止进程的结束

SIGILL

        当进程自己发生非法操作时,内核空间会发送该信号

SIGKILL

        杀死进程

SIGUSR1、SIGUSR2

        没有特殊的含义,留给程序员使用

SIGSEGV

        表示指针访问越界时的段错误

SIGPIPE

        当操作管道文件时,如果管道的读端被关闭,写端继续写的话,就会出现管道破裂

SIGALRM

        当启动一个定时器,并且定时器超时时,会发送该信号

SIGHCHLD

        当一个进程的子进程退出时,会向该进程的父进程发送该信号,表示让其为子进程收尸

SIGCONT

        该信号表示让暂停的进程继续执行

SIGSTOPSIGSTP

        表示让一个进程暂停,当用户从键盘上键入 ctrl +z时,就会发送该信号

1.7、进程的状态

        1)主要状态有五个:创建态、就绪态、运行态、阻塞态、死亡态

        2)程序中的进程状态显示:可以通过man ps查看

主状态:
               D    不可中断的休眠态 (usually IO)
               R    运行态 (on run queue)
               S    可中断的休眠态 (waiting for an event to complete)
               T    暂停态,会给出作业号进行控制
               t    程序调试时的暂停态
               W    已经弃用
               X    死亡态 (should never be seen)
               Z    僵尸态
附加态:                              
               <    高优先级的进程 (not nice to other users)
               N    低优先级的进程 (nice to other users)
               L    锁到内存中的进程 (for real-time and custom IO)
               s    会话组组长,默认为当前终端
               l    包含多线程的进程 (using CLONE_THREAD, like NPTL pthreads do)
               +    表示是前台运行的进程
 

二、 多进程编程

2.1fork进程的创建函数

1)在进程的创建过程,其实就是通过拷贝父进程的lask stucl结构体而来的,子进程中保存了大部分的父进程的遗传基因(内容一致),只需要修改少部分的内容,如子进程的进程号,子进程的父进程号

2)子进程和父进程的资源用户空间是完全独立的,创建出子进程后,父子进程的资源相互独立,互不影响

3)进程的创建,通过fork函数完成

4)当子进程创建后,会跟父进程一起执行fork后面的语句

       #include <sys/types.h>
       #include <unistd.h>

       pid_t fork(void);
    功能:拷贝父进程得到子进程
    参数:无
    返回值:成功时,父进程中返回子进程的pid号,子进程中返回0,失败返回-1并置位错误                    码

例1   不使用返回值

 创建出的子进程跟父进程没有先后执行的顺序,遵循时间片轮询机制

例2   使用返回值

#include <myhead.h>
int main(int argc, char const *argv[])
{
    pid_t pid = -1;  //定义变量存储 pid 号

    pid = fork();   //获取pid

    if (pid > 0)
    {
        while (1)
        {
            printf("父进程\n");
            sleep(1);
        }
    }
    else if (pid == 0)
    {
        while (1)
        {
            printf("子进程\n");
            sleep(1);
        }
    }

    sleep(1);

    return 0;
}

2.2 进程号的获取   getpid  getppid

       #include <sys/types.h>
       #include <unistd.h>

       pid_t getpid(void);
       功能:获取当前进程的进程号
       参数:无
       返回值:当前进程的pid
       pid_t getppid(void);
       功能:获取当前进程的父进程的pid号
       参数:无
       返回值:当前进程父进程的pid
 

2.3进程的退出    exit   _exit

       #include <sys/types.h>
       #include <unistd.h>

       pid_t getpid(void);
       功能:获取当前进程的进程号
       参数:无
       返回值:当前进程的pid
       pid_t getppid(void);
       功能:获取当前进程的父进程的pid号
       参数:无
       返回值:当前进程父进程的pid

2.4 进程资源的回收     

       #include <sys/types.h>
       #include <sys/wait.h>

       pid_t wait(int *wstatus);
       功能:阻塞回收子进程的资源,如果没有进程退出,那么就阻塞等待
       参数:子进程退出时的状态,一般不接收,直接填NULL即可
       返回值:成功返回回收的子进程的pid,失败返回-1并置位错误码
       

       pid_t waitpid(pid_t pid, int *wstatus, int options);
       功能:既可以阻塞也可以非阻塞形式回收僵尸进程
       参数1:要回收的进程号
               >0:表示回收具体的某个进程
               =0:能够回收当前进程所在的进程组中的任意一个子进程
               =-1:回收任意一个子进程
               <-1: 回收别的进程组(进程组id为给定的pid的绝对值)中的任意一个子进程
        参数2:子进程退出时的状态,一般不接收,直接填NULL即可
        参数3:表示是否阻塞回收僵尸进程
                0:表示阻塞
                WNOHANG:表示非阻塞
        返回值:成功返回回收的子进程的pid,失败返回-1并置位错误码

#include<myhead.h>

int main(int argc, const char *argv[])
{
    //定义进程号
    pid_t pid = fork();     //创建一个子进程

    //判断父子进程
    if(pid > 0)
    {
        printf("我是父进程:pid = %d, 当前进程的id为:%d,当前进程的父进程的id为:%d\n",\
                pid, getpid(), getppid());


    }else if(pid == 0)
    {
        printf("我是子进程:pid = %d,当前进程的pid为:%d, 当前进程的父进程pid为:%d\n",\
                pid, getpid(), getppid());

        sleep(3);          //休眠3秒

        //退出子进程
        //exit(EXIT_SUCCESS);         //exit(0);
        _exit(EXIT_SUCCESS);         //exit(0);
    }else
    {
        perror("fork error");
        return -1;
    }


    //回收子进程资源
    //wait(NULL);
    //waitpid(-1, NULL, 0);       //阻塞回收
    sleep(5);
    waitpid(-1, NULL, WNOHANG);       //非阻塞回收
    
    printf("回收子进程资源结束\n");
    while(1);

    return 0;
}

作业

#include <myhead.h>

#define N 128
char buf[N] = {0};

int main(int argc, char const *argv[])
{
    pid_t pid;
    int len,size, o_file, n_file;
    if (argc != 3)
    {
        printf("终端输入数不正确\n");
        return -1;
    }

    umask(0000);  //置位掩码

    if ((o_file = open(argv[1], O_RDONLY)) == -1)
    {
        perror("open");
        exit(-1);
    }

    n_file = open(argv[2], O_RDWR | O_CREAT | O_TRUNC, 0664);
    if (n_file == -1)
    {
        perror("open");
        exit(-1);
    }

    size = lseek(o_file, 0, SEEK_END);  //得到源文件大小
    if (size < 0)
    {
        perror("lseek");
        exit(-1);
    }

    size /= 2;   //取一半的大小

    close(o_file);
    close(n_file);

    pid = fork();  //子程序创建
    if (pid < 0)
    {
        perror("fork");
        exit(-1);
    }
    else if (0 == pid)  //子程序执行
    {
        o_file = open(argv[1], O_RDONLY);
        if (o_file < 0)
        {
            perror("c open1");
            exit(-1);
        }

        n_file = open(argv[2], O_WRONLY);
        if (n_file < 0)
        {
            perror("c open2");
            exit(-1);
        }

        lseek(o_file, size, SEEK_SET);  //光标定位到一半的位置
        lseek(n_file, size, SEEK_SET);

        //拷贝后一半
        while ((len = read(o_file, buf, N)) > 0)
        {
            write(n_file, buf, len);
        }

        close(o_file);
        close(n_file);
    }
    else  //父程序执行
    {
        o_file = open(argv[1], O_RDONLY);
        if (o_file < 0)
        {
            perror("f open1");
            exit(-1);
        }

        n_file = open(argv[2], O_WRONLY);
        if (n_file < 0)
        {
            perror("f open2");
            exit(-1);
        }

        //拷贝前一半
        while (size > 0)
        {
            if (size > N)
            {
                write(n_file, buf, read(o_file, buf, N));
                size -= N;
            }
            else
            {
                write(n_file, buf, read(o_file, buf, size));
                break;
            }
        }

        close(o_file);
        close(n_file);
    }

    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1964058.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

springboot的轻量替代框架-Solon

Java之所以是广泛使用的编程语言&#xff0c;不仅仅因为其具有跨平台性、面向对象、可靠性&#xff0c;还有很重要的一点是强大的生态系统&#xff0c;spring家族的一系列框架&#xff0c;对Java的崛起有着不可忽视的作用。 学Java的不可能不知道Spring&#xff0c;今天给大家…

品致差分探头和泰克差分探头的优势和特点分析

品致差分探头和泰克差分探头各有其独特的优势和特点&#xff0c;选择哪个更好主要取决于具体的应用场景、测试需求以及预算等因素。以下是对两个品牌差分探头的详细比较&#xff1a; 品致差分探头优势与特点&#xff1a; 高精度测量&#xff1a;品致差分探头具有高精度的测量…

docker(一):Develop faster. Run anywhere.

前言 在进行微服务部署时&#xff0c;首先需要进行部署环境的搭建。目前&#xff0c;Docker 已经成为了微服务部署的主流解决方案之一。Docker 可以帮助我们更快地打包、测试以及部署应用程序&#xff0c;从而缩短从编写到部署运行代码的周期。 在本文中&#xff0c;我们将对…

ChatGPT的高级语音功能“Her”终于上线啦!!

ChatGPT版“Her”突然开放&#xff0c;第一批体验报告来了&#xff01;用户们已经疯狂 刚刚&#xff0c;万众期待的GPT-4o语音功能&#xff0c;也就是被称为“Her”的功能&#xff0c;终于开始向用户陆续开放&#xff01; OpenAI官方推特表示&#xff0c;选中的Alpha用户们将在…

快速部署私有化大模型 毕昇(使用docker-compose方式)

docker安装 1. # Linux系统安装docker&#xff0c;以CentOS/RHEL为例&#xff0c;其他操作系统请参考docker官方安装方法 # 如果已经安装过docker 期望重装&#xff0c;先卸载 sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \d…

【Vue】权限控制

权限管理 分类&#xff1a; 页面权限功能(按钮)权限接口权限 vue3-element-admin 的实现方案 一般我们在业务中将 路由可以分为两种&#xff0c;constantRoutes 和 asyncRoutes。 constantRoutes&#xff1a; 代表那些不需要动态判断权限的路由&#xff0c;如登录页、404(或…

机器学习算法——常规算法,在同的业务场景也需要使用不同的算法(二)

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;开发者-曼亿点 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 曼亿点 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a…

新兴材料中载流子迁移率的霍尔效应测量

这篇文章是发表在《自然电子学》&#xff08;Nature Electronics&#xff09;2024年7月刊上的一篇评论文章&#xff0c;标题为“Reporting Hall effect measurements of charge carrier mobility in emerging materials”&#xff0c;作者是Vladimir Bruevich和Vitaly Podzorov…

数据仓库及数仓架构概述

往期推荐 大数据HBase图文简介-CSDN博客 数仓常见名词解析和名词之间的关系-CSDN博客 目录 0. 前言 0.1 浅谈维度建模 0.2 数据分析模型 1. 何为数据仓库 1.1 为什么不直接用业务平台的数据而要建设数仓&#xff1f; 1.2 数据仓库特征 1.3 数据仓库和数据库区别 1.4 以…

LLM 各种技巧| Prompt Engineering 大总结|指南

LLM 各种技巧| Prompt Engineering 大总结|指南 截止至今&#xff0c;关于LLM 的优化与技巧层出不穷&#xff0c;几乎每个月都有新的技术和方法论被提出&#xff0c;因此本篇主要是要介绍在各种不同情境下&#xff0c;LLM 的各种Prompt Engineering 技巧&#xff0c;每篇都有附…

数据结构经典测试题5

1. int main() { char arr[2][4]; strcpy (arr[0],"you"); strcpy (arr[1],"me"); arr[0][3]&; printf("%s \n",arr); return 0; }上述代码输出结果是什么呢&#xff1f; A: you&me B: you C: me D: err 答案为A 因为arr是一个2行4列…

使用AWS CDK构建生产级VPC基础设施指南

简介 虽然有很多关于AWS的信息&#xff0c;但实际如何将这些服务投入生产使用&#xff0c;还是需要自己思考。本文将介绍我们是如何思考并实施这些工作的。 目前有很多AWS环境构建的方法&#xff0c;但在这里我们将使用AWS CDK进行说明。 ※ 本文不会涉及CDK的基本操作方法或…

Java每日一练,技术成长不间断

目录 题目1.下列关于继承的哪项叙述是正确的&#xff1f;2.Java的跨平台特性是指它的源代码可以在多个平台运行。&#xff08;&#xff09;3.以下 _____ 不是 Object 类的方法4.以下代码&#xff1a;5.下面哪个流类不属于面向字符的流&#xff08;&#xff09;总结 题目 选自牛…

AI系统测试方法|变异测试的流程及优化技术

变异测试是AI系统测试中较为常见的一种测试方法。通过引入人工制造的缺陷来评估系统的健壮性。在AI系统测试实践中&#xff0c;变异测试解决了对测试套件进行有效性和充分性评估的难题。本文将重点探讨变异测试在AI系统测试中的执行流程&#xff0c;呈现一个完整的测试框架&…

Apple intelligence 正式开启测试!第一波文本工具测试体验来啦!

Apple Intelligence 开启测试了&#xff01;苹果带着它的人工智能走进现实了&#xff01; 但是&#xff0c;坏消息是&#xff0c;目前Apple Intelligence仅支持美国地区使用美英语言的开发者账户使用&#xff0c;国行的小伙伴不要急着更新了。 本次测试内容为WWDC2024预告中公布…

PTA 6-2 多项式求值

6-2 多项式求值&#xff08;15分&#xff09; 本题要求实现一个函数&#xff0c;计算阶数为n&#xff0c;系数为a[0] ... a[n]的多项式 在x点的值。 函数接口定义&#xff1a; double f( int n, double a[], double x ); 其中n是多项式的阶数&#xff0c;a[]中存储系数&…

【Qt】QWidget的windowOpacity属性 cursor属性 font属性

一.windowOpacity属性 1.概念&#xff1a; windowOpacity属性是Qt中QWindow类的一个属性。它用于设置窗口的不透明度&#xff08;透明度&#xff09;。 窗口的不透明度值范围是0.0到1.0之间&#xff0c;其中0.0表示完全透明&#xff0c;1.0表示完全不透明。默认情况下&#…

Python科研数据可视化教程

原文链接&#xff1a;Python科研数据可视化教程https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247609609&idx4&sn8629ee10544f43b46993694d929843d0&chksmfa826ceecdf5e5f8ca4fbc72104c3488d5c53c0735f41f393c9a494aceddf2b93c8eb5622813&token214…

部署一个nodejs项目+配置server

1.jdk环境 tomcat服务器需要jdk环境 版本对应 ​ tomcat9>jdk1.8 ​ tomcat10>jdk17 配置系统变量JAVA_HOME 2.nginx平滑升级&#xff0c;不停服务升级nginx服务器&#xff0c;1.26.1升级到1.27.0 3.负载均衡&#xff0c;使用nginx管理后端服务器&#xff0c;…

基础复习(IO流)

1.File类 创建对象 File f1 new File("D:/resource/ab.txt"); File f2 new File("D:\\resource\\abc.txt"); 基础方法 创建与删除方法 1、public boolean createNewFile()&#xff1a;创建一个新文件&#xff08;文件内容为空&#xff09;&#xff0c;…