最新资讯

  • 【Linux】Linux编程中最常用的控制线程的函数(内附手绘底层逻辑图 通俗易懂)

【Linux】Linux编程中最常用的控制线程的函数(内附手绘底层逻辑图 通俗易懂)

2025-04-30 22:00:03 0 阅读

绪论​

每日激励:“不设限和自我肯定的心态:I can do all things。 — Stephen Curry”

绪论​:
本章是继承上一章线程基础,本章将结合代码和逻辑图的方式带你去认识和了解控制线程中常用的函数这些函数对后面的开发以及对线程底层的了解都非常的重要,后续将继续更新Linux线程的更多知识,敬请期待吧~
————————
早关注不迷路,话不多说安全带系好,发车啦(建议电脑观看)。

1. 线程控制的函数:

1.1创建线程:pthread_create:

头文件:
#include 
int pthread_create(pthread_t *thread, 
const pthread_attr_t *attr,
void *(*start_routine) (void *), void *arg);

参数:

  1. thread:线程id(类似于进程的pid,输出型)
  2. attr:线程的属性(暂时不管统一写成nullptr)
  3. start_routine:函数指针,他的类型是void*( * )(void*),代表多线程执行的函数(自己自定义他的任务)
  4. arg:是用来给第三个函数指针传参数的 (因为其类型是void*所以我们可以传递任意类型进去!(包括传递对象))

Linux中本质是没有线程的,只有轻量级进程的概念,所以Linux OS只会提供轻量级进程创建的系统调用,不会直接提供线程的创建接口
在学习操作系统时只学过操作系统中的线程,没有学过Linux中轻量级进程(LWP)概念的人也能正常的使用,就必须得在操作系统和用户之间重新在写一个pthread原生线程库让所有人都能正常使用通过线程,而底层其实是轻量级进程。

既然他是一个第三方库,那在编译时就需要接入外部库,通过-l附加指令(-l库名字)
所以通过编译器g++,需要附加:-lpthread引入线程库

注:其中如何传参给第三个参数的函数:
这个函数的参数类型是void*,也就表示能接受任何类型,在内部使用时进行强转即可。

练习证明线程的健壮性低

使用上面函数 以及 证明一个线程崩溃会影响所有线程崩溃:
代码:

#include
#include
#include
#include
#include
#include
using namespace std;

using func_t = function<void()>;//function创建了一个接收函数签名void()的包装器类型,他能接收该类型的函数(void:返回值,():函数没有参数)


//创建一个对象,其中包含了线程名,线程创建的时间,该线程所要执行的函数
class ThreadData
{
public:
    ThreadData(const string& name,const uint64_t & ctime,func_t f)
    :threadname(name),createtime(ctime),func(f)
    {}

public:
    string threadname;//线程名
    uint64_t createtime;//创建时间
    func_t func;//接收函数(void())的包装器
};


void* ThreadRountine(void*arg)//创建一个线程后调用的函数,其中arg是参数,通过第四个参数传递进来
{ 
    ThreadData* td = static_cast<ThreadData*>(arg);//进行类型的强转成,对象
    while(true)
    {
        td->func();//对象中存着,真的调用的函数!

        cout << "threadname: "<< td->threadname << " create time: "<< td->createtime  <<endl;//通过对象访问成员变量
        sleep(1);

        if(td->threadname == "thread-4")//在4号进处出产生信号,观察情况
        {
            cout << td->threadname << " create exeption" << endl;
            int i = 1;
            i /= 0;//让4号线程进来时发生除零异常导致崩溃看看是否会影响 
        }
    }
}

void Print()
{
    cout << "I am Thread of part: ";
}
const int cnt = 5;
int main()
{
    cout << "main thread" << endl;

    for(int i = 0; i < cnt ;i++)//主线程循环多次,创建多个线程
    {
        sleep(1);
        char tname[64];
        snprintf(tname,sizeof(tname),"%s-%d","thread",i);//让每个下标对应一个进程名tname

        ThreadData* td = new ThreadData(tname,(uint64_t)time(nullptr),Print);//创建一个对象,并初始化
        //time函数获取当前时间(传递空)
        pthread_t tid;
        pthread_create(&tid,nullptr,ThreadRountine,td);//创建进程
    }    

    while(true)
    {
        sleep(10);
    }

    return 0;
}

最终结果如下图(4号线程崩溃导致所有线程崩溃):

1.2 获取线程id:pthread_self

头文件:
#include 
pthread_t pthread_self(void);

实操代码:

using func_t = function<void()>;

string ToHex(pthread_t tid)
{
    char id[64];
    snprintf(id,sizeof(id),"0x%lx",tid);
    return id;
}

void* ThreadRountine(void*arg)
{ 
    string threadname = static_cast<const char*>(arg);
    while(true)
    {
        cout << "new thread name: "<< threadname << " thread id: "<< ToHex(pthread_self()) <<endl;
        sleep(1);
    }
}

