最新资讯

  • 【项目】 :C++ - 仿muduo库one thread one loop式并发服务器实现(模块划分)

【项目】 :C++ - 仿muduo库one thread one loop式并发服务器实现(模块划分)

2026-02-04 20:54:00 栏目:最新资讯 6 阅读

【项目】 :C++ - 仿muduo库one thread one loop式并发服务器实现

  • 一、HTTP 服务器与 Reactor 模型
    • 1.1、HTTP 服务器
      • 概念
      • 实现步骤
      • 难点
    • 1.2、Reactor 模型
      • 概念
      • 分类
        • 1. 单 Reactor 单线程
        • 2. 单 Reactor 多线程
        • 3. 多 Reactor 多线程
      • 目标定位
    • 总结
  • 二、功能模块划分
    • 2.1、SERVER 模块
      • 子模块
        • Buffer 模块
        • Socket 模块
        • Channel 模块
        • Connection 模块
        • Acceptor 模块
        • TimerQueue 模块
        • Poller 模块
        • EventLoop 模块
        • TcpServer 模块
      • 模块关系图:
    • 2.2、HTTP 协议模块
      • 模块划分
        • **Util 模块**(工具模块)
        • **HttpRequest 模块**(HTTP 请求数据模块)
        • **HttpResponse 模块**(HTTP 响应数据模块)
        • **HttpContext 模块**(HTTP 上下文模块)
        • **HttpServer 模块**(HTTP 服务器模块)
  • 三、C++11 技术点与功能用例
    • 3.1 bind 概念
      • 示例 1:绑定固定参数或预留参数
      • 示例 2:任务池中的应用
      • 总结
    • 3.2 Linux 定时器 timerfd
      • 创建定时器
      • 设置定时器时间
      • 示例:每隔 3 秒触发一次
    • 3.3 时间轮思想
      • 问题
      • 原理
      • 延迟任务 + 智能指针
      • 定时任务类设计
      • 时间轮实现
      • 使用示例
      • 总结
    • 3.4 C++ 正则库()的简单使用
      • HTTP 请求首行解析
      • 完整示例
      • 总结
    • 3.5 C++ 通用类型 Any 的实现与使用
      • Any 类型的简单实现
      • 测试Any类型
      • C++17 中的 std::any 使用

  通过实现的高并发服务器组件,可以简洁快速的完成一个高性能的服务器搭建。并且,通过组件内提供的不同应用层协议支持,也可以快速完成一个高性能应用服务器的搭建(当前为了便于项目的演示,项目中提供HTTP协议组件的支持)。在这里,要明确的是咱们要实现的是一个高并发服务器组件,因此当前的项目中并不包含实际的业务内容。

代码仓库:https://gitee.com/rxrw/server

一、HTTP 服务器与 Reactor 模型


1.1、HTTP 服务器

概念

HTTP(Hyper Text Transfer Protocol,超文本传输协议)是应用层协议,属于 请求-响应协议

  • 客户端发送请求,服务器提供服务,完成后关闭连接。
  • HTTP 协议运行在 TCP 协议之上

因此,HTTP 服务器本质上就是 TCP 服务器,只是在应用层基于 HTTP 协议格式进行数据组织和解析来完成业务处理。

实现步骤

  1. 搭建一个 TCP 服务器,接收客户端请求。
  2. 按照 HTTP 协议格式解析请求数据,明确客户端目的。
  3. 根据客户端请求提供对应服务。
  4. 将服务结果按照 HTTP 协议格式组织并返回给客户端。

难点

  • 实现一个简单 HTTP 服务器并不复杂。
  • 难点在于如何实现高性能的服务器
  • 本单元将基于 Reactor 模式 实现高性能服务器。

目标:构建一个 高性能服务器基础库,作为通用组件,而不是具体的业务服务器。


1.2、Reactor 模型

概念

Reactor 模式是一种 事件驱动处理模式

  • 通过 I/O 多路复用 统一监听事件。
  • 当事件触发时,将其分发(Dispatch)给对应的处理线程执行。
  • 又称 Dispatcher 模式

这是编写高性能网络服务器的核心技术之一。

分类

1. 单 Reactor 单线程
  • 模型特点:单 I/O 多路复用 + 业务处理(同线程完成)
  • 流程
    1. I/O 多路复用监控客户端请求。
    2. 事件触发:
      • 新连接 → 加入多路复用监控。
      • 数据通信 → 读数据 → 处理 → 响应。
  • 优点:实现简单,无线程间通信。
  • 缺点:无法利用多核 CPU,性能瓶颈明显。
  • 适用场景:少量客户端,快速处理场景。
2. 单 Reactor 多线程
  • 模型特点:单 I/O 多路复用 + 线程池(业务处理)
  • 流程
    1. Reactor 线程监控请求。
    2. 新连接 → Reactor 处理并加入监控。
    3. 数据通信 → Reactor 读数据 → 分发给 Worker 线程池。
    4. Worker 处理完成 → Reactor 返回响应。
  • 优点:利用多核 CPU。
  • 缺点:多线程同步复杂,Reactor 本身可能成为瓶颈。
3. 多 Reactor 多线程
  • 模型特点:主从 Reactor 分工 + 线程池
  • 流程
    1. 主 Reactor:只处理新连接请求,并分发给子 Reactor。
    2. 子 Reactor:监控通信事件。
    3. Worker 线程池:处理业务逻辑,并由子 Reactor 返回结果。
  • 优点:充分利用多核 CPU,主从职责清晰,性能强大。
  • 缺点:设计复杂。

目标定位

  • One Thread One Loop 主从 Reactor 模型
    • 主 Reactor 仅监控监听套接字,负责高效接入新连接。
    • 子 Reactor 负责通信事件处理。
    • 每个线程绑定一个 EventLoop,保证线程安全。
  • Worker 线程池是否使用,由组件调用方决定。

总结

  • HTTP 服务器的核心是 基于 TCP + HTTP 协议解析
  • 高性能服务器的关键在于 Reactor 模型 的合理应用。
  • 最终实现是一个 主从 Reactor 高性能服务器框架,并将功能拆分为模块化组件,便于扩展和复用。

二、功能模块划分

为了实现一个带有协议支持的 Reactor 高性能服务器,项目分为两大模块:

  • SERVER 模块:实现 Reactor 模型的 TCP 服务器。
  • 协议模块:为服务器提供应用层协议支持。

2.1、SERVER 模块

负责对连接和线程进行管理,分为三个方向:

  • 监听连接管理
  • 通信连接管理
  • 超时连接管理

子模块

Buffer 模块
  • 通信缓冲区,提供用户态接收和发送缓冲区。
Socket 模块
  • 封装套接字操作。
Channel 模块
  • 管理描述符的 I/O 事件(读、写、错误等)。
  • 与 Poller 配合,触发事件时回调相应处理函数。
Connection 模块
  • 封装 Buffer、Socket、Channel,管理一个通信套接字。
  • 每个新连接由一个 Connection 管理。
  • 提供:
    • 回调函数(连接建立、事件、新数据、关闭)。
    • 接口(数据发送、连接关闭)。
    • 用户态缓冲区(接收 + 发送)。
  • 处理流程
    1. 注册 Channel 回调并加入 Poller 监控。
    2. IO 可读 → 读数据到用户缓冲区 → 调用业务回调。
    3. 业务处理完 → 写数据到发送缓冲区。
    4. Poller 通知可写 → 调用写回调 → 数据发送到内核。
Acceptor 模块
  • 管理监听套接字。
  • 负责获取新连接,为其创建 Connection 对象。
TimerQueue 模块
  • 定时任务管理器。
  • 管理 Connection 生命周期,释放超时连接。
  • 基于 timerfd + Channel 实现。
Poller 模块
  • 封装 epoll,管理 IO 事件(添加、修改、删除、获取活跃事件)。
EventLoop 模块
  • 核心 Reactor 单元,一个线程一个 EventLoop。
  • 管理 Poller、TimerQueue、任务队列。
  • 保证所有 Connection 操作都在其绑定线程内完成。
  • 机制
    • eventfd 用于任务队列唤醒 epoll 阻塞。
    • 处理顺序:Poller 就绪事件 → Channel 回调 → 任务队列执行。
