最新资讯

  • 【Linux探索学习】第三十弹——线程互斥与同步(上):深入理解线程保证安全的机制

【Linux探索学习】第三十弹——线程互斥与同步(上):深入理解线程保证安全的机制

2025-05-06 15:01:01 1 阅读

Linux学习笔记:

https://blog.csdn.net/2301_80220607/category_12805278.html?spm=1001.2014.3001.5482

前言:

在上篇我们已经学习了关于线程的大部分知识,包括线程概念和线程控制等内容,今天我们来学习一下使用线程要做到的很重要的一步,那就是要保证线程的同步与互斥,从而确保线程安全问题,我们将通过一些生活中的例子和代码示例来理解如何做到线程的互斥与同步

目录

前提知识

线程的互斥

什么是线程的互斥

为什么需要线程的互斥

互斥的实现方法:互斥量

1. 互斥量的概念

2. 互斥量的接口函数

初始化与销毁

加锁与解锁

尝试加锁

3. 互斥量的使用

互斥锁实现互斥的原理

互斥量的使用场景

保护共享资源

避免竞态条件

互斥量的注意事项

死锁问题

性能开销

总结


前提知识

在深入探讨线程的互斥与同步之前,我们需要了解一些基本概念:

  • 并发与并行:并发是指多个任务在同一时间段内交替执行,而并行是指多个任务在同一时刻同时执行。

  • 临界区:临界区是指访问共享资源的代码段,这些资源在同一时刻只能被一个线程访问。

  • 竞态条件:当多个线程同时访问共享资源时,如果对资源的访问顺序不确定,可能会导致程序的行为不可预测,这种情况称为竞态条件。

线程的互斥

什么是线程的互斥

互斥是指在同一时刻,只允许一个线程访问共享资源。互斥机制确保了一个线程在访问共享资源时,其他线程不能同时访问该资源,从而避免了竞态条件的发生。

为什么需要线程的互斥

在多线程编程中,多个线程可能会同时访问共享资源。如果没有互斥机制,可能会导致以下问题:

  1. 数据不一致:当多个线程同时修改共享数据时,可能会导致数据的不一致。例如,两个线程同时对一个变量进行自增操作,可能会导致最终结果不正确。

  2. 竞态条件:竞态条件是指程序的输出依赖于线程的执行顺序,这会导致程序的行为不可预测。

下面我们通过一个春节购票系统来看一下会有什么问题:

我们定义一个全局变量count=1000表示有1000张票,我们再创建四个新线程,这四个新线程执行抢票工作,主线程等待回收它们,抢票的逻辑具体分为以下三步:

1、先检查是否还有余票。if(count>0)

2、如果有余票就让count--,同时子线程返回抢票的那一步

3、如果没有余票就退出

#include
#include
#include
using namespace std;

int count=1000;