int main()
{
    pthread_t tid;
    pthread_create(&tid,nullptr,ThreadRountine,(void*)"thread-1");

    while(true)
    {
        cout << "main thread , sub thread " << tid << " main thread id: "<< ToHex(pthread_self())<<endl;
        sleep(1);
    }
    return 0;
}

最终结果如下图:

其中不难发现线程id值非常大,把它通过自定义函数ToHex转成十六进制来看,发现它很像一个地址,那他是地址吗?

再通过ps -aL查看线程的LWP发现和线程id并不一样?

上述两问题,我们继续往下看,后面通过底层分析解释(因为内容较多,见2.线程id和LWP到底是什么)。

1.3 线程的终止

1. 默认情况下,线程跑完后就会终止

string ToHex(pthread_t tid)
{
    char id[64];
    snprintf(id,sizeof(id),"0x%x",tid);
    return id;
}

void* ThreadRountine(void*arg)
{ 
    string threadname = static_cast<const char*>(arg);
    int cnt = 5;
    while(cnt--)
    {   
        cout << "new thread name: "<< threadname << " thread id: "<< ToHex(pthread_self()) <<endl;
        sleep(1);
    }
    return nullptr;
}

int main()  
{
    pthread_t tid;
    pthread_create(&tid,nullptr,ThreadRountine,(void*)"thread-1");

    while(true)
    {
        cout << "main thread , sub thread " << ToHex(tid) << " main thread id: "<< ToHex(pthread_self())<<endl;
        sleep(1);
    }
    return 0;
}

其中注意的是:exit(int)是用来终止的进程(不能作为线程的一种),否则整个进程都会被终止!

2. 用pthread_exit 终止线程

头文件:#include

void* ThreadRountine(void*arg)
{ 
    string threadname = static_cast<const char*>(arg);
    int cnt = 5;
    while(cnt--)
    {   
        cout << "new thread name: "<< threadname << " thread id: "<< ToHex(pthread_self()) <<endl;
        sleep(1);
    }
    // return nullptr;
    pthread_exit(nullptr);
}

这里替代上面代码中的同位置函数即源码

1.4 线程的返回

  1. 线程返回的时候默认是要被等待的
  2. 进程直接退出,没有等待线程的话,会导致类似进程的僵尸问题

那么就继续引出下面等待函数

1.4.1 线程等待的函数:

头文件:#include

int pthread_join(pthread_t thread,
 void **retval);
  1. thread:线程的id
  2. retval:一个输出型参数,用于获取线程的返回值(该参数得到线程返回值 void*,外部要得到就得使用void**),也就是等待后其参数二会接收来自对应线程的返回值

返回值:如果等待成功返回0,失败则返回错误码

using func_t = function<void()>;//包装器

string ToHex(pthread_t tid)
{
    char id[64];
    snprintf(id,sizeof(id),"0x%x",tid);
    return id;
}

void* ThreadRountine(void*arg)
{ 
    string threadname = static_cast<const char*>(arg);
    int cnt = 5;
    while(cnt--)
    {   
        cout << "new thread name: "<< threadname << " thread id: "<< ToHex(pthread_self()) <<endl;
        sleep(1);
    }
    return (void*)"thread-done";//返回的是这个字符串常量的起始地址
    // pthread_exit(nullptr);
}

int main()  
{
    pthread_t tid;
    pthread_create(&tid,nullptr,ThreadRountine,(void*)"thread-1");


    cout << " main thread id: "<< ToHex(pthread_self())<<endl;

    sleep(8);
    void* ret = nullptr;
    int n = pthread_join(tid,&ret);
    cout << "main thread get new thread return: " << (const char*)ret <<endl;//获取线程的返回值,并打印
    
    return 0;
}

返回用ret接收,因为其类型是void*,进行强转为const char打印出来。

同理因为返回的是void
所以可以返回的任意类型的(包括对象),外部使用强转回来即可使用。

1.5 线程的状态

  1. joinable状态:线程默认为joinable的主线程会在pthread_join处阻塞式的等待线程
  2. 分离状态:就不用等待了主线程就不用管线程,线程运行结束就自动退出了。(不等待)

状态可以理解成:一个家庭,家庭成员他们相互有关也就是joinable的(你的事情父母会管),而分离状态也就也就相当于儿子和父母的关系不好分家了,他们就互不关心了(资源隔离)。
不过线程再怎么分离,资源还是多线程共用的,一个线程出问题别的线程也会出错。


那么状态的不同就引出了不同的情况,也就引出了不同状态时使用的不同函数


1.5.1 线程分离的函数:

头文件:#include

int pthread_detach(pthread_t thread);

该函数可以在线程内使用,也可以直接在主线程内使用(参数指定要分离的线程id)。

实操查看线程的两种状态(分离和等待)
void* ThreadRountine(void*arg)
{ 
    pthread_detach(pthread_self());
    int cnt = 5;
    while(cnt--)
    {   
        cout << "new thread runing... "<<endl;
        sleep(1);
    }
    return nullptr;
}