TcpServer 模块
  • 封装整个 TCP 服务器:
    • BaseLoop(主 Reactor)。
    • EventLoopThreadPool(子 Reactor 池)。
    • Acceptor(监听套接字)。
    • Hash 表(管理所有 Connection)。
  • 处理流程
    1. 实例化时初始化 BaseLoop、Acceptor、线程池和连接表。
    2. Acceptor 接收新连接 → 创建 Connection → 设置回调 → 加入哈希表 → 分配 EventLoop → 设置定时销毁任务 → 加入 Poller。
    3. 启动 BaseLoop。

模块关系图:

2.2、HTTP 协议模块

HTTP 协议模块用于为高并发服务器提供协议支持,简化 HTTP 服务器的搭建过程。
它由多个子模块组成,每个模块负责不同的功能。


模块划分

Util 模块(工具模块)
  • 作用:提供常用的工具函数,避免重复造轮子。
  • 功能示例
    • URL 编解码(encode/decode)
    • 文件读写操作(读取静态资源文件)
    • 字符串处理(分割、去空格、大小写转换等)

➡️ 可以认为是 基础支撑库


HttpRequest 模块(HTTP 请求数据模块)
  • 作用:负责存储和管理 解析后的 HTTP 请求信息
  • 核心字段
    • 请求行(method、URL、version)
    • 请求头部(headers)
    • 请求正文(body,可能是 JSON/表单数据)
  • 职责
    • 解析原始请求字符串
    • 提供统一接口让上层业务获取请求内容

➡️ 相当于 HTTP 请求的 数据结构


HttpResponse 模块(HTTP 响应数据模块)
  • 作用:负责生成和管理 HTTP 响应数据
  • 核心字段
    • 状态行(version、status code、reason phrase)
    • 响应头部(headers)
    • 响应正文(body,HTML/JSON/文件内容)
  • 职责
    • 设置响应码、响应头、响应体
    • 将结构化数据拼装成完整的 HTTP 响应字符串

➡️ 相当于 HTTP 响应的 数据结构 + 序列化器


HttpContext 模块(HTTP 上下文模块)
  • 作用:解决 请求接收的不完整性 问题。
  • 问题场景
    • TCP 是流式协议,一次 recv 可能拿到的是半个请求,或者多个请求拼在一起。
  • 职责
    • 缓存未完整的请求数据
    • 持续解析,直到完整请求被解析成 HttpRequest
    • 管理请求解析状态(正在解析头部/正在解析 body/解析完成)

➡️ 可以理解为 请求的粘包拆包处理器


HttpServer 模块(HTTP 服务器模块)
  • 作用:对外暴露简单接口,开发者只需要关注“注册路由 + 处理逻辑”。
  • 内部结构
    • TcpServer 对象:负责底层 TCP 连接、收发数据。
    • 两个接口(供 TcpServer 回调):
      • 连接建立成功 → 设置 HttpContext
      • 数据到来 → 调用解析逻辑并触发业务回调
    • 请求-处理函数映射表(hash-map)
      • key: 路径(URL)或方法+路径组合
      • value: 业务处理函数
  • 职责
    • 接收请求
    • 匹配路由
    • 调用对应的业务处理函数
    • 将业务结果封装成 HttpResponse 并返回

➡️ 开发者只需要写业务逻辑,比如:

server.Get("/hello", [](const HttpRequest& req, HttpResponse* resp){
    resp->SetBody("Hello World!");
    resp->SetStatus(200);
});

三、C++11 技术点与功能用例


3.1 bind 概念

  • std::bind 是通用的函数适配器。
  • 接受函数对象和参数,返回一个新的函数对象。
  • 新函数对象的参数可以:
    • 已经绑定(固定值)
    • 或使用占位符 std::placeholders::_1, _2... 预留,调用时传入。

函数原型

template <class Fn, class... Args>
bind(Fn&& fn, Args&&... args);

示例 1:绑定固定参数或预留参数

#include 
#include 
#include 

class Test {
public:
    Test() { std::cout << "构造" << std::endl; }
    ~Test() { std::cout << "析构" << std::endl; }
};

void del(const Test *t, int num) {
    std::cout << num << std::endl;
    delete t;
}

int main() {
    Test *t = new Test;

    // 第1个参数固定为 t,第2个参数预留
    std::function<void(int)> cb = std::bind(del, t, std::placeholders::_1);

    cb(10); // 调用绑定函数

    while(1) sleep(1);
    return 0;
}

输出:

构造
10
析构

示例 2:任务池中的应用

#include 
#include 
#include 
#include 

void print(const std::string &str) {
    std::cout << str << std::endl;
}

int main() {
    using Functor = std::function<void()>;
    std::vector<Functor> task_pool;

    task_pool.push_back(std::bind(print, "我是"));
    task_pool.push_back(std::bind(print, "大"));
    task_pool.push_back(std::bind(print, "帅哥"));

    for (auto &functor : task_pool) {
        functor();
    }

    return 0;
}

输出:

我是
大
帅哥

总结

  • std::bind 用于生成可调用对象并绑定参数。

  • 占位符 _1, _2… 用于预留参数。

  • 在任务池/线程池中,可用 bind 将函数任务封装,降低耦合度。

这种格式特点:

  • 标题层次分明(概念 → 示例 → 总结)
  • 示例代码独立清晰
  • 输出结果紧跟代码块
  • 便于快速查阅和复制

3.2 Linux 定时器 timerfd

创建定时器

Linux 提供timerfd_create 创建定时器:

#include 

int timerfd_create(int clockid, int flags);
  • clockid

    • CLOCK_REALTIME:系统实时时间,修改系统时间会影响定时器。

    • CLOCK_MONOTONIC:从开机到现在的相对时间,不受系统时间修改影响。

  • flags:通常为 0(阻塞模式)。


设置定时器时间

int timerfd_settime(int fd, int flags, struct itimerspec *new_value, struct itimerspec *old_value);
  • fd:timerfd_create 返回的文件描述符

  • flags:0 表示相对时间,1 表示绝对时间

  • struct itimerspec

struct timespec {
    time_t tv_sec;   // 秒
    long tv_nsec;    // 纳秒
};

struct itimerspec {
    struct timespec it_interval; // 第一次之后的超时间隔
    struct timespec it_value;    // 第一次超时时间
};

当定时器超时时,会在 fd 写入 8 字节整数,表示自上次读取后超时次数。


示例:每隔 3 秒触发一次

#include 
#include 
#include 

int main() {
    int timerfd = timerfd_create(CLOCK_MONOTONIC, 0);

    struct itimerspec itm;
    itm.it_value.tv_sec = 3;
    itm.it_value.tv_nsec = 0;
    itm.it_interval.tv_sec = 3;
    itm.it_interval.tv_nsec = 0;

    timerfd_settime(timerfd, 0, &itm, NULL);

    time_t start = time(NULL);
    while (1) {
        uint64_t tmp;
        int ret = read(timerfd, &tmp, sizeof(tmp));
        if (ret < 0) return -1;
        std::cout << tmp << " " << time(NULL) - start << std::endl;
    }

    close(timerfd);
    return 0;
}

输出:

1 3
1 6
1 9
1 12

3.3 时间轮思想

问题

遍历所有连接判断超时,效率低。
解决方法:

  • 小根堆

  • 时间轮


原理

  • 类似钟表:

    • 数组表示时间槽,每秒 tick 向后走一步。

    • 将任务放入 (tick + delay) 的槽位。

  • 同一时间槽可以有多个任务。

  • 支持多层时间轮(秒轮、分轮、时轮),但 30 秒以内的定时任务通常只需单层时间轮。


延迟任务 + 智能指针

  • 利用 shared_ptr 管理任务:

    • 刷新任务时增加计数,旧任务失效。

    • 计数为 0 时真正析构,执行定时任务。


定时任务类设计

using OnTimerCallback = std::function<void()>;
using ReleaseCallback = std::function<void()>;

class Timer {
private:
    int _timeout;
    bool _canceled = false;
    uint64_t _timer_id;
    OnTimerCallback _timer_callback;
    ReleaseCallback _release_callback;

public:
    Timer(uint64_t timer_id, int timeout): _timer_id(timer_id), _timeout(timeout) {}
    ~Timer() {
        if (_release_callback) _release_callback();
        if (_timer_callback && !_canceled) _timer_callback();
    }

    int delay_time() { return _timeout; }
    void canceled() { _canceled = true; }
    void set_on_time_callback(const OnTimerCallback &cb) { _timer_callback = cb; }
    void set_release_callback(const ReleaseCallback &cb) { _release_callback = cb; }
};


