当前位置: 首页 > news >正文

第十三章:优化内存管理_《C++性能优化指南》_notes

优化内存管理

      • 一、内存管理基础概念
      • 二、自定义分配器
      • 三、智能指针优化
        • 重点知识
        • 代码示例:智能指针性能对比
      • 四、性能优化关键点总结
      • 多选题
      • 设计题
      • 答案与详解
        • 多选题答案
        • 设计题示例答案(第1题)


一、内存管理基础概念

重点知识

  1. 动态内存分配开销
    • newdelete涉及系统调用,频繁操作会导致性能瓶颈
    • 内存碎片化会降低内存利用率
  2. 自定义内存管理
    • 预分配内存块(内存池)
    • 类专属内存管理器
    • 自定义分配器

代码示例:类专属内存管理器

#include <iostream>
#include <vector>class MemoryPool {
public:static void* Allocate(size_t size) {if (!freeList.empty()) {void* ptr = freeList.back();freeList.pop_back();return ptr;} else {return ::operator new(size); // 系统默认分配}}static void Deallocate(void* ptr, size_t size) {freeList.push_back(ptr);}private:static std::vector<void*> freeList;
};std::vector<void*> MemoryPool::freeList;class MyObject {
public:void* operator new(size_t size) {return MemoryPool::Allocate(size);}void operator delete(void* ptr, size_t size) {MemoryPool::Deallocate(ptr, size);}MyObject(int val) : data(val) {}int getData() const { return data; }private:int data;
};int main() {// 测试内存池MyObject* obj1 = new MyObject(10);MyObject* obj2 = new MyObject(20);std::cout << "obj1 data: " << obj1->getData() << std::endl;std::cout << "obj2 data: " << obj2->getData() << std::endl;delete obj1;delete obj2;// 验证内存回收后重用MyObject* obj3 = new MyObject(30);std::cout << "obj3 data: " << obj3->getData() << std::endl;delete obj3;return 0;
}

代码解析:

  • MemoryPool管理空闲内存块,Allocate优先使用空闲列表
  • MyObject重载newdelete,使用自定义内存池
  • main函数测试内存分配、释放和重用

编译运行:

g++ -std=c++11 mem_pool.cpp -o mem_pool && ./mem_pool

二、自定义分配器

重点知识

  1. STL容器默认分配器性能问题
    • 频繁小内存分配效率低
  2. 实现自定义分配器
    • 必须提供allocatedeallocate等方法
    • 需要处理类型定义和模板参数

代码示例:固定大小内存分配器

#include <iostream>
#include <vector>
#include <memory>template <typename T>
class FixedAllocator {
public:using value_type = T;FixedAllocator() = default;template <typename U>FixedAllocator(const FixedAllocator<U>&) {}T* allocate(size_t n) {if (n != 1) {throw std::bad_alloc(); // 仅支持单对象分配}return static_cast<T*>(::operator new(sizeof(T)));}void deallocate(T* p, size_t n) {::operator delete(p);}
};// 允许不同模板实例间的转换
template <typename T, typename U>
bool operator==(const FixedAllocator<T>&, const FixedAllocator<U>&) {return true;
}int main() {std::vector<int, FixedAllocator<int>> vec;for (int i = 0; i < 5; ++i) {vec.push_back(i);}std::cout << "Vector elements: ";for (auto v : vec) {std::cout << v << " ";}std::cout << std::endl;return 0;
}

代码解析:

  • FixedAllocator实现固定大小的内存分配
  • std::vector结合使用,减少内存分配次数
  • main测试自定义分配器的容器使用

编译运行:

g++ -std=c++11 custom_allocator.cpp -o custom_allocator && ./custom_allocator

三、智能指针优化

重点知识
  1. std::make_shared vs new
    • make_shared合并控制块和对象内存,提升局部性
  2. 避免循环引用
    • 使用weak_ptr打破循环
代码示例:智能指针性能对比
#include <iostream>
#include <memory>
#include <chrono>class HeavyObject {
public:HeavyObject() { data = new int[1000]; }~HeavyObject() { delete[] data; }
private:int* data;
};void test_make_shared() {auto start = std::chrono::high_resolution_clock::now();for (int i = 0; i < 10000; ++i) {auto p = std::make_shared<HeavyObject>();}auto end = std::chrono::high_resolution_clock::now();std::cout << "make_shared time: " << std::chrono::duration_cast<std::chrono::milliseconds>(end - start).count()<< " ms\n";
}void test_new_shared() {auto start = std::chrono::high_resolution_clock::now();for (int i = 0; i < 10000; ++i) {auto p = std::shared_ptr<HeavyObject>(new HeavyObject);}auto end = std::chrono::high_resolution_clock::now();std::cout << "new+shared_ptr time: "<< std::chrono::duration_cast<std::chrono::milliseconds>(end - start).count()<< " ms\n";
}int main() {test_make_shared();test_new_shared();return 0;
}

代码解析:

  • 对比make_shared和直接new的性能差异
  • HeavyObject模拟大对象分配
  • 使用高精度计时器测量执行时间

编译运行:

g++ -std=c++11 smart_ptr.cpp -o smart_ptr && ./smart_ptr

四、性能优化关键点总结

  1. 减少系统调用
    • 预分配内存池
    • 批量分配代替单次分配
  2. 提高缓存命中率
    • 对象连续存储(如std::vector
    • 使用make_shared合并内存块
  3. 线程安全考虑
    • 多线程环境需加锁(示例未展示,但实际项目需注意)
  4. 自定义分配器适用场景
    • 频繁小对象分配
    • 特定大小的对象分配

核心知识点总结:

  1. C++内存管理API(new/delete, operator new/delete)
  2. 自定义内存分配器的设计与实现
  3. 类专用内存管理器(per-class allocator)
  4. 内存池技术(memory pool)
  5. 智能指针与所有权管理
  6. 移动语义与右值引用优化
  7. 内存对齐与缓存优化
  8. 内存碎片管理策略
  9. 多线程环境下的内存管理
  10. 标准库容器内存分配策略

多选题

  1. 关于C++内存管理API,哪些说法正确?
    A. operator new可以重载实现自定义内存分配策略
    B. delete表达式会自动调用析构函数并释放内存
    C. placement new不会分配内存,只在已分配内存上构造对象
    D. ::operator new(size_t)会触发构造函数调用

  2. 以下哪些方法可以有效减少动态内存分配?
    A. 使用std::make_shared替代new
    B. 预分配内存并复用内存块
    C. 使用std::vector的reserve方法
    D. 优先使用栈分配对象

  3. 关于类专用内存管理器,正确的是:
    A. 需要重载类的operator new和operator delete
    B. 可以避免内存碎片问题
    C. 适用于频繁创建销毁的小对象
    D. 必须使用单例模式实现

  4. 选择内存池技术的主要优势包括:
    A. 减少内存分配/释放的系统调用开销
    B. 提高缓存局部性
    C. 完全消除内存泄漏风险
    D. 支持任意大小的内存分配

  5. 关于std::allocator,正确的是:
    A. 可以通过rebind模板适配不同类型
    B. 分配的内存总是按字节对齐
    C. 默认实现使用malloc/free
    D. 可以完全避免内存碎片

  6. 移动语义对内存管理的优化体现在:
    A. 避免不必要的深拷贝
    B. 允许资源所有权的转移
    C. 完全替代拷贝构造函数
    D. 只能在模板元编程中使用

  7. 多线程环境下内存管理需要注意:
    A. 使用线程局部存储(TLS)分配器
    B. 避免虚假共享(false sharing)
    C. 必须使用锁保护所有分配操作
    D. 优先使用无锁数据结构

  8. 关于内存对齐优化,正确的是:
    A. alignas关键字可以指定对象对齐方式
    B. SIMD指令需要特殊内存对齐
    C. 错误对齐会导致性能下降
    D. 所有平台默认对齐方式相同

  9. 智能指针的内存管理策略包括:
    A. std::shared_ptr使用引用计数
    B. std::unique_ptr支持拷贝语义
    C. std::weak_ptr用于打破循环引用
    D. make_shared比直接new更高效

  10. 减少内存复制的有效方法有:
    A. 使用移动构造函数
    B. 实现写时复制(COW)
    C. 优先传递const引用
    D. 所有返回对象都使用RVO


设计题

  1. 实现固定大小内存池

    // 要求:
    // 1. 支持固定大小的内存块分配
    // 2. 内存池预分配大块内存管理
    // 3. 线程安全
    // 4. 提供性能对比测试
    
  2. 优化std::list的内存分配

    // 要求:
    // 1. 为std::list设计专用分配器
    // 2. 每次批量分配多个节点内存
    // 3. 支持动态调整批量大小
    // 4. 验证内存使用效率提升
    
  3. 无锁内存分配器设计

    // 要求:
    // 1. 实现基于原子操作的内存分配
    // 2. 支持多线程并发分配
    // 3. 避免使用mutex锁
    // 4. 测试并发性能指标
    
  4. 对象池模板实现

    // 要求:
    // 1. 模板化设计支持任意类型
    // 2. 对象复用避免重复构造
    // 3. 自动回收机制
    // 4. 测试对象创建性能提升
    
  5. 智能指针自定义删除器优化

    // 要求:
    // 1. 实现内存池绑定的删除器
    // 2. 与std::unique_ptr集成
    // 3. 支持不同内存池实例
    // 4. 验证内存回收正确性
    

答案与详解

多选题答案
  1. ABC
    D错误:operator new只分配内存,不调用构造函数

  2. ABCD
    所有选项均为有效减少动态分配的方法

  3. ABC
    D错误:单例模式不是必须的

  4. AB
    C错误:不能完全消除泄漏;D错误:固定大小

  5. AC
    B错误:对齐由实现决定;D错误:仍可能产生碎片

  6. AB
    C错误:不能完全替代;D错误:通用特性

  7. ABD
    C错误:无锁设计不需要锁

  8. ABC
    D错误:不同平台对齐要求不同

  9. ACD
    B错误:unique_ptr不可拷贝

  10. ABCD
    所有选项均为有效方法


设计题示例答案(第1题)

固定大小内存池实现

#include <iostream>
#include <vector>
#include <memory>
#include <chrono>template <size_t BlockSize>
class FixedMemoryPool {struct Block {char data[BlockSize];Block* next;};Block* freeList = nullptr;std::vector<std::unique_ptr<char[]>> chunks;public:void* allocate() {if (!freeList) {const size_t chunk_size = 1024;auto chunk = std::make_unique<char[]>(chunk_size * BlockSize);chunks.push_back(std::move(chunk));for (size_t i = 0; i < chunk_size; ++i) {Block* blk = reinterpret_cast<Block*>(chunks.back().get() + i * BlockSize);blk->next = freeList;freeList = blk;}}void* result = freeList;freeList = freeList->next;return result;}void deallocate(void* ptr) {Block* blk = static_cast<Block*>(ptr);blk->next = freeList;freeList = blk;}
};struct MyObject {int data[128];
};void test_performance() {const int iterations = 100000;// 测试标准分配auto start_std = std::chrono::high_resolution_clock::now();for (int i = 0; i < iterations; ++i) {auto ptr = new MyObject;delete ptr;}auto end_std = std::chrono::high_resolution_clock::now();// 测试内存池FixedMemoryPool<sizeof(MyObject)> pool;auto start_pool = std::chrono::high_resolution_clock::now();for (int i = 0; i < iterations; ++i) {auto ptr = pool.allocate();pool.deallocate(ptr);}auto end_pool = std::chrono::high_resolution_clock::now();auto std_time = std::chrono::duration_cast<std::chrono::microseconds>(end_std - start_std).count();auto pool_time = std::chrono::duration_cast<std::chrono::microseconds>(end_pool - start_pool).count();std::cout << "Standard alloc: " << std_time << "μs\n"<< "Pool alloc:     " << pool_time << "μs\n"<< "Performance ratio: " << static_cast<double>(std_time)/pool_time << "x\n";
}int main() {test_performance();return 0;
}

测试结果示例:

Standard alloc: 5432μs
Pool alloc:     127μs
Performance ratio: 42.75x

实现要点:

  1. 使用链表管理空闲块
  2. 批量预分配内存块(chunk)
  3. 分配/释放操作O(1)时间复杂度
  4. 线程安全需要额外加锁(示例未包含)
  5. 显著提升小对象分配性能

其他设计题目的答案, 稍后补充
其他设计题需要类似的结构,针对特定问题设计解决方案,并通过性能测试验证优化效果。每个实现应包含:

  • 核心数据结构和算法
  • 内存管理策略
  • 线程安全机制(如果需要)
  • 性能测试对比
  • 正确性验证测试

相关文章:

第十三章:优化内存管理_《C++性能优化指南》_notes

优化内存管理 一、内存管理基础概念二、自定义分配器三、智能指针优化重点知识代码示例&#xff1a;智能指针性能对比 四、性能优化关键点总结多选题设计题答案与详解多选题答案设计题示例答案&#xff08;第1题&#xff09; 一、内存管理基础概念 重点知识 动态内存分配开销…...

requestAnimationFrame和requestIdleCallback分别是什么,是用在什么场景下

深入解析 requestAnimationFrame 和 requestIdleCallback requestAnimationFrame (rAF) 和 requestIdleCallback (rIC) 都是浏览器提供的 异步调度 API&#xff0c;但它们的执行时机和用途完全不同。 API主要用途何时执行是否保证执行适合场景requestAnimationFrame高优先级 U…...

SAP-ABAP:SAP BW模块架构与实战应用详解

SAP BW模块架构与实战应用详解 目录导航 核心架构分层设计数据建模关键技术典型行业应用场景BW/4HANA革新特性实施路线图常见问题解决方案学习资源推荐一、核心架构分层设计 1. 数据仓库层(Data Warehousing Layer) 组件功能说明典型对象🔄 ETL引擎数据抽取、转换、加载Da…...

准确--配置服务器文件数

某些系统可能在 /etc/security/limits.d/ 目录下有额外配置覆盖全局设置。检查是否存在冲突文件&#xff1a; ls /etc/security/limits.d/如果有文件&#xff08;如 90-nproc.conf 或 90-nofile.conf&#xff09;&#xff0c;需编辑或删除这些文件中的冲突配置。 确保系统启用…...

揭秘大数据 | 12、大数据的五大问题 之 大数据管理与大数据分析

书接上文&#xff0c;老夫讲到规划大数据战略、构建大数据的解决方案与体系架构、解决大数据问题及大数据发展历程中通常会依次涉及到大数据存储、大数据管理、大数据分析、数据科学、大数据应用这五大问题。上篇内容主要围绕的是大数据存储&#xff0c;今天主要聊一下大数据管…...

Java操作RabbitMQ

文章目录 Spring集成RabbitMQ1. AMQP&SpringAMQP2. SpringBoot集成RabbitMQ3. 模型work模型 4.交换机Fanout交换机Direct交换机Topic交换机 5.声明式队列和交换机基于API声明基于注解声明 6.消息转换器 Spring集成RabbitMQ 1. AMQP&SpringAMQP AMQP&#xff08;高级消…...

【MySQL】实战篇—项目需求分析:ER图的绘制与关系模型设计

在软件开发中&#xff0c;数据库是信息系统的核心部分&#xff0c;合理的数据库设计能够显著提高系统的性能和可维护性。 ER图&#xff08;实体-关系图&#xff09;是数据库设计的重要工具&#xff0c;它通过图形化的方式描述了数据实体及其相互关系&#xff0c;帮助开发者和设…...

Apache Shiro 统一化实现多端登录(PC端移动端)

Apache Shiro 是一个强大且易用的Java安全框架&#xff0c;提供了身份验证、授权、密码学和会话管理等功能。它被广泛用于保护各种类型的应用程序&#xff0c;包括Web应用、桌面应用、RESTful服务、移动端应用和大型企业级应用。 需求背景 在当今数字化浪潮的推动下&#xff…...

es新增运算符

?? ( 空值合并运算符) ?. (可选链式运算符) ?? (空值合并赋值操作符) // ?? ( 空值合并运算符)&#xff1a;这个运算符主要是左侧为null和undefined&#xff0c;直接返回右侧值 let result value ?? 默认值;. ??&#xff08;空值合并运算符&#xff09; ✅ 用于…...

数据库三级填空+应用(2)

sysadmin、dbcreator 数据是面向主题的&#xff08;2&#xff09;、集成的、非易失的、随时间不断变化的数据集合&#xff0c; 数据字典 【答案】完整性约束 数据模型成分 33【解析】顺序图主要用于描述系统内对象之间的消息发送和接收序列。 34如果把舍弃的元组也保存在结果关…...

贪心算法经典应用:最优答疑调度策略详解与Python实现

目录 引言&#xff1a;从现实场景到算法设计 一、问题背景与数学建模 1.1 现实场景抽象 1.2 时间线分析 二、贪心策略的数学证明与选择依据 2.1 贪心选择性质 2.2 证明过程 三、算法实现与代码解析 3.1 算法步骤分解 3.2 代码亮点解析 四、测试案例与结果验证 4.1 …...

把手搭建vue前后端管理系统-TAB标签通过pinia来进行管理(二十六)

目标&#xff1a;通过pinia的store来进行组件状态的统一管理&#xff0c;这样大家都可以共用到这个组件的状态信息&#xff0c;就可以实现组件的联动 一、添加侧边栏菜单的点击事件&#xff1a; 1、CommonAside.vue里面添加click的事件 <el-menu-itemv-for"item in …...

Python与数据库

目录 一、数据库 1、数据库的概念 2、数据库的表 3、字段详解 二、SQL数据库语句 1、了解SQL命令 2、CREATE命令 3、INSERT命令 三、数据库和SQL命令 四、数据库的查询与修改 1、SELECT命令 2、UPDATE命令 3、DELETE命令 4、DROP TABLE 5、SQL的注意事项 五、处…...

MyBatis中mapper.xml 的sql映射规则

一、SQL 映射文件核心元素 MyBatis 映射文件的顶级元素&#xff08;按定义顺序&#xff09;&#xff1a; cache&#xff1a;命名空间的缓存配置。cache-ref&#xff1a;引用其他命名空间的缓存。resultMap&#xff1a;自定义结果集映射。sql&#xff1a;可重用的 SQL 片段。i…...

ubuntu22.04安装搜狗输入法保姆教程~

一、添加中文语言支持 1.首先打开设置,找到Language and Region 2.点击Manage Installed Languages 3.点击 Install/Remove Languages... 4.选中Chinese (simplified),点击Apply...

Jenkins 配置python项目和allure

Jenkins新建项目 新建ry-api-auto-test。 添加项目描述&#xff0c;选择gitee令牌。 源码管理&#xff0c;设置仓库地址和凭证。参考我上一篇文章的链接&#xff1a;配置gitee私人令牌和凭证 构建步骤&#xff0c;因为我Jenkins部署在Windows&#xff0c;因此选择batch。…...

keda基于postgresql伸缩dify-api服务

1 概述 dify-api使用postgresql来存储数据&#xff0c;在dify控制台每新建一个聊天机器的聊天框&#xff0c;就会在conversations表里新插入一条记录&#xff0c;并且不断地更新字段updated_at&#xff0c;示例如下&#xff1a; dify# select * from conversations limit 1; …...

蓝桥杯 拼正方形

问题描述 小蓝正在玩拼图游戏。他有&#xff1a; 7385137888721 个 22 的方块10470245 个 11 的方块 他需要从中挑出一些方块来拼出一个正方形。 例如&#xff1a; 用 3 个 22 和 4 个 11 方块可以拼出一个 44 的正方形&#xff1b;用 9 个 22 方块可以拼出一个 66 的正方…...

failed to load steamui.dll”错误:Steam用户的高频崩溃问题解析

当你满心欢喜地双击 Steam 图标&#xff0c;准备进入游戏世界时&#xff0c;屏幕上突然弹出 “failed to load steamui.dll” 的刺眼提示——这是全球数百万 Steam 用户最不愿见到的错误之一。作为 Steam 客户端的核心界面动态链接库文件&#xff0c;steamui.dll 的缺失或损坏会…...

Django之旅:第六节--mysql数据库操作增删改查(二)

前提条件(models.py已经设置好&#xff09;&#xff1a; from django.db import mmodelsclass UserInfo(models.Model):namemodels.CharFIeld(max_length32)passwordmodels.CharFIeld(max_length64)#agemodels.IntegerFIeld()操作数据语法&#xff08;在views.py文件&#xff0…...

6. 使用VUE实现前端页面的分级嵌套

1. 说明 在UI设计中&#xff0c;页面中有些部分的占用空间位置是固定不动&#xff0c;有些部分的区域是根据情况进行动态切换的。比如&#xff0c;一个网页的菜单栏和主题内容展示&#xff0c;往往菜单栏区域的导航按钮占用的空间是固定不动的&#xff0c;当用户点击不同按钮时…...

(UI自动化测试web端)第三篇:元素的常用操作方法_浏览器操作

模拟浏览器的常见操作。 1、最大化浏览器窗口 driver.maximize_window()2、浏览器后退、前进、刷新、关闭、退出 # 调用浏览器的后退 driver.back() # 调用浏览器的前进 driver.forward() # 刷新页面 driver.refresh() # 关闭当前窗口 driver.close() # 退出浏览器 driver.q…...

Ubuntu软件包离线下载安装

1、下载软件包tcpd&#xff0c;并在/var/cache/apt/archives目录中查看。 rooteducoder:~# apt-get install -d tcpd Reading package lists... Done Building dependency tree Reading state information... Done The following NEW packages will be installed:tcpd …...

第十节 MATLAB逻辑运算

MATLAB逻辑运算都是针对元素的操作&#xff0c;运算结果是特殊的逻辑数组&#xff1b;在逻辑分析时&#xff0c;逻辑&#xff08;真&#xff09;用1表示&#xff0c;逻辑假用0表示&#xff0c;逻辑运算中所有的非零元素作为1处理。 注意&#xff1a; 使用MATLAB逻辑运算时的语…...

初识哈希表

一、题意 给定一个整数数组 nums 和一个目标值 target&#xff0c;要求你在数组中找出和为目标值的那两个整数&#xff0c;并返回它们的数组下标。你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素不能使用两遍。 示例&#xff1a; 给定 nums [2, 7, …...

Ajax与Axios,以及Apifox的入门使用

Ajax与Axios&#xff0c;以及Apifox的入门使用 作者&#xff1a;blue 时间&#xff1a;2025.3.20 文章目录 Ajax与Axios&#xff0c;以及Apifox的入门使用1.Ajax2.Axios3.Apifox的基本使用内容Path 参数定义语法用途 Query 参数定义语法用途 1.Ajax 概念&#xff1a;Asynchr…...

jmm-java内存模型

java内存模型----底层原理 底层原理 从Java代码到最终执行的CPU指令的流程&#xff1a; 最开始&#xff0c;我们编写的Java代码&#xff0c;是*.java文件在编译&#xff08;javac命令&#xff09;后&#xff0c;从刚才的*.java文件会变出一个新的Java字节码文件&#xff08;…...

机器学习——KNN数据均一化

在KNN&#xff08;K-近邻&#xff09;算法中&#xff0c;数据均一化&#xff08;归一化&#xff09;是预处理的关键步骤&#xff0c;用于消除不同特征量纲差异对距离计算的影响。以下是两种常用的归一化操作及其核心要点&#xff1a; 质押 一 、主要思想 1. 最值归一化&#…...

页面元素内容太长,给元素添加title

一、需求 页面元素内容太长&#xff0c;给元素添加title 二、实现 1、直接使用title属性 <div target"_blank" class"text-overflow" title"叉车司机">叉车司机</div> 2、使用tdesign的Popup 弹出层 <t-popup>触发元素&…...

【Git多分支使用教程】

Git多分支使用教程 Git多分支使用手册目录多分支只拉取一个多分支拉取指定几个步骤 1&#xff1a;克隆第一个分支步骤 2&#xff1a;获取其他分支 常见问题与解决方法1. 错误&#xff1a;origin/分支名 is not a commit2. 分支名称冲突3. --single-branch 限制 总结 Git多分支使…...

【408--复习笔记】数据结构

【408--复习笔记】数据结构 1.绪论数据结构基本概念• 请简述数据结构的定义。• 数据结构中数据、数据元素、数据项、数据对象的区别是什么&#xff1f; 算法相关• 什么是算法&#xff1f;算法的五个重要特性是什么&#xff1f;• 如何理解算法的时间复杂度和空间复杂度&…...

使用 Vite 提升前端开发体验:入门与配置指南

在现代前端开发中&#xff0c;构建工具的选择对开发效率和项目性能有着至关重要的影响。Vite 是一个新兴的前端构建工具&#xff0c;由 Vue.js 的作者尤雨溪开发&#xff0c;旨在通过利用现代浏览器的原生 ES 模块特性&#xff0c;提供更快的开发服务器启动速度和更高效的热更新…...

WPS JS宏编程教程(从基础到进阶)--第二部分:WPS对象模型与核心操作

第二部分&#xff1a;WPS对象模型与核心操作 WPS对象的属性、方法、集合 工作簿对象常用表达方式工作表对象常用表达方式单元格对象常用表达方式 单元格操作实战 单元格复制与重定位单元格偏移与尺寸调整 颜色设置专题 索引颜色与RGB颜色按条件动态设置单元格颜色 第二部分&…...

瑞数信息《BOTS自动化威胁报告》正式发布

在数字化时代&#xff0c;BOTS自动化攻击如同一场无声的风暴&#xff0c;正以前所未有的态势席卷全球网络空间。为了让各行业更好地应对自动化威胁挑战&#xff0c;瑞数信息作为BOTS自动化攻击防护领域的专业厂商&#xff0c;多年来持续输出BOTS自动化威胁报告&#xff0c;为各…...

【NUUO 摄像头】(弱口令登录漏洞)

漏洞简介&#xff1a;NUUO 是NUUO公司的一款小型网络硬盘录像机设备。 NUUO NVRMini2 3.0.8及之前版本中存在后门调试文件。远程攻击者可通过向后门文件handle_site_config.php发送特定的请求利用该漏洞执行任意命令。 1.Fofa搜索语句&#xff1a; 在Fofa网站&#xff0c;搜索&…...

Android系统的安全问题 - Linux的能力模型(Capability)和 SELinux 的区别

Linux 的能力模型&#xff08;Capabilities&#xff09;和 SELinux 是两种不同的安全机制&#xff0c;虽然它们都用于增强 Linux 系统的安全性&#xff0c;但它们的实现方式和目标有所不同。 1. Linux Capabilities&#xff08;能力模型&#xff09; 作用&#xff1a;传统的 …...

Rust安装并配置配置vscode编译器

一. 下载rustup-init.exe rust下载网址&#xff1a;Getting started - Rust Programming Language 根据系统&#xff0c;选择适合的exe文件 我选择的的是右边64bit的 打开下载的文件 输入1&#xff0c;回车 二. Visual C 安装 自动下载安装vs 等待安装完毕 三. Rust 安装…...

Spring Boot响应压缩配置与优化

一、核心工作机制 1.1 自动协商触发条件 Spring Boot的响应压缩功能基于智能协商机制&#xff0c;需同时满足以下条件方可触发&#xff1a; 客户端支持&#xff1a;请求头包含Accept-Encoding: gzip/deflate数据量阈值&#xff1a;响应体大小超过预设值&#xff08;默认2KB&…...

el-select开启filterable模式,限制输入框输入类型

遇到el-select开启filterable模式查询&#xff0c;下拉框内容是文字与数字组合版&#xff0c;导致校验不准&#xff0c;且没有属性能直接限制focus输入的内容&#xff0c;这时候可以用自定义属性来解决 实例&#xff1a;&#xff08;以只能输入数字为例&#xff09; <el-for…...

创建login.api.js步骤和方法

依次创建 login.api.js、home.api.js...... login.api.js、home.api.js 差不多 导入到 main.js main.js 项目中使用...

在线运行vscode

安装 https://github.com/coder/code-server?utm_sourcesyndication&pubDate20250317 运行前预览脚本 curl -fsSL https://code-server.dev/install.sh | sh -s -- --dry-run运行脚本 curl -fsSL https://code-server.dev/install.sh | sh其他 可以通过后台服务运行&am…...

【Nginx】可以做哪些优化?

一、配置文件优化 1.1 性能优化 开启网页压缩 gzip on;设置网页缓存时间expires 缓存时间;设置连接保持超时keepalive_timeout 服务端超时时间 客户端超时时间;设置连接保持最大请求数keepalive_requests设置工作进程数 worker_processes 与服务器CPU数量…...

springboot在feign和线程池中使用TraceId日志链路追踪(最终版)-2

文章目录 简述问题feign调用时给head加入traceIdFeignConfig配置FeignConfig 局部生效feign拦截器和配置合并为一个文件&#xff08;最终版&#xff09;feign异步调用拦截器配置[不常用] 使用TTL自定义线程池为什么需要TransmittableThreadLocal&#xff1f; 总结参考和拓展阅读…...

datawhale组队学习-大语言模型-task5:主流模型架构及新型架构

目录 5.3 主流架构 5.3.1 编码器-解码器架构 5.3.2 因果解码器架构 5.3.3 前缀解码器架构 5.4 长上下文模型 5.4.1 扩展位置编码 5.4.2 调整上下文窗口 5.4.3 长文本数据 5.5 新型模型架构 5.5.1 参数化状态空间模型 5.5.2 状态空间模型变种 5.3 主流架构 在预训…...

《Matplotlib三维可视化工业实践——从分子模拟到流体力学》

目录 ​编辑 一、工业三维可视化挑战 1.1 典型工业场景需求 1.2 技术痛点分析 二、Matplotlib三维可视化基础 2.1 三维坐标体系构建 2.2 核心三维绘图API 三、分子模拟可视化实战 3.1 晶体结构渲染 3.2 分子轨迹动态演示 四、流体力学场数据优化渲染 4.1 矢量场高效…...

【neo4j数据导出并在其他电脑导入】

停止服务 neo4j stop 导出 neo4j-admin database dump neo4j --to-path"C:\Users\12901\Downloads\test folder" 导入 将 .dump 文件放在一个目录中 mkdir /root/dump-directory mv /root/neo4j.dump /root/dump-directory/ 使用包含 .dump 文件的目录路径作为 …...

多智能体融合(Multi-Agent Fusion)

多智能体融合&#xff08;Multi-Agent Fusion&#xff09;是指在多智能体系统&#xff08;MAS, Multi-Agent System&#xff09;中&#xff0c;多个智能体&#xff08;Agent&#xff09;通过协作、竞争或共享信息&#xff0c;实现全局最优的智能决策和任务执行。该方法广泛应用…...

状态模式(State Pattern)

状态模式&#xff08;State Pattern&#xff09; 如果任务的执行过程是有多个不同状态的&#xff08;比如初始化、运行中、完成等&#xff09;&#xff0c;你可以使用状态模式。每个状态可以有不同的行为&#xff0c;使得任务的状态管理更加清晰和可维护。 示例&#xff1a; …...

Linux网站搭建(新手必看)

1.宝塔Linux面板的功能 宝塔面板是一款服务器管理软件&#xff0c;可以帮助用户建立网站&#xff0c;一键配置服务器环境&#xff0c;使得用户通过web界面就可以轻松的管理安装所用的服务器软件。 2. 宝塔Linux面板的安装 宝塔官网地址&#xff1a;宝塔面板 - 简单好用的Linu…...

JavaEE进阶---Mybatis(预编译SQL即时SQL动态SQL标签池化技术说明)

文章目录 1.经典面试题&#xff08;#{}和${}的区别&#xff09;1.1关于#1.2关于$1.3情况下需要使用$ 2.数据库连接池2.1池化技术图解 3.动态SQL3.1if标签的使用3.2where标签的使用3.3set标签的使用 1.经典面试题&#xff08;#{}和${}的区别&#xff09; 1.1关于# 预编译SQL&a…...