int main()  
{
    pthread_t tid;
    pthread_create(&tid,nullptr,ThreadRountine,(void*)"thread-1");
    
    sleep(1);
    int n = pthread_join(tid,nullptr);
    cout << "main thread get new thread return: " << n <<endl;
    
    return 0;
}

其中返回错误码 22 是通用的错误代码,在不同的编程语言、系统或环境中可能有不同的含义。通常,它对应的描述是 Invalid argument(无效参数)。

通过上图,可以发现打印好像出了点问题,但其实本质就体现了线程的分离状态,线程和主进程分离了,也就形成了异步执行打印的操作,这样才出来点问题。

让我们继续看不分离的状态,也就是joinable状态(默认就是,所以注释分离函数即可)

void* ThreadRountine(void*arg)
{ 
    // pthread_detach(pthread_self());
    int cnt = 5;
    while(cnt--)
    {   
        cout << "new thread runing... "<<endl;
        sleep(1);
    }
    return nullptr;
}


int main()  
{
    pthread_t tid;
    pthread_create(&tid,nullptr,ThreadRountine,(void*)"thread-1");
    sleep(1);
    pthread_detach(tid);

    int n = pthread_join(tid,nullptr);
    cout << "main thread get new thread return: " << n <<endl;
    
    return 0;
}

1.6 取消(终止)线程函数pthread_cancel

头文件:#include

int pthread_cancel(pthread_t thread);

成功返回0,反之返回错误码

  1. 取消后等待的退出码结果是-1(-1就表明线程是被取消掉的)

    线程通过调用pthread_cancel异常终止,retval(pthread_join的第二个参数)所指向的单元里存放的是常量PTHREAD_CANCELED

  2. 线程如果是被分离的,该线程仍可以被pthread_cancel取消,但不能被pthread_join等待。

    并且主线程也是能取消的,取消后主线程内的代码将不会被执行。

2. 线程的id和LWP到底是什么?

首先了解线程中的概念:

  1. Linux中所有的线程接口都不是系统直接提供的接口,而是原生线程库pthread提供的接口
  2. 每个操作系统的任意版本都必须默认配备一个该库,否则多线程在LInux下跑步起来。

线程和系统的关系

  1. 用户成若有5个线程,那么本质上就是在内核系统中就会有5个LWP

  2. Linux的线程一般称为用户级线程(因为本质线程只是在用户层实现,底层是轻量级进程)

  3. 对此所有线程(轻量级进程)都需要被管理,所以在中间的pthread库也需要能管理系统中的LWP(上图)

这样我们就能知道:

其实线程的id本质是原生库中的概念,而LWP是系统底层的概念,在Linux下在内核态和用户态见有一个线程库(他本质是为了给没学过LWP的人也能方便的使用的),其中线程库中有他自己的id(并且线程库是能找到对应线程tcb的),而底层使用的就是LWP,也就是通过id找到对应的tcb(id只是用于找到对应的tcb的他其实用的就是LWP),详细见3.2。

3.底层系统调用细节

线程的独立属性:

  1. 上下文(寄存器中存储)
  2. 栈结构,只有一个栈(只有一套寄存器),但有多个堆

3.1 创建轻量级进程

头文件:
#include 
int clone(int (*fn)(void *), void *child_stack,
                 int flags, void *arg, ...);
  1. fn:是所要执行的方法(回调函数)
  2. child_stack:是申请所要使用的栈的空间地址(允许用户传入栈空间)
  3. flag:用来区分创建的是进程还是轻量级进程
  4. arg:是用来给第一个函数传参的

pthread创建线程的本质就是通过函数clone创建的:
也就表示

  1. pthread_create()的底层是封装了clone的
  2. clone它同样也是fork的底层。


child_stack可以通过malloc来申请空间,所以每个新线程的栈都是在库中维护,其中线程库在内存共享区有指向自己的栈空间的地址变量。而默认地址空间的栈,由主线程使用。


3.2 如何理解pthread库来管理线程


一个操作系统可能有多个进程,而这些进程他们所使用的都是同一个相同的库,所以称他为共享的!

并且线程是在用户地址空间也就是共享区(内存映射段,不了解的可以搜一下内存模型,如下图)

其中mmap区就是在内存映射段的(存储着线程库)


mmap区域的动态库中就包含有线程库,其中当一个线程的创建就会再动态库中创建一个线程的属性集:

struct pthread会存着线程的属性:

  1. 线程的内部存储
  2. 线程栈会指向一块自己的空间

线程的创建和管理通常由线程库(如 pthread)抽象化实现,底层依赖于 clone 系统调用。使用 clone 创建线程时,需要提供用户函数(线程执行的函数)、栈地址和一组标志位,这些标志位决定了线程之间共享的资源(如地址空间、文件描述符等)。线程的属性集由线程库维护,底层 clone 系统调用完成轻量级进程的创建。