时间轮实现

#define MAX_TIMEOUT 60

class TimerQueue {
private:
    using PtrTimer = std::shared_ptr<Timer>;
    using WeakTimer = std::weak_ptr<Timer>;
    using Bucket = std::vector<PtrTimer>;
    using BucketList = std::vector<Bucket>;

    int _tick = 0;
    int _capacity = MAX_TIMEOUT;
    BucketList _conns;
    std::unordered_map<uint64_t, WeakTimer> _timers;

public:
    TimerQueue(): _tick(0), _capacity(MAX_TIMEOUT), _conns(_capacity) {}

    bool has_timer(uint64_t id) {
        return _timers.find(id) != _timers.end();
    }

    void timer_add(const OnTimerCallback &cb, int delay, uint64_t id) {
        if (delay <= 0 || delay > _capacity) return;
        PtrTimer timer(new Timer(id, delay));
        timer->set_on_time_callback(cb);
        timer->set_release_callback(std::bind(&TimerQueue::remove_weaktimer_from_timerqueue, this, id));
        _timers[id] = WeakTimer(timer);
        _conns[(_tick + delay) % _capacity].push_back(timer);
    }

    void timer_refresh(uint64_t id) {
        auto it = _timers.find(id);
        assert(it != _timers.end());
        int delay = it->second.lock()->delay_time();
        _conns[(_tick + delay) % _capacity].push_back(it->second.lock());
    }

    void timer_cancel(uint64_t id) {
        auto it = _timers.find(id);
        assert(it != _timers.end());
        if (auto pt = it->second.lock()) pt->canceled();
    }

    void remove_weaktimer_from_timerqueue(uint64_t id) {
        _timers.erase(id);
    }

    void run_ontime_task() {
        _tick = (_tick + 1) % _capacity;
        _conns[_tick].clear();
    }
};


使用示例