void *GetTickets(void *args)
{
    int thread_id = (int)(intptr_t)args; // 获取线程ID
    while(1)
    {
        if(count>0)
        {
            usleep(10000);   //模拟购票准备工作所需时间
            printf("[pthread %d] get a picket, the picket number: %d
",thread_id,count);
            --count;
        }
        else
        {
            //如果没票,直接退出
            break;
        }
    }
    return nullptr;
}
int main()
{
    //创建四个新线程
    pthread_t tids[4];
    for(int i=0;i<4;i++)
    {
        pthread_create(&tids[i],nullptr,GetTickets,(void*)(intptr_t)(i+1));
    }
    //阻塞等待回收线程
    for(int i=0;i<4;i++)
    {
        pthread_join(tids[i],nullptr);
    }
    return 0;
}

执行结果(只截取了最后几行):

我们发现出现了错误,按照逻辑票应该是一张一张减少的,而且最终票数到0之后就不能再购买了,但是这里多购买了三张,那么原因是什么呢?

该错误是由以下两个原因组成的:

  • if 语句判断条件为真以后,代码可以并发的切换到其他线程。
  • usleep 是个模拟漫长业务的过程。在这个漫长的业务过程中,可能有其他线程会进入该代码段。

简单点来说就是在一个线程执行购票过程的时候,其它线程也可能会进入进行购票,因为线程是并发执行的,最终就可能会导致票数已经为0了,但是有些进程已经在票数为0前进入到if判断中了,就可能导致以上问题

根本原因就是--操作并不是原子的(简单来说并不是一次完成的),而是对应三条汇编指令:

  • load :将共享变量ticket从内存加载到寄存器中
  • update : 更新寄存器里面的值,执行-1操作
  • store :将新值,从寄存器写回共享变量ticket的内存地址
要解决以上问题,需要做到三点:
  • 代码必须要有互斥行为:当代码进入临界区执行时,不允许其他线程进入该临界区。
  • 如果多个线程同时要求执行临界区的代码,并且临界区没有线程在执行,那么只能允许一个线程进入该临 界区。
  • 如果线程不在临界区中执行,那么该线程不能阻止其他线程进入临界区。

要做到以上三点,本质上就是需要一把锁,在一个线程进入临界区时将临界区的入口锁住不让其它线程进入,Linux提供的这个锁叫做互斥量

互斥的实现方法:互斥量

1. 互斥量的概念

互斥量是一种用于多线程编程的同步机制,用于确保同一时刻只有一个线程可以访问共享资源。互斥量的核心思想是通过加锁(Lock)和解锁(Unlock)操作来控制对共享资源的访问,从而避免多个线程同时修改共享资源导致的数据不一致或竞态条件。

互斥量通常用于保护临界区,即访问共享资源的代码段。当一个线程进入临界区时,它会先加锁;当线程离开临界区时,它会解锁,允许其他线程进入。

2. 互斥量的接口函数

1、互斥量的接口函数头文件都是 #include

2、返回值都是:成功返回0,失败返回相应的错误码

初始化与销毁
pthread_mutex_init

用于初始化互斥量。

int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t *attr);
  • 参数

    • mutex:指向互斥量的指针。

    • attr:互斥量属性,通常设置为NULL以使用默认属性。

  • 返回值:成功返回0,失败返回错误码。

  1. PTHREAD_MUTEX_TIMED_NP:这时默认值,也就是普通锁。当一个线程加锁以后,其它申请该锁的线程组成一个资源等待队列,并在解锁后按优先级获得锁。这种解锁策略保证了资源分配的公平性。
  2. PTHREAD_MUTEX_RECURSIVE_NP:嵌套锁,允许同一个线程对同一个锁成功获得多次,并通过多次unlock解锁。如果是不同线程请求,则在加锁线程解锁后重新竞争。
  3. PTHREAD_MUTEX_ERRORCHECK_NP:检错锁,如果同一个线程请求同一个锁,则返回EDEADLK错误,否则与PTHREAD_MUTEX_TIMED_NP类型动作相同。这样就保证当不允许多次加锁时,不会出现最简单情况下的死锁。
  4. PTHREAD_MUTEX_ADAPTIVE_NP:适应锁,动作最简单的锁类型,仅等待解锁后重新竞争。
pthread_mutex_destroy

用于销毁互斥量,释放相关资源。

int pthread_mutex_destroy(pthread_mutex_t *mutex);
  • 参数

    • mutex:指向互斥量的指针。

  • 返回值:成功返回0,失败返回错误码。

加锁与解锁
pthread_mutex_lock

用于加锁互斥量。如果互斥量已被其他线程锁定,当前线程会被阻塞,直到互斥量被解锁。

int pthread_mutex_lock(pthread_mutex_t *mutex);
  • 参数

    • mutex:指向互斥量的指针。

  • 返回值:成功返回0,失败返回错误码。

pthread_mutex_unlock

用于解锁互斥量,允许其他线程加锁。

int pthread_mutex_unlock(pthread_mutex_t *mutex);
  • 参数

    • mutex:指向互斥量的指针。

  • 返回值:成功返回0,失败返回错误码。

尝试加锁
pthread_mutex_trylock

尝试加锁互斥量。如果互斥量已被其他线程锁定,函数立即返回,不会阻塞当前线程。

int pthread_mutex_trylock(pthread_mutex_t *mutex);

参数

  • mutex:指向互斥量的指针。
  • 返回值:成功返回0,失败返回错误码(如EBUSY表示互斥量已被锁定)。

在锁的初始化上除了上面用函数来初始化外,我们也可以直接初始化:

这种初始化的方法叫做静态初始化,它将锁的声明、定义和初始化全部完成了,而且这样初始化的锁最后也不需要我们手动销毁

3. 互斥量的使用

我们使用一把互斥锁来对我们上面的购票系统进行一下加工:

首先我们先定义一个全局的互斥量,因为多个线程都要使用,定义全局的可以提高效率

主线程对所进行初始化,然后等待子线程都执行完后,回收子线程并且销毁锁

子线程在进入临界区时加锁,出临界区时解锁

#include
#include
#include
using namespace std;

int count=1000;
pthread_mutex_t mutex;

