Files
XCEngine/docs/api/core/refcounted/refcounted.md
ssdfasd a9f882f233 docs: 修正 API 文档准确性 (第二轮检查)
修复的问题:
- math: 修复 Quaternion::Normalize 链接错误
- containers: HashMap 迭代器示例使用不存在的 cbegin/cend,删除冗余构造函数声明
- core: RefCounted 析构函数访问级别修正 (protected)
- debug: LogLevelToString 示例返回值大小写修正
- memory: 修正 LinearAllocator::Reallocate 返回 nullptr,ProxyAllocator 统计描述,头文件路径 IAllocator.h -> Allocator.h
- resources: Texture::Create mipLevels 参数描述修正
- rhi: 修复多处链接错误,新增缺失的方法文档
- threading: TaskSystem 配置项未实现状态标注,Wait 方法空实现标注
2026-03-19 00:31:14 +08:00

1.5 KiB
Raw Blame History

RefCounted

命名空间: XCEngine::Core

类型: class

描述: 引用计数基类,提供线程安全的引用计数生命周期管理。

概述

RefCounted 是一个简单的引用计数基类。当引用计数归零时,对象会自动删除。它提供了 AddRefRelease 方法,线程安全地管理引用计数。

公共方法

构造/析构

方法 描述
RefCounted() 构造函数,初始引用计数为 1
protected virtual ~RefCounted() 虚析构函数(受保护,不允许直接删除)

引用计数

方法 描述
void AddRef() 增加引用计数
void Release() 减少引用计数(归零时自动 delete this
uint32_t GetRefCount() const 获取当前引用计数

方法列表

方法 描述
AddRef 增加引用计数
Release 减少引用计数
GetRefCount 获取当前引用计数

使用示例

class MyObject : public RefCounted {
public:
    MyObject() { /* ... */ }
    ~MyObject() { /* ... */ }
    
    void DoSomething() { /* ... */ }
};

// 使用
MyObject* obj = new MyObject();  // refCount = 1
obj->AddRef();                   // refCount = 2
obj->Release();                   // refCount = 1
obj->Release();                   // refCount = 0, 自动 delete

相关文档