class TimerTest {
private:
    int _data;
public:
    TimerTest(int data): _data(data) { std::cout << "test 构造!
"; }
    ~TimerTest() { std::cout << "test 析构!
"; }
};

void del(TimerTest *t) { delete t; }

int main() {
    TimerQueue tq;
    TimerTest *t = new TimerTest(10);
    int id = 3;
    tq.timer_add(std::bind(del, t), 5, id);

    // 刷新定时任务
    for (int i = 0; i < 5; i++) {
        sleep(1);
        tq.timer_refresh(id);
        std::cout << "刷新了1下定时任务!
";
        tq.run_ontime_task();
    }

    std::cout << "刷新停止, 5s后释放任务将被执行
";

    while (1) {
        sleep(1);
        tq.run_ontime_task();
        if (!tq.has_timer(id)) {
            std::cout << "定时任务已执行完毕!
";
            break;
        }
    }
    return 0;
}

输出:

test 构造!
刷新了1下定时任务!
刷新了1下定时任务!
刷新了1下定时任务!
刷新了1下定时任务!
刷新了1下定时任务!
刷新停止, 5s后释放任务将被执行
test 析构!

总结

  • 利用 timerfd 可以实现秒级定时器。

  • 单层时间轮高效管理大量定时任务。

  • 利用 shared_ptr 延迟任务析构,实现刷新任务逻辑。

  • 适合高并发服务器中处理连接超时问题。


3.4 C++ 正则库()的简单使用

正则表达式(Regular Expression)是一种描述字符串匹配模式的工具。它可以用来:

  • 检查字符串是否包含某种子串

  • 替换匹配的子串

  • 提取符合条件的子串

在 HTTP 请求解析中,正则表达式可以让程序逻辑更简洁灵活。不过需要注意,正则表达式通常比直接字符串处理效率低。


HTTP 请求首行解析

下面示例演示如何使用正则表达式解析 HTTP 请求首行:

#include 
#include 
#include 

void req_line() {
    std::cout << "------------------first line start-----------------
";
    std::string str = "GET /hello?a=b&c=d HTTP/1.1
";
    std::regex re("(GET|HEAD|POST|PUT|DELETE) (([^?]+)(?:?(.*?))?) (HTTP/1.[01])(?:
|
)");
    std::smatch matches;
    std::regex_match(str, matches, re);

    for (int i = 0; i < matches.size(); ++i) {
        std::cout << i << ": " << matches[i] << std::endl;
    }

    if (matches[4].length() > 0) {
        std::cout << "have param!
";
    } else {
        std::cout << "have not param!
";
    }
    std::cout << "------------------first line end-----------------
";
}

int main() {
    req_line();
    return 0;
}

输出示例:

------------------first line start-----------------
0: GET /hello?a=b&c=d HTTP/1.1
1: GET
2: /hello?a=b&c=d
3: /hello
4: a=b&c=d
5: HTTP/1.1
have param!
------------------first line end-----------------

matches 的存储说明:
matches[0]:整体首行
matches[1]:请求方法
matches[2]:整体 URL
matches[3]:路径(? 之前)
matches[4]:查询字符串
matches[5]:HTTP 协议版本

提取请求方法

void method_match(const std::string str) {
    std::cout << "------------------method start-----------------
";
    std::regex re("(GET|HEAD|POST|PUT|DELETE) .*");
    std::smatch matches;
    std::regex_match(str, matches, re);
    std::cout << matches[0] << std::endl; // 整行
    std::cout << matches[1] << std::endl; // 方法
    std::cout << "------------------method over------------------
";
}

提取请求路径

void path_match(const std::string str) {
    std::cout << "------------------path start------------------
";
    std::regex re("([^?]+).*");  // 匹配 ? 前的路径
    std::smatch matches;
    std::regex_match(str, matches, re);
    std::cout << matches[0] << std::endl;
    std::cout << matches[1] << std::endl;
    std::cout << "------------------path over------------------
";
}

提取查询字符串

void query_match(const std::string str) {
    std::cout << "------------------query start------------------
";
    std::regex re("(?:?(.*?))? .*"); 
    std::smatch matches;
    std::regex_match(str, matches, re);
    std::cout << matches[0] << std::endl;
    std::cout << matches[1] << std::endl;
    std::cout << "------------------query over------------------
";
}
(?(.*?))? 表示匹配以 ? 开头的查询字符串(可能没有)。

提取协议版本

void version_match(const std::string str) {
    std::cout << "------------------version start------------------
";
    std::regex re("(HTTP/1.[01])(?:
|
)");
    std::smatch matches;
    std::regex_match(str, matches, re);
    std::cout << matches[0] << std::endl;
    std::cout << matches[1] << std::endl;
    std::cout << "------------------version over------------------
";
}

完整示例

int main() {
    req_line();
    method_match("GET /s");
    path_match("/search?name=bitejiuyeke ");
    query_match("?name=xiaoming&age=19 HTTP/1.1");
    version_match("HTTP/1.1
");
    return 0;
}

输出示例:

------------------first line start-----------------
0: GET /bitejiuyeke?a=b&c=d HTTP/1.1
1: GET
2: /bitejiuyeke?a=b&c=d
3: /bitejiuyeke
4: a=b&c=d
5: HTTP/1.1
have param!
------------------first line end-----------------
------------------method start-----------------
GET /s
GET
------------------method over------------------
------------------path start------------------
/search?name=bitejiuyeke 
/search
------------------path over------------------
------------------query start------------------
?name=xiaoming&age=19 HTTP/1.1
name=xiaoming&age=19
------------------query over------------------
------------------version start------------------
HTTP/1.1
HTTP/1.1
------------------version over------------------

总结

  1. 可以方便地解析 HTTP 请求首行、路径、查询字符串和版本号。

  2. 捕获组 () 可以获取匹配的子字符串。

  3. 非捕获组 (?:…) 用于匹配但不捕获。

  4. 懒惰匹配 *? 可以确保只匹配第一次出现的内容。

  5. 正则表达式虽然灵活,但性能通常低于直接字符串操作。


3.5 C++ 通用类型 Any 的实现与使用

在网络编程中,每个 Connection 对象都需要管理协议处理的上下文。为了降低耦合度,上下文不能依赖具体协议,需要一个通用类型来存储任意数据结构。

在 C 语言中,可以使用 void*,但在 C++ 中,我们可以使用 C++17 提供的 std::any,或者自己实现一个简单的 Any 类型。


Any 类型的简单实现

原理:

  1. 定义一个基类 placeholder,提供虚函数 type() 和 clone()。

  2. 定义模板子类 holder 保存实际类型的数据。

  3. Any 类持有 placeholder*,在运行时管理不同类型的数据。

#include 
#include 
#include 
#include 

class Any {
public:
    Any() : _content(nullptr) {}

    template<typename T>
    Any(const T &val) : _content(new holder<T>(val)) {}

    Any(const Any &other) 
        : _content(other._content ? other._content->clone() : nullptr) {}

    ~Any() { if (_content) delete _content; }

    const std::type_info &type() { 
        return _content ? _content->type() : typeid(void); 
    }

    template<typename T>
    T* get() {
        assert(typeid(T) == _content->type());
        return &((holder<T>*)_content)->val;
    }

    template<typename T>
    Any& operator=(const T &val) {
        Any(val).swap(*this);
        return *this;
    }

    Any& operator=(Any other) {
        other.swap(*this);
        return *this;
    }

private:
    class placeholder {
    public:
        virtual ~placeholder() {}
        virtual const std::type_info &type() = 0;
        virtual placeholder *clone() = 0;
    };

    template <typename T>
    class holder : public placeholder {
    public:
        holder(const T &v) : val(v) {}
        const std::type_info &type() { return typeid(T); }
        placeholder *clone() { return new holder(val); }
        T val;
    };

    void swap(Any &other) { std::swap(_content, other._content); }

    placeholder *_content;
};

测试Any类型

class Test {
public:
    std::string _data;
    Test(const std::string &data) : _data(data) { std::cout << "构造" << _data << std::endl; }
    Test(const Test &other) { _data = other._data; std::cout << "拷贝" << _data << std::endl; }
    ~Test() { std::cout << "析构" << _data << std::endl; }
};

int main() {
    // 基本类型
    Any any_a = 10;
    Any any_b = 20.5f;
    Any any_c = std::string("Hello World");

    std::cout << *any_a.get<int>() << std::endl;
    std::cout << *any_b.get<float>() << std::endl;
    std::cout << *any_c.get<std::string>() << std::endl;

    // 对象类型
    Test d("Leihou");
    Any any_d = d;
    Any any_e(d);
    Any any_f(any_d);
    Any any_g = any_d;

    // 不同类型的赋值
    Any any_h;
    any_h = 33;
    std::cout << *any_h.get<int>() << std::endl;
    any_h = std::string("Hello Any");
    std::cout << *any_h.get<std::string>() << std::endl;
    any_h = Any(Test("test"));
    std::cout << any_h.get<Test>()->_data << std::endl;

    return 0;
}

输出示例:

10
20.5
Hello World
构造Leihou
拷贝Leihou
拷贝Leihou
拷贝Leihou
拷贝Leihou
析构Leihou
析构Leihou
析构Leihou
析构Leihou
析构Leihou
33
Hello Any
构造test
拷贝test
析构test
test
析构test

C++17 中的 std::any 使用

C++17 提供了标准的 std::any,使用起来更简洁,不需要手动实现:

#include 
#include 
#include 

class Test {
public:
    std::string _data;
    Test(const std::string &data) : _data(data) { std::cout << "构造" << _data << std::endl; }
    Test(const Test &other) { _data = other._data; std::cout << "拷贝" << _data << std::endl; }
    ~Test() { std::cout << "析构" << _data << std::endl; }
};

int main() {
    std::any a = 10;
    std::any b = 88.88;
    std::any c = std::string("bitejiuyeke");

    std::cout << *std::any_cast<int>(&a) << std::endl;
    std::cout << *std::any_cast<double>(&b) << std::endl;
    std::cout << *std::any_cast<std::string>(&c) << std::endl;

    Test d("Leihou");
    std::any any_d = d;
    std::any any_f;
    any_f = 33;
    std::cout << *std::any_cast<int>(&any_f) << std::endl;

    std::string s = "Hello World";
    any_f = s;
    std::cout << *std::any_cast<std::string>(&any_f) << std::endl;

    any_f = std::any(Test("test"));
    std::cout << std::any_cast<Test>(&any_f)->_data << std::endl;

    return 0;
}
注意:使用 std::any 需要 C++17 支持,推荐 g++ 7.3 及以上版本。

本文地址:https://www.yitenyun.com/5619.html

搜索文章

Tags

#服务器 #python #pip #conda #人工智能 #微信 #ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 #远程工作 #Trae #IDE #AI 原生集成开发环境 #Trae AI 香港站群服务器 多IP服务器 香港站群 站群服务器 #kubernetes #笔记 #平面 #容器 #linux #学习方法 #运维 #log4j #ollama #飞牛nas #fnos #科技 #深度学习 #自然语言处理 #神经网络 #kylin #docker #arm #hadoop #hbase #hive #zookeeper #spark #kafka #flink #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #低代码 #爬虫 #音视频 #AI编程 #飞书 #学习 #语言模型 #大模型 #ai #ai大模型 #agent #华为云 #部署上线 #动静分离 #Nginx #新人首发 #大数据 #职场和发展 #程序员创富 #ARM服务器 # GLM-4.6V # 多模态推理 #fastapi #html #css #PyTorch #模型训练 #星图GPU #分阶段策略 #模型协议 #ssh #ide #java #开发语言 #前端 #javascript #架构 #经验分享 #安卓 #MobaXterm #ubuntu #langchain #数据库 #harmonyos #鸿蒙PC #C++ #Reactor #nginx #开源 #windows #物联网 #websocket #自动化 #ansible #云计算 #进程控制 #驱动开发 #c++ #github #git #node.js #tcp/ip #网络 #qt #unity #c# #游戏引擎 #私有化部署 #pytorch #aws #区块链 #测试用例 #生活 #word #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #Conda # 私有索引 # 包管理 #android #腾讯云 #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #cpolar #fabric #postgresql #openHiTLS #TLCP #DTLCP #密码学 #商用密码算法 #大模型学习 #AI大模型 #大模型教程 #大模型入门 #jar #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #vue上传解决方案 #vue断点续传 #vue分片上传下载 #vue分块上传下载 #sql #AIGC #agi #风控模型 #决策盲区 #内网穿透 #算法 #牛客周赛 #mysql #云原生 #iventoy #VmWare #OpenEuler #dify #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #ci/cd #jenkins #gitlab #pycharm #Ansible # 自动化部署 # VibeThinker #Harbor #vscode #文心一言 #AI智能体 #矩阵 #线性代数 #AI运算 #向量 #机器学习 #flutter #centos #svn #后端 #缓存 #硬件工程 #mobaxterm #计算机视觉 #http #项目 #高并发 #spring cloud #spring #vue.js #json #serverless #diskinfo # TensorFlow # 磁盘健康 #microsoft #儿童书籍 #儿童诗歌 #童话故事 #经典好书 #儿童文学 #好书推荐 #经典文学作品 #鸿蒙 #边缘计算 #mcp #mcp server #AI实战 #阿里云 #重构 #ecmascript #elementui #开源软件 #FTP服务器 #流程图 #论文阅读 #信息可视化 #c语言 #FaceFusion # Token调度 # 显存优化 #设备驱动 #芯片资料 #网卡 #数学建模 #shell #CPU利用率 #php #2026年美赛C题代码 #2026年美赛 #java-ee #分布式 #华为 #iBMC #UltraISO #spring boot #性能优化 #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 #超算服务器 #算力 #高性能计算 #仿真分析工作站 #springboot #prometheus #Ubuntu服务器 #硬盘扩容 #命令行操作 #VMware #jmeter #功能测试 #软件测试 #自动化测试 #stm32 #CFD #mongodb #数据结构 #mcu #MCP #MCP服务器 #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #内存治理 #django #进程 #mvp #个人开发 #设计模式 #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #llama #opencv #web安全 #安全 #蓝桥杯 #正则 #正则表达式 #信息与通信 #时序数据库 #程序人生 #科研 #博士 #PyCharm # 远程调试 # YOLOFuse #产品经理 #ui #团队开发 #墨刀 #figma #Windows 更新 #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #搜索引擎 #导航网 #select #游戏 #大语言模型 #长文本处理 #GLM-4 #Triton推理 #嵌入式 #毕业设计 #系统架构 #rocketmq #Linux #TCP #线程 #线程池 #网络协议 #RAGFlow #DeepSeek-R1 #powerpoint #Com #web #webdav #uni-app #小程序 #notepad++ #es安装 #redis #chatgpt #DeepSeek #AI #DS随心转 #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #开服 #flask #FL Studio #FLStudio #FL Studio2025 #FL Studio2026 #FL Studio25 #FL Studio26 #水果软件 #vim #gcc #yum #lvs #负载均衡 #jetty #scrapy #课程设计 #jvm #SSH # ProxyJump # 跳板机 #哈希算法 #散列表 #dreamweaver #HCIA-Datacom #H12-811 #题库 #最新题库 #计算机网络 #线性回归 #服务器繁忙 #transformer #AI写作 #Agent #程序员 #Android #Bluedroid #ffmpeg #学习笔记 #jdk #udp #酒店客房管理系统 #毕设 #论文 #https #leetcode #wsl #L2C #勒让德到切比雪夫 #钉钉 #机器人 #LLM #3d #深度优先 #DFS #ssl #arm开发 #嵌入式硬件 #企业微信 #堡垒机 #安恒明御堡垒机 #windterm #自动驾驶 #能源 #servlet #todesk #SSM 框架 #孕期健康 #产品服务推荐 #推荐系统 #用户交互 #阻塞队列 #生产者消费者模型 #服务器崩坏原因 #PowerBI #企业 #vllm #Streamlit #Qwen #本地部署 #AI聊天机器人 #数据集 #golang #零售 #AI产品经理 #大模型开发 #mmap #nio #京东云 #语音识别 #rabbitmq #protobuf #我的世界 #游戏私服 #云服务器 #网络安全 #全能视频处理软件 #视频裁剪工具 #视频合并工具 #视频压缩工具 #视频字幕提取 #视频处理工具 #逻辑回归 #智能手机 #YOLO #电脑 #Canal #pjsip #信号处理 #目标跟踪 #社科数据 #数据分析 #数据挖掘 #数据统计 #经管数据 #everything #AB包 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #sqlserver #压枪 #单片机 #数据仓库 #vue3 #天地图 #403 Forbidden #天地图403错误 #服务器403问题 #天地图API #部署报错 #autosar #AI论文写作工具 #学术论文创作 #论文效率提升 #MBA论文写作 #claude #操作系统 #cnn #gitee #求职招聘 #面试 #svm #amdgpu #kfd #ROCm #DisM++ # 系统维护 #蓝耘智算 #数模美赛 #matlab #whisper #守护进程 #复用 #screen #就业 #openclaw #分类 #abtest #iphone #聚类 #树莓派4b安装系统 #TURN # WebRTC # HiChatBox #架构师 #软考 #系统架构师 #OCR #文字检测 #openresty #lua #AI大模型应用开发 #电气工程 #C# #PLC #ESXi #SSH Agent Forwarding # PyTorch # 容器化 #贪心算法 #pdf #paddlepaddle #其他 #新浪微博 #前端框架 #支持向量机 #启发式算法 #需求分析 #scala #测试工具 #压力测试 #oracle #debian #Chat平台 #ARM架构 #CISSP #CISSP考点 #信息安全 #CISSP哪里考 #公众号:厦门微思网络 #+微信号:xmweisi #排序算法 #插入排序 #考研 #软件工程 #adb #1024程序员节 #GB/T4857 #GB/T4857.17 #GB/T4857测试 #HeyGem # 局域网访问 # 批量处理 #claude code #codex #code cli #ccusage #Ascend #MindIE #OBC #银河麒麟 #系统升级 #信创 #国产化 #ModelEngine #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #twitter #gpu算力 #金融 #金融投资Agent #ProCAST2025 #ProCast #脱模 #顶出 #应力计算 #铸造仿真 #变形计算 #ssm #elasticsearch #版本控制 #Git入门 #开发工具 #代码托管 #laravel #里氏替换原则 #幼儿园 #园长 #幼教 #Keycloak #Quarkus #AI编程需求分析 #n8n #推荐算法 #若依 #quartz #框架 #sizeof和strlen区别 #sizeof #strlen #计算数据类型字节数 #计算字符串长度 #googlecloud #七年级上册数学 #有理数 #有理数的加法法则 #绝对值 #流量运营 #用户运营 #串口服务器 #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #文生视频 #CogVideoX #AI部署 #visual studio code #prompt #react.js #react native #智能路由器 #环境搭建 #pandas #matplotlib #mamba #凤希AI伴侣 #双指针 #生信 #tomcat #firefox #我的世界服务器搭建 #minecraft #rust #流量监控 #journalctl #selenium #RAG #全链路优化 #实战教程 #MC #数组 #fastmcp #wordpress #雨云 #LobeChat #vLLM #GPU加速 #长文本理解 #glm-4 #推理部署 #macos #几何学 #拓扑学 #链表 #链表的销毁 #链表的排序 #链表倒置 #判断链表是否有环 #电商 #人脸识别 #人脸核身 #活体检测 #身份认证与人脸对比 #H5 #微信公众号 #python学习路线 #python基础 #python进阶 #python标准库 #eBPF #web3 #SSH反向隧道 # Miniconda # Jupyter远程访问 #数据结构与算法 #grafana #.net #homelab #Lattepanda #Jellyfin #Plex #Emby #Kodi #ICPC #gpu #nvcc #cuda #nvidia #ISP Pipeline #行缓冲 #智慧校园解决方案 #智慧校园一体化平台 #智慧校园选型 #智慧校园采购 #智慧校园软件 #智慧校园专项资金 #智慧校园定制开发 #LangGraph #模型上下文协议 #MultiServerMCPC #load_mcp_tools #load_mcp_prompt #TensorRT # Triton # 推理优化 #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #dubbo #SSH别名 # CUDA #测试流程 #金融项目实战 #P2P #webrtc #微信小程序 #建筑缺陷 #红外 #结构体 #ping通服务器 #读不了内网数据库 #bug菌问答团队 #论文笔记 #游戏美术 #技术美术 #游戏策划 #游戏程序 #用户体验 #漏洞 #数码相机 # 公钥认证 #改行学it #创业创新 #Coze工作流 #AI Agent指挥官 #多智能体系统 # 服务器IP访问 # 端口映射 #HBA卡 #RAID卡 #epoll #高级IO #VS Code调试配置 #无人机 #Deepoc #具身模型 #开发板 #未来 #机器视觉 #6D位姿 #asp.net #tdengine #制造 #涛思数据 #测试覆盖率 #单元测试 #可用性测试 #海外短剧 #海外短剧app开发 #海外短剧系统开发 #短剧APP #短剧APP开发 #短剧系统开发 #海外短剧项目 #Proxmox VE #虚拟化 #硬件 #lstm #智慧城市 #LoRA # RTX 3090 # lora-scripts #Cpolar #国庆假期 #服务器告警 #GPU服务器 #8U #硬件架构 #fiddler #rtmp #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 #ddos #windbg分析蓝屏教程 #Node.js #漏洞检测 #CVE-2025-27210 #ROS #Modbus #IFix #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #anaconda #虚拟环境 #fpga开发 #LVDS #高速ADC #DDR #游戏机 #JumpServer #FRP #UDP的API使用 #远程连接 #振镜 #振镜焊接 #Modbus-TCP #ai编程 #azure #xeon #编辑器 #SRS #流媒体 #直播 #ida #UDP套接字编程 #UDP协议 #网络测试 #研发管理 #禅道 #禅道云端部署 #mapreduce #maven #glibc #中间件 #SSE #zabbix #ONLYOFFICE #MCP 服务器 #Nacos #微服务 #三种参数 #参数的校验 #fastAPI #STUN # TURN # NAT穿透 #蓝牙 #LE Audio #BAP #RAID #RAID技术 #磁盘 #存储 #计算机 #连锁药店 #连锁店 #目标检测 #YOLO26 #YOLO11 #xlwings #Excel #unity3d #服务器框架 #Fantasy #llm #pytest #tcpdump #embedding #Ubuntu #Steam #饥荒联机版 #IndexTTS2 # 阿里云安骑士 # 木马查杀 #零代码平台 #AI开发 #Karalon #AI Test #命令模式 #RustDesk #IndexTTS 2.0 #本地化部署 #YOLOv8 # 目标检测 # Docker镜像 #文件IO #输入输出流 #esp32教程 #行为模式分析 #数据 #应用层 #跨领域 #敏感信息 #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #模版 #函数 #类 #笔试 #visual studio #CNAS #CMA #程序文件 #图像处理 #yolo #CPU #监测 #车辆排放 #敏捷流程 #paddleocr #高品质会员管理系统 #收银系统 #同城配送 #最好用的电商系统 #最好用的系统 #推荐的前十系统 #JAVA PHP 小程序 #Spring AI #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #LabVIEW知识 #LabVIEW程序 #labview #LabVIEW功能 #ipv6 #WEB #CMake #Make #C/C++ #Python #vps #Anything-LLM #IDC服务器 #工具集 #排序 # 高并发部署 #pencil #pencil.dev #设计 #Playbook #AI服务器 #AI助手 #企业微信集成 #轻量大模型 #simulink #list #aiohttp #asyncio #异步 #echarts #Rust #软件 #本地生活 #电商系统 #商城 ##程序员和算法的浪漫 #sqlite #SMP(软件制作平台) #EOM(企业经营模型) #应用系统 #ue4 #ue5 #DedicatedServer #独立服务器 #专用服务器 #intellij-idea #database #idea #学术写作辅助 #论文创作效率提升 #AI写论文实测 #Triton #NAS #飞牛NAS #监控 #NVR #EasyNVR #项目申报系统 #项目申报管理 #项目申报 #企业项目申报 #wpf #p2p #JAVA #Java #910B #SSH保活 #Miniconda #远程开发 #语义搜索 #嵌入模型 #Qwen3 #AI推理 #rdp #海外服务器安装宝塔面板 #翻译 #开源工具 #openlayers #bmap #tile #server #vue #Shiro #反序列化漏洞 #CVE-2016-4437 #vuejs #运营 #React安全 #漏洞分析 #Next.js # GLM-4.6V-Flash-WEB # 显卡驱动备份 #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 #EMC存储 #存储维护 #NetApp存储 #职场发展 #虚拟机 #简单数论 #埃氏筛法 #openEuler #Hadoop #客户端 #DIY机器人工房 #高仿永硕E盘的个人网盘系统源码 #nacos #银河麒麟aarch64 #阳台种菜 #园艺手扎 #Gemini #Nano Banana Pro #汽车 #uvicorn #uvloop #asgi #event #yolov12 #研究生life #ip #typescript #npm #VPS #搭建 #土地承包延包 #领码SPARK #aPaaS+iPaaS #数字化转型 #智能审核 #档案数字化 #信令服务器 #Janus #MediaSoup #群晖 #音乐 #状态模式 #Jetty # CosyVoice3 # 嵌入式服务器 # 远程访问 # 服务器IP配置 #捷配 #pcb工艺 #MS #Materials #Moltbot #2026AI元年 #年度趋势 #国产PLM #瑞华丽PLM #瑞华丽 #PLM #多线程 #性能调优策略 #双锁实现细节 #动态分配节点内存 #markdown #建站 #空间计算 #原型模式 #跳槽 #业界资讯 #google #search #SMTP # 内容安全 # Qwen3Guard #X11转发 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman #区间dp #二进制枚举 #图论 #智能体 #clickhouse #代理 #5G #平板 #交通物流 #智能硬件 # AI翻译机 # 实时翻译 #DDD #tdd #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 # IndexTTS 2.0 # 远程运维 #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #自动化运维 #IO #插件 #策略模式 #r-tree #apache #K8s #镜像 #集群自动化 #TFTP #risc-v #性能测试 #LoadRunner #bytebase #ms-swift # 一锤定音 # 大模型微调 #deepseek #VibeVoice # 语音合成 #CUDA #Docker #tensorflow #wps #dba #SSH公钥认证 # 安全加固 #dynadot #域名 #工厂模式 #Fun-ASR # 语音识别 # WebUI #密码 #cpp #交互 #log #NPU #CANN #Moltbook #Clawdbot #SEO优化 #浏览器自动化 #python #PyTorch 特性 #动态计算图 #张量(Tensor) #自动求导Autograd #GPU 加速 #生态系统与社区支持 #与其他框架的对比 #Qwen3-14B # 大模型部署 # 私有化AI #cascadeur #设计师 #opc ua #opc #大剑师 #nodejs面试题 #SSH免密登录 #vp9 #AutoDL #安全架构 #screen 命令 #运维开发 #指针 #远程桌面 #远程控制 # GLM-TTS # 数据安全 #chrome #集成测试 #静脉曲张 #腿部健康 #spring native #支付 #智能一卡通 #门禁一卡通 #梯控一卡通 #电梯一卡通 #消费一卡通 #一卡通 #考勤一卡通 #远程访问 #远程办公 #飞网 #安全高效 #配置简单 #RK3576 #瑞芯微 #硬件设计 #Gunicorn #WSGI #Flask #并发模型 #容器化 #性能调优 #css3 #bash #逆向工程 #ngrok #ceph #Spring #Spring Boot #RPA #影刀RPA #AI办公 #源代码管理 #社交智慧 #职场生存 #系统思维 #身体管理 #商务宴请 #拒绝油腻 #清醒日常 #chat #iot #智能家居 #健康医疗 #教育电商 #媒体 #SAP #ebs #metaerp #oracle ebs #galeweather.cn #高精度天气预报数据 #光伏功率预测 #风电功率预测 #高精度气象 #爱心代码 #表白代码 #爱心 #tkinter #情人节表白代码 # IndexTTS # GPU集群 #框架搭建 #mybatis #SSH跳转 #贴图 #材质 #WinSCP 下载安装教程 #SFTP #FTP工具 #服务器文件传输 #JT/T808 #车联网 #车载终端 #模拟器 #仿真器 #开发测试 #个人博客 #Anaconda配置云虚拟环境 #测评 #C语言 #vivado license #jupyter #nas #音乐分类 #音频分析 #ViT模型 #Gradio应用 #鼠大侠网络验证系统源码 #可信计算技术 #AI赋能盾构隧道巡检 #开启基建安全新篇章 #以注意力为核心 #YOLOv12 #AI隧道盾构场景 #盾构管壁缺陷病害异常检测预警 #隧道病害缺陷检测 #winscp # 双因素认证 #powerbi #go #嵌入式编译 #ccache #distcc #cursor #puppeteer #鸿蒙系统 #系统安全 #车载系统 #Deepseek #gpt-3 #ARM64 # DDColor # ComfyUI #spine #excel #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #Fluentd #Sonic #日志采集 #进程创建与终止 #企业架构治理 #电力企业IT架构 #IT架构设计 #外卖配送 #处理器模块 #现货库存 #价格优惠 #PM864AK01 #3BSE018161R1 #控制器模块 #迁移重构 #数据安全 #代码迁移 #restful #ajax #转行 #bootstrap #Claude #视频去字幕 #flume #麒麟OS #文件管理 #文件服务器 #国产开源制品管理工具 #Hadess #一文上手 #swagger #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #范式 #实在Agent #UDP #入侵 #日志排查 #榛樿鍒嗙被 #mariadb # 大模型 # 模型训练 #OPCUA #ET模式 #非阻塞 #高并发服务器 #工程实践 #pve #OSS #CLI #JavaScript #langgraph.json #图像识别 #分库分表 #垂直分库 #水平分表 #雪花算法 #分布式ID #跨库查询 #考试系统 #在线考试 #培训考试 #考试练习 #raid #raid阵列 #KMS激活 # 硬件配置 #思维模型 #认知框架 #认知 #算力一体机 #ai算力服务器 #gpt #API #taro #青少年编程 #ambari #bigtop #hdp #hue #kerberos #软件需求 #欧拉 #CSDN #寄存器 #vrrp #脑裂 #keepalived主备 #高可用主备都持有VIP #coffeescript #tornado #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #webpack #儿童AI #图像生成 #H3C #知识库 #Syslog #系统日志 #日志分析 #日志监控 #生产服务器问题查询 #日志过滤 #YOLOFuse # 水冷服务器 # 风冷服务器 #Aluminium #Google #学工管理系统 #学工一体化平台 #学工软件二次开发 #学工平台定制开发 #学工系统服务商 #学工系统源头厂家 #智慧校园学工系统 #材料工程 #智能电视 #vmware #AI生成 # outputs目录 # 自动化 #挖漏洞 #渗透测试 #黑客技术 #攻击溯源 #编程 #blender #warp #stl #漏洞修复 #IIS Crypto #reactjs #sglang #网络攻击模型 #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #大模型部署 #mindie #大模型推理 #ComfyUI # 推理服务器 #cocoa #tcp/ip #网络 #libosinfo #Go并发 #高并发架构 #Goroutine #系统设计 #Dify #鲲鹏 #net core #kestrel #web-server #asp.net-core #elk #esp32 arduino #HistoryServer #Spark #YARN #jobhistory #FASTMCP #因果学习 #三维重建 #高斯溅射 #Tetrazine-Acid #1380500-92-4 #postman #UEFI #BIOS #Legacy BIOS #产品运营 #1panel #内存接口 # 澜起科技 # 服务器主板 #Puppet # IndexTTS2 # TTS #模拟退火算法 #gitea #性能 #优化 #RAM #KMS 激活 #AI智能棋盘 #Rock Pi S #wireshark #eclipse #x86_64 #数字人系统 #MC群组服务器 #汇编 # 服务器迁移 # 回滚方案 #windows11 #系统修复 #视觉检测 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #说话人验证 #声纹识别 #CAM++ #云开发 #claude-code #软件开发 #PTP_1588 #gPTP #农产品物流管理 #物流管理系统 #农产品物流系统 #农产品物流 #xss #rtsp #转发 #unix #CS2 #debian13 #BoringSSL #turn #ICE #信创国产化 #达梦数据库 #未加引号服务路径 #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 # ARM服务器 # 鲲鹏 #IntelliJ IDEA #http头信息 #VSCode # SSH #neo4j #NoSQL #SQL #Llama-Factory # 大模型推理 #Coturn #k8s #Windows #dash #进程等待 #wait #waitpid #树莓派 #温湿度监控 #WhatsApp通知 #IoT #MySQL # 离线AI # 服务器IP # 端口7860 #万悟 #联通元景 #创业管理 #财务管理 #团队协作 #创始人必修课 #数字化决策 #经营管理 #TCP服务器 #开发实战 #SMARC #ARM # 代理转发 #idm #网站 #截图工具 #批量处理图片 #图片格式转换 #图片裁剪 #卷积神经网络 #短剧 #短剧小程序 #短剧系统 #微剧 #LangFlow # 智能运维 # 性能瓶颈分析 # GPU租赁 # 自建服务器 #hibernate #nosql #结构与算法 # 云服务器 #健身房预约系统 #健身房管理系统 #健身管理系统 #web服务器 #文件上传漏洞 #ThingsBoard MCP #Kylin-Server #国产操作系统 #服务器安装 #Android16 #音频性能实战 #音频进阶 #扩展屏应用开发 #android runtime #CTF #域名注册 #新媒体运营 #网站建设 #国外域名 #gateway #Comate #TLS协议 #HTTPS #运维安全 #遛狗 #bug #easyui #网络编程 #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #大学生 #大作业 #esp32 #mosquito #arm64 #SSH复用 # 远程开发 # GPU服务器 # tmux #C++ UA Server #SDK #跨平台开发 #聊天小程序 #UOS #海光K100 #统信 #NFC #智能公交 #服务器计费 #FP-增长 #outlook #错误代码2603 #无网络连接 #2603 #mssql #注入漏洞 #效率神器 #办公技巧 #自动化工具 #Windows技巧 #打工人必备 #MOXA #GATT服务器 #蓝牙低功耗 #服务器解析漏洞 #nodejs #云服务器选购 #Saas #智能体从0到1 #新手入门 #具身智能 #kmeans #练习 #基础练习 #循环 #九九乘法表 #计算机实现 #数字孪生 #三维可视化 # Qwen3Guard-Gen-8B #SQL调优 #EXPLAIN #慢查询日志 #分布式架构 #后端开发 #esb接口 #走处理类报异常 #N8N #safari #随机森林 #le audio #低功耗音频 #通信 #连接 #部署 #昇腾300I DUO #docker-compose #smtp #smtp服务器 #PHP #intellij idea #晶振 #WinDbg #Windows调试 #内存转储分析 #hdfs #华为od #华为od机试 #华为od机考 #华为od最新上机考试题库 #华为OD题库 #华为OD机试双机位C卷 #od机考题库 #AI+ #coze #AI入门 #AI赋能 #c++20 #计组 #数电 #cosmic #运维 #vnstat #AI视频创作系统 #AI视频创作 #AI创作系统 #AI视频生成 #AI工具 #AI创作工具 # 远程连接 #fs7TF #夏天云 #夏天云数据 #知识图谱 #昇腾 #npu #React #Next #CVE-2025-55182 #RSC #视频 #攻防演练 #Java web #红队 #Python3.11 #远程软件 #clawdbot #QQbot #QQ #GB28181 #SIP信令 #SpringBoot #视频监控 #SSH跳板机 # Python3.11 #WT-2026-0001 #QVD-2026-4572 #smartermail #东方仙盟 #API限流 # 频率限制 # 令牌桶算法 #TTS私有化 # 音色克隆 #处理器 #上下文工程 #langgraph #意图识别 #ansys #ansys问题解决办法 #黑群晖 #无U盘 #纯小白 #单例模式 #快递盒检测检测系统 #分布式数据库 #集中式数据库 #业务需求 #选型误 #ESP32 #传感器 #MicroPython # Connection refused #WRF #WRFDA #百度 #teamviewer #蓝湖 #Axure原型发布 #HarmonyOS #数据采集 #浏览器指纹 #vertx #vert.x #vertx4 #runOnContext #网络配置实战 #Web/FTP 服务访问 #计算机网络实验 #外网访问内网服务器 #Cisco 路由器配置 #静态端口映射 #网络运维 #防火墙 #门禁 #梯控 #智能梯控 #Socket网络编程 #工作 #网安应急响应 #gRPC #注册中心 #Tokio #异步编程 #系统编程 #Pin #http服务器 #AutoDL使用教程 #AI大模型训练 #linux常用命令 #PaddleOCR训练 #edge #迭代器模式 #观察者模式 #微PE # GLM # 服务连通性 #机器人学习 #CosyVoice3 # IP配置 # 0.0.0.0 #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #muduo库 #uv #uvx #uv pip #npx #Ruff # 服务器配置 # GPU #服务器架构 #AI推理芯片 # 高并发 #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #勒索病毒 #勒索软件 #加密算法 #.bixi勒索病毒 #数据加密 #CA证书 # 轻量化镜像 # 边缘计算 #milvus #web server #请求处理流程 #Host #SSRF #html5 #知识 #weston #x11 #x11显示服务器 #科普 # 批量部署 #copilot #星际航行 #RSO #机器人操作系统 # TTS服务器 # 键鼠锁定 #agentic bi #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #论文复现 #sql注入 #opc模拟服务器 #MQTT协议 #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #Socket #套接字 #I/O多路复用 #字节序 #娱乐 #计算机毕业设计 #程序定制 #毕设代做 #课设 #政务 #语音生成 #TTS #集成学习 #证书 #华为od机考真题 #华为od机试真题 #华为OD上机考试真题 #华为OD上机考试双机位C卷 #华为ODFLASH坏块监测系统 # ms-swift #osg #服务器线程 # SSL通信 # 动态结构体 #cocos2d #图形渲染 # 数字人系统 # 远程部署 #AI技术 #学术生涯规划 #CCF目录 #基金申请 #职称评定 #论文发表 #科研评价 #顶会顶刊 #个人助理 #数字员工 #JNI #moltbot #漏洞挖掘 #Exchange #sentinel #KMS #slmgr #IT #技术 #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #rustdesk #可再生能源 #绿色算力 #风电 #连接数据库报错 #节日 #ESP32编译服务器 #Ping #DNS域名解析 #Kuikly #openharmony #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 #源码 #闲置物品交易系统 #TRO #TRO侵权 #TRO和解 #仙盟创梦IDE #运维工具 # Base64编码 # 多模态检测 #地理 #遥感 #IPv6 #DNS #reactor反应堆 #动态规划 #面向对象 #Discord机器人 #云部署 #程序那些事 #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 # REST API # keep-alive #安全威胁分析 #Minecraft #Minecraft服务器 #PaperMC #我的世界服务器 #ipmitool #BMC #前端开发 # 黑屏模式 #EN4FE #C #领域驱动 #自由表达演说平台 #演说 #nfs #iscsi #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #AI Agent #开发者工具 #clamav #SPA #单页应用 #web3.py #语义检索 #向量嵌入 #边缘AI # Kontron # SMARC-sAMX8 #智能体来了 #传统行业 #remote-ssh #小艺 #搜索 #glances #代理模式 #Spring AOP #scanf #printf #getchar #putchar #cin #cout #人脸活体检测 #live-pusher #动作引导 #张嘴眨眼摇头 #苹果ios安卓完美兼容 #gnu #企业级存储 #网络设备 #多模态 #微调 #超参 #LLamafactory #Smokeping #GPU #租显卡 #训练推理 #duckdb #强化学习 #策略梯度 #REINFORCE #蒙特卡洛 #AI应用 #ueditor导入word #多进程 #python技巧 #高考 #zotero #WebDAV #同步失败 #轻量化 #低配服务器 #cesium #可视化 #麒麟 #V11 #kylinos #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 #阿里云RDS #Linux多线程 #Java程序员 #Java面试 #Spring源码 #LED #设备树 #GPIO #信息收集 #Langchain-Chatchat # 国产化服务器 # 信创 #.netcore # 自动化运维 # 模型微调 #Autodl私有云 #深度服务器配置 #C₃₂H₄₅N₇O₁₁S₂ #实体经济 #商业模式 #数智红包 #商业变革 #创业干货 #VMware创建虚拟机 #n8n解惑 #Qwen3-VL # 服务状态监控 # 视觉语言模型 #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Zabbix #语音合成 #全栈 #传媒 #隐函数 #常微分方程 #偏微分方程 #线性微分方程 #线性方程组 #非线性方程组 #复变函数 #eureka #计算机现代史 #广播 #组播 #并发服务器 #UDP服务器 #recvfrom函数 #身体实验室 #健康认知重构 #微行动 #NEAT效应 #亚健康自救 #ICT人 #asp.net上传大文件 #高精度农业气象 #递归 #线性dp #webgl #c++高并发 #百万并发 #Termux #Samba #Ward #企业存储 #RustFS #对象存储 #高可用 #三维 #3D #云计算运维 #IPMI #模块 #文本生成 #CPU推理 #CVE-2025-61686 #路径遍历高危漏洞 #4U8卡 AI 服务器 ##AI 服务器选型指南 #GPU 互联 #GPU算力 #ShaderGraph #图形 #uip #日志模块 #VMware Workstation16 #服务器操作系统 #音诺ai翻译机 #AI翻译机 # Ampere Altra Max #sklearn #全文检索 #银河麒麟服务器系统 #ueditor导入pdf ##租显卡 #devops #xml #MinIO服务器启动与配置详解 #数据访问 #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #投标 #标书制作 #A2A #GenAI #VMWare Tool #题解 #图 #dijkstra #迪杰斯特拉 #程序开发 #程序设计 #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #mvc #网络安全大赛 #idc #DHCP #NSP #下一状态预测 #aigc #智能制造 #供应链管理 #工业工程 #库存管理 #实时检测 #量子计算 #DAG #b树 #RK3588 #RK3588J #评估板 #核心板 #嵌入式开发 #SSH密钥 # ControlMaster #HarmonyOS APP #旅游 #AI电商客服 #提词器 #西门子 #汇川 #Blazor #经济学 #数据可视化 #memory mcp #Cursor #网路编程 #zygote #应用进程 #声源定位 #MUSIC #Buck #NVIDIA #交错并联 #DGX #resnet50 #分类识别训练 #SSH代理转发 #OpenManage #Xshell #Finalshell #生物信息学 #组学 #AI 推理 #NV #Spire.Office #隐私合规 #网络安全保险 #法律风险 #风险管理 #memcache #ServBay #C2000 #TI #实时控制MCU #AI服务器电源 # 树莓派 # ARM架构 #企业微信机器人 #本地大模型 #gerrit #ranger #MySQL8.0 #统信UOS #win10 #qemu # OTA升级 # 黄山派 #内网 # 网络延迟 #screen命令 #智能体对传统行业冲击 #行业转型 #系统管理 #服务 #公共MQTT服务器 #代理服务器 #claudeCode #content7 #0day漏洞 #DDoS攻击 #漏洞排查 #超时设置 #客户端/服务器 #挖矿 #Linux病毒 #懒汉式 #恶汉式 #管道Pipe #system V #odoo #win11 #雨云服务器 #教程 #MCSM面板 # DIY主机 # 交叉编译 #路由器 #Redis #分布式锁 #appche #视觉理解 #Moondream2 #多模态AI #c #muduo #TcpServer #accept #ftp #sftp #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #AI-native #国产化OS #OpenHarmony #华为机试 #CS336 #Assignment #Experiments #TinyStories #Ablation #实时音视频 #余行补位 #意义对谈 #余行论 #领导者定义计划 #计算几何 #斜率 #方向归一化 #叉积 #samba # 批量管理 #硬盘克隆 #DiskGenius #ASR #SenseVoice #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #超算中心 #PBS #lsf #反向代理 #报表制作 #职场 #用数据讲故事 #AE #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #PN 结 #ARMv8 #内存模型 #内存屏障 #ArkUI #ArkTS #鸿蒙开发 #node #CCE #Dify-LLM #Flexus #参数估计 #矩估计 #概率论 #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #AITechLab #cpp-python #CUDA版本 #pxe #gmssh #宝塔 #设计规范 #放大电路 #系统安装 #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #MinIO #运动 #期刊 #SCI #基础语法 #标识符 #常量与变量 #数据类型 #运算符与表达式 #POC #问答 #交付 #pyqt #AI应用编程 #r语言 #游戏服务器断线 #百度文库 #爱企查 #旋转验证码 #验证码识别 #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #主板 #总体设计 #电源树 #框图 #Archcraft #STDIO传输 #SSE传输 #WebMVC #WebFlux #Linly-Talker # 数字人 # 服务器稳定性 #okhttp #人大金仓 #Kingbase #电子电气架构 #系统工程与系统架构的内涵 #Routine #starrocks #Taiji #STL #string #格式工厂 #L6 #L10 #L9 #OpenAI #故障 #Beidou #北斗 #SSR #numpy #docker安装seata #composer #symfony #java-zookeeper #poll #proc # AI部署 #人脸识别sdk #视频编解码 #远程更新 #缓存更新 #多指令适配 #物料关联计划 #个性化推荐 #BERT模型 #防毒面罩 #防尘面罩 #编程助手 #pipeline #Transformers #NLP #AI运维 #DevOps自动化 #Prometheus #决策树 #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #DooTask #交换机 #三层交换机 #个人电脑 #开关电源 #热敏电阻 #PTC热敏电阻 #一人公司 #独立开发者 #思爱普 #SAP S/4HANA #ABAP #NetWeaver # 权限修复 #WAN2.2 #SQL注入主机 #统信操作系统 #戴尔服务器 #戴尔730 #装系统 #人形机器人 #人机交互 #junit #EventLoop #电梯 #电梯运力 #电梯门禁 #vncdotool #链接VNC服务器 #如何隐藏光标 #字符串 #时间复杂度 #空间复杂度 #bond #服务器链路聚合 #网卡绑定 #数据报系统 #FHSS #算力建设 #lucene #编程语言 #ETL管道 #向量存储 #数据预处理 #DocumentReader #spring ai #oauth2 #nmodbus4类库使用教程 #江协 #瑞萨 #OLED屏幕移植 # 高温监控 #图像分类 #图像分割 #yolo26算法 # 环境迁移 #2025年 #AI工具集成 #容器化部署 #CMC #AI教程 #Matrox MIL #二次开发 #一周会议与活动 #ICLR #CCF #自动化巡检 #istio #服务发现 # 串口服务器 # NPort5630 #Gateway #认证服务器集成详解 #SEW #赛威 #SEW变频器 #cpu #rag #后端框架 #RWK35xx #语音流 #实时传输 #ossinsight #adobe #canvas层级太高 #canvas遮挡问题 #盖住其他元素 #苹果ios手机 #安卓手机 #调整画布层级 #数据迁移 #测速 #iperf #iperf3 #express #cherry studio # child_process #分子动力学 #化工仿真 #free #vmstat #sar #小智 #scikit-learn #api #key #AI作画 #计算机外设 #boltbot #tekton #DuckDB #协议 #Arduino BLDC #核辐射区域探测机器人 #xshell #host key #rsync # 数据同步 #基金 #股票 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu #Python办公自动化 #Python办公 #jquery #fork函数 #进程创建 #进程终止 #session #JADX-AI 插件