当线程完成执行时,可以通过返回一个 void* 值向调用方传递结果。通过调用 pthread_join,可以等待线程完成,并获取其返回值。线程库维护一个类似数组的结构,用于存储每个线程的属性集(如线程 ID、栈地址、返回值等)。线程 ID(tid)可作为索引,用于高效管理和调度线程。

每个线程的属性集可以看作数组中的一个元素。线程库在底层以动态数组的形式维护这些属性集,随着线程的创建,不断扩展数组结构,以便支持更多的线程。
具体如下图(类似于数组的底层):

所以我们所用的线程id,它就是线程属性集合在库中的地址(每个属性集的起始地址)!!!所以pthread_join通过线程id就能很好的拿到想要拿到的线程的数据。

LWP和线程id不一样是因为:LWP是内核的概念,而tid是线程库里的概念(人们不用理解LWP)。


本章完。预知后事如何,暂听下回分解。

如果有任何问题欢迎讨论哈!

如果觉得这篇文章对你有所帮助的话点点赞吧!

持续更新大量Linux细致内容,早关注不迷路。

本文地址:https://www.vps345.com/6423.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 javascript 前端 chrome edge 进程 操作系统 进程控制 Ubuntu 科技 ai java 语言模型 人工智能 个人开发 自然语言处理 python MCP ssh 阿里云 网络 网络安全 网络协议 llama 算法 opencv 神经网络 ubuntu deepseek Ollama 模型联网 API CherryStudio RTSP xop RTP RTSPServer 推流 视频 rust http 开发语言 harmonyos 华为 typescript 计算机网络 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse 数据库 centos oracle 关系型 安全 分布式 运维开发 云原生 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn cuda cudnn anaconda 面试 性能优化 jdk intellij-idea 架构 Dell R750XS 华为云 物联网 Windsurf 嵌入式硬件 单片机 c++ 温湿度数据上传到服务器 Arduino HTTP udp unity 机器学习 macos 向日葵 学习 tcp/ip uni-app 编辑器 鸿蒙 鸿蒙系统 前端框架 php android ESXi spring boot websocket pycharm ide pytorch ollama 大模型 mac YOLO efficientVIT YOLOv8替换主干网络 TOLOv8 ssl ESP32 深度学习 目标检测 计算机视觉 golang 后端 WSL2 HarmonyOS Next HCIE 数通 开源 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 nginx dubbo ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 命名管道 客户端与服务端通信 node.js json html5 firefox kubernetes 容器 学习方法 经验分享 程序人生 asm numpy GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 github 创意 社区 flutter Hyper-V WinRM TrustedHosts vue3 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 camera Arduino 电子信息 统信UOS 麒麟 bonding 链路聚合 flask AI编程 AIGC adb debian PVE c# iot cpu 内存 实时 使用 vim wireshark 测试工具 信息与通信 windows docker yum Cookie C语言 AI Agent conda ipython vscode apache ue4 着色器 ue5 虚幻 mongodb YOLOv8 NPU Atlas800 A300I pro asi_bench fpga开发 react.js 前端面试题 持续部署 chatgpt jenkins maven svn 自动化 kylin express UOS 统信操作系统 redis mybatis tcpdump mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 llama3 Chatglm 开源大模型 transformer 深度优先 图论 并集查找 换根法 树上倍增 计算机外设 课程设计 大数据 jupyter pip AI大模型 程序员 prometheus ffmpeg 音视频 Linux 进程信号 部署 服务器配置 跨域 笔记 firewalld 智能路由器 dell服务器 vue 电脑 .net 中间件 web安全 可信计算技术 安全架构 网络攻击模型 ollama下载加速 mysql n8n 工作流 workflow asp.net大文件上传 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 生物信息学 银河麒麟服务器操作系统 系统激活 tomcat devops springboot matplotlib sql KingBase 博客 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 工业4.0 微信小程序 小程序 oceanbase rc.local 开机自启 systemd 微服务 springcloud 蓝耘科技 元生代平台工作流 ComfyUI 负载均衡 ping++ ddos iBMC UltraISO llm c语言 qt stm32项目 stm32 智能手机 NAS Termux Samba 嵌入式 linux驱动开发 arm开发 弹性计算 云服务器 裸金属服务器 弹性裸金属服务器 虚拟化 postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 zotero WebDAV 同步失败 代理模式 agi 软件需求 mcu ocr IIS服务器 IIS性能 日志监控 webrtc 腾讯云 micropython esp32 mqtt 实时音视频 k8s django sqlite Qwen2.5-coder 离线部署 Docker Hub docker pull 镜像源 daemon.json MQTT mosquitto 消息队列 threejs 3D r语言 数据挖掘 数据可视化 数据分析 .netcore git ansible 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 Dify spring cloud kafka hibernate kamailio sip VoIP zabbix 微信 微信分享 Image wxopensdk outlook sqlserver rust腐蚀 安全威胁分析 漏洞 unity3d 系统架构 并查集 leetcode 豆瓣 追剧助手 迅雷 nas 远程工作 LDAP 华为od OD机试真题 华为OD机试真题 服务器能耗统计 gitlab VMware安装Ubuntu Ubuntu安装k8s okhttp CORS dns 低代码 aws googlecloud 恒源云 数据结构 vSphere vCenter 软件定义数据中心 sddc intellij idea jmeter 软件测试 arm rpc RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 服务器管理 宝塔面板 配置教程 服务器安装 网站管理 监控 自动化运维 gateway Clion Nova ResharperC++引擎 Centos7 远程开发 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 外网访问 内网穿透 端口映射 https AISphereButler 大数据平台 交换机 telnet 远程登录 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 web3.py spring Kali Linux 黑客 渗透测试 信息收集 孤岛惊魂4 C 环境变量 进程地址空间 DeepSeek gitee Python 网络编程 聊天服务器 套接字 TCP 客户端 Socket 大模型微调 pygame 小游戏 五子棋 代码调试 ipdb adobe 软件工程 NPS 雨云服务器 雨云 springsecurity6 oauth2 授权服务器 token sas nvidia gpu算力 live555 源码剖析 rtsp实现步骤 流媒体开发 多线程服务器 Linux网络编程 rtsp rtp 远程控制 远程看看 远程协助 僵尸进程 pillow rsyslog 金融 Trae IDE AI 原生集成开发环境 Trae AI 腾讯云大模型知识引擎 Deepseek 爬虫 网络用户购物行为分析可视化平台 大数据毕业设计 1024程序员节 串口服务器 框架搭建 WSL win11 无法解析服务器的名称或地址 缓存 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 bootstrap html ecmascript nextjs react reactjs eureka Ubuntu Server Ubuntu 22.04.5 YOLOv12 飞牛NAS 飞牛OS MacBook Pro LLM DeepSeek-R1 API接口 thingsboard postgresql list go KVM rabbitmq 直播推流 产品经理 microsoft file server http server web server Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 状态管理的 UDP 服务器 Arduino RTOS iftop 网络流量监控 驱动开发 硬件工程 嵌入式实习 Linux PID hive hadoop DBeaver 数据仓库 kerberos gitea make命令 makefile文件 媒体 微信公众平台 LInux 开机自启动 rag ragflow ragflow 源码启动 计算机 Kylin-Server 国产操作系统 ruoyi visual studio code Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer 安卓 bash 目标跟踪 OpenVINO 推理应用 Wi-Fi web mamba Vmamba SysBench 基准测试 ecm bpm Reactor 设计模式 C++ 机器人 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? Google pay Apple pay 压力测试 android studio 交互 职场和发展 文件系统 路径解析 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 MacOS录屏软件 OpenManus visualstudio 音乐服务器 Navidrome 音流 dify 游戏服务器 Minecraft 蓝桥杯 lio-sam SLAM Erlang OTP gen_server 热代码交换 事务语义 glibc MNN Qwen Dell HPE 联想 浪潮 iDRAC R720xd 实时互动 freebsd python3.11 bug RAGFLOW RAG 检索增强生成 文档解析 大模型垂直应用 elasticsearch 系统安全 unix 远程桌面 gaussdb playbook CLion 远程连接 kind bcompare Beyond Compare AI写作 AI作画 QQ 聊天室 DevEco Studio 命令 IIS .net core Hosting Bundle .NET Framework vs2022 其他 医疗APP开发 app开发 curl wget 大模型应用 Redis Desktop 测试用例 功能测试 集成学习 集成测试 GPU 剧本 无人机 设置代理 实用教程 muduo openEuler X11 Xming 企业微信 Linux24.04 deepin linux 命令 sed 命令 矩阵 链表 虚拟机 VMware 自动化任务管理 Invalid Host allowedHosts rdp 实验 EMUI 回退 降级 升级 计算虚拟化 弹性裸金属 jar gradle 王者荣耀 virtualenv SSH 服务 SSH Server OpenSSH Server DNS 游戏程序 C# MQTTS 双向认证 emqx kali 共享文件夹 minio yum源切换 更换国内yum源 safari Mac 系统 vscode 1.86 网站搭建 serv00 jetty undertow Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 线程 云电竞 云电脑 todesk 硬件架构 ip EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 单元测试 selenium SSH vr 灵办AI kvm ui p2p wsl 图形化界面 yolov8 游戏机 hugo Netty 即时通信 NIO jvm SWAT 配置文件 服务管理 网络共享 excel 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 ip命令 新增网卡 新增IP 启动网卡 指令 mq rocketmq 银河麒麟桌面操作系统 Kylin OS 国产化 DeepSeek行业应用 Heroku 网站部署 wsl2 半虚拟化 硬件虚拟化 Hypervisor tensorflow trae 英语 思科模拟器 思科 Cisco 大语言模型 GCC crosstool-ng java-ee nuxt3 xcode 服务器繁忙 next.js 部署next.js 边缘计算 npm pgpool openssl 密码学 业界资讯 模拟退火算法 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 田俊楠 多层架构 解耦 NFS 监控k8s 监控kubernetes 算力 个人博客 pyautogui 网络工程师 华为认证 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 WebUI DeepSeek V3 分析解读 数据集 mariadb 数据库系统 同步 备份 建站 grafana IPMI 直流充电桩 充电桩 bot Docker W5500 OLED u8g2 TCP服务器 硬件 设备 PCI-Express chfs ubuntu 16.04 log4j 网络穿透 MacMini 迷你主机 mini Apple 火绒安全 宠物 毕业设计 免费学习 宠物领养 宠物平台 Nuxt.js 小艺 Pura X 银河麒麟 kylin v10 麒麟 v10 高级IO epoll 致远OA OA服务器 服务器磁盘扩容 飞书 uniapp 迁移指南 gpt 图像处理 css k8s集群资源管理 云原生开发 服务器数据恢复 数据恢复 存储数据恢复 北亚数据恢复 oracle数据恢复 能力提升 面试宝典 技术 IT信息化 docker run 数据卷挂载 交互模式 Cline 自动化编程 VR手套 数据手套 动捕手套 动捕数据手套 echarts matlab LLMs 技能大赛 繁忙 解决办法 替代网站 汇总推荐 AI推理 移动云 输入法 鲲鹏 av1 电视盒子 机顶盒ROM 魔百盒刷机 ros2 moveit 机器人运动 code-server Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 3d 数学建模 网络结构图 XCC Lenovo Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 c dity make eNSP 网络规划 VLAN 企业网络 显示过滤器 安装 ICMP Wireshark安装 embedding keepalived redhat ios linux环境变量 远程 执行 sshpass 操作 xshell termius iterm2 nfs 信息可视化 网页设计 SSL 域名 skynet 大模型入门 大模型教程 chrome devtools chromedriver remote-ssh rime LORA NLP ArcTS 登录 ArcUI GridItem ci/cd arkUI ukui 麒麟kylinos openeuler 微信开放平台 微信公众号配置 统信 虚拟机安装 远程服务 minicom 串口调试工具 黑客技术 Xterminal URL Cursor 本地部署 api VPS pyqt Docker Compose docker compose docker-compose RTMP 应用层 监控k8s集群 集群内prometheus TRAE opensearch helm 服务器主板 AI芯片 MI300x WebRTC docker命令大全 openwrt 5G 3GPP 卫星通信 nac 802.1 portal ux 多线程 CPU 主板 电源 网卡 open Euler dde oneapi open webui IPMITOOL BMC 硬件管理 黑苹果 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 传统数据库升级 银行 TrinityCore 魔兽世界 sdkman elk opcua opcda KEPServer安装 selete 群晖 文件分享 iis 视觉检测 政务 分布式系统 监控运维 Prometheus Grafana 崖山数据库 YashanDB VMware创建虚拟机 ceph tidb GLIBC MS Materials 虚拟局域网 pdf 自定义客户端 SAS shell 开发环境 mysql离线安装 ubuntu22.04 mysql8.0 raid5数据恢复 磁盘阵列数据恢复 大模型面经 大模型学习 显卡驱动 源码 银河麒麟操作系统 protobuf 序列化和反序列化 混合开发 环境安装 JDK 深度求索 私域 知识库 服务器部署ai模型 sqlite3 webstorm Anolis nginx安装 linux插件下载 gpt-3 文心一言 匿名管道 京东云 etcd 数据安全 RBAC 强制清理 强制删除 mac废纸篓 frp 命令行 基础入门 编程 三级等保 服务器审计日志备份 Hive环境搭建 hive3环境 Hive远程模式 无桌面 risc-v k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm centos-root /dev/mapper yum clean all df -h / du -sh 回显服务器 UDP的API使用 ftp 软考 Ark-TS语言 flash-attention 报错 流式接口 ruby 联想开天P90Z装win10 EasyConnect 多个客户端访问 IO多路复用 TCP相关API RustDesk自建服务器 rustdesk服务器 docker rustdesk xml Java docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos ssrf 失效的访问控制 网工 springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 USB网络共享 压测 ECS 搜索引擎 Playwright 自动化测试 宕机切换 服务器宕机 JAVA cmos 昇腾 npu linux上传下载 idm xrdp windows日志 SRS 流媒体 直播 SSL证书 VMware安装mocOS macOS系统安装 vmware 卡死 DOIT 四博智联 RAID RAID技术 磁盘 存储 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 cnn 邮件APP 免费软件 FTP 服务器 性能测试 wps 环境迁移 Ubuntu 24.04.1 轻量级服务器 MQTT协议 消息服务器 代码 dash 正则表达式 dba VSCode 多进程 gcc AI代码编辑器 磁盘监控 linux安装配置 deepseek r1 相差8小时 UTC 时间 远程过程调用 Windows环境 netty 系统开发 binder 车载系统 framework 源码环境 XFS xfs文件系统损坏 I_O error 毕设 es FTP服务器 v10 软件 iphone perf seatunnel 阿里云ECS 游戏引擎 本地部署AI大模型 FunASR ASR 佛山戴尔服务器维修 佛山三水服务器维修 Spring Security 技术共享 我的世界 我的世界联机 数码 产测工具框架 IMX6ULL 管理框架 Ubuntu共享文件夹 共享目录 Linux共享文件夹 k8s二次开发 集群管理 openstack Xen 我的世界服务器搭建 seleium IMX317 MIPI H265 VCU 镜像 干货分享 黑客工具 密码爆破 composer 执法记录仪 智能安全帽 smarteye ROS 自动驾驶 线性代数 电商平台 服务器时间 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 ISO镜像作为本地源 Logstash 日志采集 eclipse 单例模式 less MCP server C/S cursor 宝塔 程序 性能分析 DeepSeek r1 Open WebUI 信号处理 Node-Red 编程工具 流编程 常用命令 文本命令 目录命令 HarmonyOS NLP模型 策略模式 自学笔记 小米 澎湃OS Android prompt tcp dns是什么 如何设置电脑dns dns应该如何设置 x64 SIGSEGV SSE xmm0 miniapp 真机调试 调试 debug 断点 网络API请求调试方法 HiCar CarLife+ CarPlay QT RK3588 CH340 串口驱动 CH341 uart 485 模拟器 教程 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 AI agent 信创 信创终端 中科方德 bat 端口 查看 ss 前后端分离 OpenSSH rclone AList webdav fnOS IPv4 子网掩码 公网IP 私有IP SSH 密钥生成 SSH 公钥 私钥 生成 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 嵌入式Linux IPC Linux的基础指令 easyui langchain edge浏览器 相机 权限 ShenTong 历史版本 下载 apt etl 软件构建 游戏开发 中兴光猫 换光猫 网络桥接 自己换光猫 fd 文件描述符 飞牛nas fnos 显示管理器 lightdm gdm 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 换源 国内源 Debian AI-native Docker Desktop 免费域名 域名解析 minecraft 音乐库 飞牛 HTTP 服务器控制 ESP32 DeepSeek H3C xss 毕昇JDK c/c++ 串口 pppoe radius 分布式训练 语音识别 李心怡 用户缓冲区 模拟实现 云服务 支付 微信支付 开放平台 Linux的权限 办公自动化 自动化生成 pdf教程 查询数据库服务IP地址 SQL Server deekseek qt项目 qt项目实战 qt教程 arcgis 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP cocoapods 影刀 #影刀RPA# g++ g++13 docker部署Python SenseVoice Kali 渗透 运维监控 银河麒麟高级服务器 外接硬盘 Kylin 根服务器 clickhouse 社交电子 版本 figma 信号 qemu libvirt Java Applet URL操作 服务器建立 Socket编程 网络文件读取 laravel WebVM 流水线 脚本式流水线 junit 推荐算法 DIFY DenseNet 阻塞队列 生产者消费者模型 服务器崩坏原因 代理 CrewAI trea idea banner cd 目录切换 内网服务器 内网代理 内网通信 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR Xinference RAGFlow 需求分析 规格说明书 GoogLeNet Ubuntu22.04 开发人员主页 反向代理 nlp virtualbox DocFlow 备选 网站 调用 示例 ubuntu24 vivado24 网络药理学 生信 gromacs 分子动力学模拟 MD 动力学模拟 程序员创富 键盘 vasp安装 视频编解码 AutoDL 代理服务器 7z CDN WLAN EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 deep learning Radius Headless Linux 本地知识库部署 DeepSeek R1 模型 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 代码托管服务 sonoma 自动更新 flink 实习 UOS1070e neo4j 数据库开发 database EMQX 通信协议 VS Code 做raid 装系统 大大通 第三代半导体 碳化硅 小智AI服务端 xiaozhi TTS Windows ai工具 AD 域管理 服务网格 istio searxng PPI String Cytoscape CytoHubba firewall VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 项目部署到linux服务器 项目部署过程 稳定性 看门狗 Typore 金仓数据库 2025 征文 数据库平替用金仓 序列化反序列化 h.264 互信 语法 vpn big data cpp-httplib 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 OpenHarmony 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 autodl web3 AD域 WSL2 上安装 Ubuntu 捆绑 链接 谷歌浏览器 youtube google gmail 图形渲染 聚类 ArkTs ArkUI 单一职责原则 sysctl.conf vm.nr_hugepages 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 交叉编译 Linux环境 alias unalias 别名 强化学习 Mac内存不够用怎么办 yaml Ultralytics 可视化 安防软件 端口测试 prometheus数据采集 prometheus数据模型 prometheus特点 asp.net大文件上传下载 powerpoint Claude AnythingLLM AnythingLLM安装 僵尸世界大战 游戏服务器搭建 华为机试 regedit 开机启动 zookeeper 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 主从复制 armbian u-boot swoole 人工智能生成内容 ldap Jellyfin webgl 基础环境 GIS 遥感 WebGIS 云桌面 微软 AD域控 证书服务器 TrueLicense 考研 实战案例 CVE-2024-7347 rustdesk 架构与原理 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 cfssl 私有化 超融合 su sudo 拓扑图 内网环境 玩机技巧 软件分享 软件图标 can 线程池 双系统 GRUB引导 Linux技巧 tailscale derp derper 中转 triton 模型分析 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors MySql vscode1.86 1.86版本 ssh远程连接 虚拟显示器 虚拟现实 ssh远程登录 P2P HDLC LLM Web APP Streamlit IDEA QT 5.12.12 QT开发环境 Ubuntu18.04 浏览器开发 AI浏览器 ssh漏洞 ssh9.9p2 CVE-2025-23419 重启 排查 系统重启 日志 原因 lua vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 移动魔百盒 USB转串口 Unity Dedicated Server Host Client 无头主机 aarch64 编译安装 HPC Deepseek-R1 私有化部署 推理模型 uv ros 域名服务 DHCP 符号链接 配置 spark HistoryServer Spark YARN jobhistory ubuntu24.04.1 IO模型 软负载 odoo 服务器动作 Server action midjourney 读写锁 openvpn server openvpn配置教程 centos安装openvpn IM即时通讯 剪切板对通 HTML FORMAT rnn saltstack sentinel 粘包问题 react native 加解密 Yakit yaklang React Next.js 开源框架 TCP协议 云耀服务器 开发 milvus CentOS Stream CentOS 流量运营 钉钉 网卡的名称修改 eth0 ens33 端口聚合 windows11 带外管理 navicat nvm whistle System V共享内存 进程通信 防火墙 NAT转发 NAT Server Attention docker desktop image 网络建设与运维 db css3 AI Agent 字节智能运维 Unity插件 iventoy VmWare OpenEuler fast docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 离线部署dify word 智能电视 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK gnu rpa 软件卸载 系统清理 iperf3 带宽测试 ubuntu20.04 开机黑屏 企业网络规划 华为eNSP UDP KylinV10 麒麟操作系统 Vmware grub 版本升级 扩容 Linux find grep hexo 多端开发 智慧分发 应用生态 鸿蒙OS 大模型推理 欧标 OCPP 抓包工具 沙盒 AI员工 元服务 应用上架 计算生物学 生物信息 基因组 PX4 perl MDK 嵌入式开发工具 论文笔记 sublime text top Linux top top命令详解 top命令重点 top常用参数 ros1 Noetic 20.04 apt 安装 zip unzip HAProxy 软链接 硬链接 ABAP Qwen2.5-VL vllm onlyoffice 网络爬虫 nosql SEO kernel kotlin win服务器架设 windows server 虚幻引擎 问题解决 llama.cpp Sealos 论文阅读 centos 7 xpath定位元素 SVN Server tortoise svn rancher 烟花代码 烟花 元旦 性能调优 安全代理 嵌入式系统开发 状态模式 wpf 网络搭建 神州数码 神州数码云平台 云平台 磁盘清理 物联网开发 区块链 wsgiref Web 服务器网关接口 java-rocketmq Linux权限 权限命令 特殊权限 ardunio BLE ip协议 知识图谱 visual studio MAC SecureCRT 抗锯齿 nftables 合成模型 扩散模型 图像生成 大模型部署 查看显卡进程 fuser ArtTS ranger MySQL8.0 鸿蒙开发 移动开发 IMM sequoiaDB MVS 海康威视相机 MacOS dock 加速 Python基础 Python教程 Python技巧 proxy模式 进程优先级 调度队列 进程切换 环境配置 在线office 浏览器自动化 存储维护 NetApp存储 EMC存储 本地化部署 容器技术 jina docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 hosts 多路转接 对比 工具 meld DiffMerge 健康医疗 互联网医院 项目部署 vu大文件秒传跨域报错cors 智能音箱 智能家居 harmonyOS面试题 HarmonyOS NEXT 原生鸿蒙 树莓派 VNC fstab 极限编程 安装MySQL 通信工程 毕业 deployment daemonset statefulset cronjob Reactor反应堆 国产数据库 瀚高数据库 数据迁移 下载安装 达梦 DM8 热榜 话题通信 服务通信 macOS 接口优化 数字证书 签署证书 WebServer 解决方案 服务器正确解析请求体 IO vnc 搜狗输入法 中文输入法 视频平台 录像 视频转发 视频流 yum换源 风扇控制软件 电视剧收视率分析与可视化平台 Web服务器 多线程下载工具 PYTHON yolov5 MobaXterm copilot conda配置 conda镜像源 js UEFI Legacy MBR GPT U盘安装操作系统 ubuntu 18.04 mcp服务器 client close 搭建个人相关服务器 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 MAVROS 四旋翼无人机 西门子PLC 通讯 机柜 1U 2U