void *GetTickets(void *args)
{
    int thread_id = (int)(intptr_t)args; // 获取线程ID
    while(1)
    {
        //进入临界区时加锁
        pthread_mutex_lock(&mutex);
        if(count>0)
        {
            usleep(10000);   //模拟购票准备工作所需时间
            printf("[pthread %d] get a picket, the picket number: %d
",thread_id,count);
            --count;
            pthread_mutex_unlock(&mutex);    //买完票后退出重新进入购票队列,并把锁释放
        }
        else
        {
            //如果没票,直接退出
            pthread_mutex_unlock(&mutex);
            break;
        }
    }
    return nullptr;
}
int main()
{
    //创建新线程前先把锁初始化了
    pthread_mutex_init(&mutex,nullptr);
    //创建四个新线程
    pthread_t tids[4];
    for(int i=0;i<4;i++)
    {
        pthread_create(&tids[i],nullptr,GetTickets,(void*)(intptr_t)(i+1));
    }
    //阻塞等待回收线程
    for(int i=0;i<4;i++)
    {
        pthread_join(tids[i],nullptr);
    }
    //线程都回收后把锁也销毁了
    pthread_mutex_destroy(&mutex);
    return 0;
}

运行结果:

此时我们就发现我们最终的执行结果没有出现上面的问题了,这就是因为互斥锁保证了ticket--的原子性问题,每一次票数减一后才会有其它线程进入到临界区中

但是我们观察上面的执行结果,我们发现怎么所有的票都被线程2抢走了呢?这是因为最一开始是线程2先拿到锁抢到票,但是之后线程2对锁的竞争力就会远强于其它线程了,因为它将锁刚一释放就马上又获取了,所以我们采取的方法可以是:线程2抢完票之后可以让它短暂睡眠一会儿,这样其它线程就能够来争夺锁了

再次运行:

此时我们就可以发现所有线程都参与到抢票中来了,符合我们的预期结果

互斥锁实现互斥的原理

在了解锁的原理前,首先我们先来看一个小的知识点:

我们都知道寄存器是32位的,但是早期的寄存器实际上是只有16位的,现在的寄存器实际上可以看成两个16位的寄存器组合在一起,看成al和ah两块,al就是低位的那块,ah就是高位的那块

锁的原理图:

  • 第一步:首先将al寄存器清零
  • 第二步:将al寄存器中的内容和mutex的内容做一次交换,这个动作其实就是我们申请锁的动作
  • 第三步:判断,如果锁的数量大于0就会申请成功并退出,如果不大于0就会挂起等待

下面来看一下锁的伪代码对应的各个过程:

在整个加锁的过程中只有一个数值1存在,这个1要么保存在某个线程的私有的寄存器中,要么保存在共享的互斥锁变量mutex里。如果某个线程的寄存器中的值为1,说明该线程已经加锁成功。

锁本身其实也是作为共享资源存在的,那锁本身需要保护吗?

答案是不需要,因为锁在执行各种操作时其实已经是互斥的了

互斥量的使用场景

保护共享资源

互斥量最常见的用途是保护共享资源,例如全局变量、文件、数据库连接等。通过加锁和解锁操作,可以确保同一时刻只有一个线程访问共享资源。

避免竞态条件

互斥量可以避免竞态条件的发生。例如,在多个线程同时修改同一个变量时,使用互斥量可以确保每次修改操作是原子的。


互斥量的注意事项

死锁问题

死锁是指多个线程相互等待对方释放锁,导致程序无法继续执行。常见的死锁场景包括:

  • 线程A锁定互斥量X,然后尝试锁定互斥量Y;

  • 线程B锁定互斥量Y,然后尝试锁定互斥量X。

为了避免死锁,可以遵循以下原则:

  • 按固定顺序加锁;

  • 使用超时互斥量;

  • 避免嵌套加锁。

性能开销

互斥量的加锁和解锁操作会带来一定的性能开销,尤其是在高并发场景下。为了减少开销,可以:

  • 尽量减少临界区的范围;

  • 使用读写锁(std::shared_mutex)替代互斥量;

  • 使用无锁数据结构(Lock-Free Data Structures)。

总结

互斥量是多线程编程中不可或缺的同步机制,用于保护共享资源、避免竞态条件和数据不一致问题。通过加锁和解锁操作,互斥量确保同一时刻只有一个线程访问临界区。

在实际开发中,需要根据具体场景选择合适的互斥量类型,并注意避免死锁和性能开销问题。通过合理使用互斥量,可以编写出高效、可靠的多线程程序。

 除了互斥外,同步也是保证线程安全的很重要的概念,鉴于篇幅问题,同步我们放在下一篇进行讲解

本篇笔记:

感谢各位大佬观看,创作不易,还请各位大佬点赞支持!!!

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

搜索文章

Tags

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