作用域
-
c++中的mutex和lock_guard是什么_c++互斥锁使用方法【线程安全】
mutex 是 C++ 基础互斥锁,不支持递归和超时;lock_guard 是 RAII 锁管理器,构造时加锁、析构时自动解锁,确保异常安全,不可复制或手动解锁。 mutex 是 C++ 中用于保护共享资源的互斥量,而 lock_guard 是一个 RAII 风格的锁管理器,它在构造时自动加锁、析构…
-
c++如何使用LLVM/Clang LibTooling_c++编写自己的静态分析工具
首先需搭建LLVM/Clang开发环境并配置CMake,接着通过继承ASTFrontendAction定义MallocFindAction,使用MatchFinder结合AST Matcher查找名为”malloc”的函数调用,匹配结果在MallocCallHandler::…
-
c++中的继承构造函数(Inheriting Constructors)是什么_c++ C++11 using声明【语法】
继承构造函数是C++11特性,通过using Base::Base声明将基类构造函数签名注入派生类,由编译器自动生成对应构造函数,形参一致且函数体等价于调用基类构造函数。 继承构造函数是C++11引入的特性,允许派生类直接复用基类的构造函数,而无需手动编写转发构造函数。它通过 using 声明实现,…
-
c++中的RAII是什么意思_c++资源获取即初始化技术详解【核心思想】
RAII是C++中将资源生命周期绑定到对象生命周期的设计哲学:资源在构造时获取、析构时自动释放,确保异常安全与确定性清理;要求构造函数完全成功或彻底失败,支持移动语义以安全转移所有权,并广泛体现于std::unique_ptr、std::lock_guard等标准库工具中。 RAII(Resourc…
-
c++ 运算符重载代码 c++ operator重载实例
运算符重载允许为类类型定义运算符行为,如复数类中重载+和 在C++中,运算符重载允许我们为自定义类型(如类)赋予标准运算符新的行为。通过重载,可以让对象像基本数据类型一样使用+、-、==等操作符,提升代码可读性和易用性。 什么是运算符重载 运算符重载是函数重载的一种形式,它使我们能重新定义已有运算符…
-
c++中的两阶段名称查找是什么_c++模板编译核心机制【高级】
两阶段名称查找是C++模板编译中分两阶段解析名字的规则:第一阶段在模板定义时查找非依赖名字并立即报错;第二阶段在实例化时查找依赖名字,支持ADL和特化。 两阶段名称查找是什么 两阶段名称查找是 C++ 模板编译过程中对名字(标识符)进行解析的特殊规则,核心在于:模板定义时和实例化时,分两个阶段查找未…
-
c++如何使用std::unique_ptr的自定义删除器_c++智能指针与资源管理扩展
自定义删除器用于适配非普通堆内存资源的释放,如文件句柄、C库资源或数组,确保正确调用fclose、delete[]等清理操作。 在C++中,std::unique_ptr 是一种独占式智能指针,用于自动管理动态分配资源的生命周期。默认情况下,它会在析构时调用 delete 释放所持有的对象。但在某些…
-
C++ delete与delete[]的区别_C++数组内存释放的正确姿势
delete用于释放单个对象,delete[]用于释放对象数组;误用会导致析构函数未被正确调用或未定义行为,尤其类类型数组将引发内存泄漏,应始终匹配new与delete形式,并优先使用智能指针和容器管理内存。 在C++中,delete 和 delete[] 都用于释放动态分配的内存,但它们的使用场景…
-
c++ define和const区别 c++宏定义优缺点分析
const 提供类型安全、作用域控制和调试支持,而 #define 是简单文本替换,无类型检查;应优先使用 const 或 constexpr,仅在条件编译等必要时使用 #define。 在C++中,#define 和 const 都可以用来定义常量,但它们在机制、作用域、类型安全和编译处理上有显著…
-
C++如何解决野指针问题_C++ nullptr与NULL的区别及最佳实践
野指针指向不确定或已释放内存,访问会导致程序崩溃。使用nullptr替代NULL可提升类型安全,避免重载歧义,并通过初始化为nullptr、删除后置空及使用前判空等实践降低风险。配合智能指针和容器能进一步减少野指针问题。 野指针是C++中常见且危险的问题,它指向一块不确定或已被释放的内存区域。访问野…