【UE4 C++】UObject 创建、销毁、内存管理
UObject 的创建
NewObject 模板类
本例使用 UE 4.26,只剩下 NewObject 用来创建 UObject,提供两个带不同可选参数构造函数的模板类
Outer 表示这个对象的外部对象,通常可传 this 指针进去
Name 为对象名,如果没有自定义,默认生成,自带 GetName() 方法获取
template<class T>
T* NewObject(UObject* Outer)
{
T* Object = ::NewObject<T>(Outer);
Object->SetInternalFlags(EInternalObjectFlags::Async);
return Object;
} template<class T>
T* NewObject(UObject* Outer, UClass* Class, FName Name = NAME_None,
EObjectFlags Flags = RF_NoFlags, UObject* Template = nullptr,
bool bCopyTransientsFromClassDefaults = false, FObjectInstancingGraph* InInstanceGraph = nullptr)
{
T* Object = ::NewObject<T>(Outer, Class, Name, Flags, Template, bCopyTransientsFromClassDefaults, InInstanceGraph);
Object->SetInternalFlags(EInternalObjectFlags::Async);
return Object;
}
实践
创建一个 UObject 类
UCLASS()
class TIPS_API UItemObject : public UObject
{
GENERATED_BODY()
FString m_Name;
public:
UItemObject() {
m_Name = GetName();
UE_LOG(LogTemp, Warning, TEXT(__FUNCTION__" %s"), *m_Name);
} ~UItemObject() { UE_LOG(LogTemp, Warning, TEXT(__FUNCTION__" %s"), *m_Name); }
};
创建 UObject 实例
UItemObject* Obj = NewObject<UItemObject>();
UItemObject* Obj2 = NewObject<UItemObject>(this, TEXT("Obj2"));
UObject 的销毁
自动销毁
UObject及其派生 具有被 UE4 垃圾回收机制管理,因而当指向对象的指针为 nullptr 后,将会被 UE4 自动回收掉
Obj = NewObject<UItemObject>(this, TEXT("Obj"));
Obj = nullptr;
主动销毁
UObject::ConditionalBeginDestroy()
- 异步执行且对象在当前帧内持续有效
- 等待下次GC
Obj->ConditionalBeginDestroy();
Obj = nullptr;
MarkPendingKill()
- 标记为PendingKill,等待回收。指向此实例的指针将设置为NULL,并在下一次GC时删除。
- IsPendingKill 判断是否处于 PendingKill 状态
- ClearPendingKill 清除 PendingKill 状态
Obj->MarkPendingKill();
Obj = nullptr;
Engine\Config \BaseEngine.ini 更改下面参数,设置销毁时间间隔
gc.TimeBetweenPurgingPendingKillObjects=60
强制垃圾回收
UWorld::ForceGarbageCollection 弃用
GEngine->ForceGarbageCollection
GEngine->ForceGarbageCollection(true);
原生对象内存管理
new/delete
需要手动清理,易造成内存泄漏
delete 一般将指针置为 nullptr ,防止指向的地址不固定
class SimpleObject {
public:
SimpleObject() { UE_LOG(LogTemp, Warning, TEXT(__FUNCTION__)); }
~SimpleObject() { UE_LOG(LogTemp, Warning, TEXT(__FUNCTION__)); }
};
SimpleObject* Obj = new SimpleObject(); delete Obj;
Obj = nullptr;

使用智能指针
- 对于非 UObject 的对象,可以使用智能指针进行管理
- 当引用计数为0时,对象自动销毁
UObject 对象内存管理
UPROPERTY() 保持引用
支持容器 TArray、TMap 的 <UObject*>类型。TArray、TMap使用UPROPERTY() ,也可以使元素对象常驻内存
UPROPERTY()
class UItemObject* m_ItemObject2; UPROPERTY()
TArray<class UItemObject*> m_ObjList1;
AddToRoot 和 RemoveFromRoot 标记不被GC/移除标记
构造时 和 AddToRoot 一起
析构时和 RemveFromRoot 一起
//创建对象
m_ItemObject1 = NewObject<UItemObject>(this,TEXT("m_ItemObject1"));
m_ItemObject1->AddToRoot(); // 释放对象
m_ItemObject1->RemoveFromRoot();
m_ItemObject1 = nullptr;

FStreamableManager 资源卸载
FStreamableHandle::ReleaseHandle()TSharedPtr<FStreamableHandle> Handle = UAssetManager::GetStreamableManager().RequestSyncLoad(AssetPath);
UObject* Obj = Handle->GetLoadedAsset();
Handle->ReleaseHandle();
AActor 销毁
Destroy()方法
UActorComponent
DestroyComponent()方法
扩展:FGCObjectScopeGuard
【UE4 C++】UObject 创建、销毁、内存管理的更多相关文章
- UIView的创建与内存管理
学习过程中遇到一些问题,现在记录下来,以后忘记以便翻看. 创建工程的步骤: xcode的ARC改为MRC .h文件中的strong改为retain .m文件中加入dealloc方法 .m文件中_win ...
- 关于Image创建的内存管理
image创建方法 [UIImage imageNamed:imageName] 上述方法创建的image,会常驻在内存中,不会随着imageView的dealloc而释放内存. NSString * ...
- Object-c 内存管理
内存管理 主要内容 1.内存管理的概念 2.引用计数 3.如何持有对象所有权 4.自动释放池 5.@property的使用 什么是内存管理 内存管理是关于如何管理对象生 ...
- nginx源码分析—内存池结构ngx_pool_t及内存管理
Content 0. 序 1. 内存池结构 1.1 ngx_pool_t结构 1.2 其他相关结构 1.3 ngx_pool_t的逻辑结构 2. 内存池操作 2.1 创建内存池 2.2 销毁内存池 2 ...
- TaskTracker节点上的内存管理器
Hadoop平台的最大优势就是充分地利用了廉价的PC机,这也就使得集群中的工作节点存在一个重要的问题——节点所在的PC机内存资源有限(这里所说的工作节点指的是TaskTracker节点),执行任务时常 ...
- 内存管理运算符new delete与内存管理函数malloc free的区别——已经他们对对象创建的过程。
(1)内存管理函数与内存管理运算符的区别 内存管理函数有内存分配函数,malloc calloc realloc 以及内存释放函数free. 内存管理运算符有new 和delete. 两种内存管理方式 ...
- BBS项目详解(forms快速创建登陆页面,登陆验证、通过阅读器进行头像上传的预览、内存管理器)
BBS项目涉及的知识点 django中知识点 钩子函数(局部钩子和全局钩子) 1.局部钩子就是用来做合法性校验,比如用户名有没有被使用等 2.全局的就是用来做对比校验,比如两次输入的密码是否一致 3. ...
- 使用虚幻引擎中的C++导论(四-内存管理与垃圾回收)(终)
使用虚幻引擎中的C++导论(四)(终) 第一,这篇是我翻译的虚幻4官网的新手编程教程,原文传送门,有的翻译不太好,但大体意思差不多,请支持我O(∩_∩)O谢谢. 第二,某些细节操作,这篇文章省略了,如 ...
- Objective-C内存管理之引用计数
初学者在学习Objective-c的时候,很容易在内存管理这一部分陷入混乱状态,很大一部分原因是没有弄清楚引用计数的原理,搞不明白对象的引用数量,这样就当然无法彻底释放对象的内存了,苹果官方文档在内存 ...
随机推荐
- Dockerfile简介及基于centos7的jdk镜像制作
Dockerfile简介 dockerfile 是一个文本格式的配置文件, 用户可以使用 Dockerfile 来快速创建自定义的镜像, 另外,使用Dockerfile去构建镜像好比使用pom去构建m ...
- 作用域 作用域链 闭包 思想 JS/C++比较
首先,我说的比较是指JS中这种思想/实现方式与C++编译原理中思想/实现方式的比较 参考链接:(比较易懂的介绍,我主要写个人理解) 作用域链: http://www.cnblogs.com/dolph ...
- 基于Ubuntu18.04一站式部署(python-mysql-redis-nginx)
基于Ubuntu18.04一站式部署 Python3.6.8的安装 1. 安装依赖 ~$ sudo apt install openssl* zlib* 2. 安装python3.6.8(个人建议从官 ...
- npm 设置同时从多个包源加载包的方法
随着前后端分离技术的发展成熟,越来越来越多的后台系统甚至前端系统采用前后端分离方式,在大型前后端分离系统中,前端往往包含大量的第三方js 包的引用,各个第三方包又可能依赖另外一个第三方包,因此急需要一 ...
- Jmeter系列(18)- 八大组件
说明 取样器(Sampler):不与其他元件发⽣交互的作⽤的元件 逻辑控制器(Logic Controller):只对其⼦节点的sampler有效,⽽其他元件需要与sampler等元件交互 前置处理器 ...
- php文件加密(screw方式)
1.上传已经生成好的执行文件. 2.上传扩展文件到目录: /usr/lib64/php/modules 3.上传配置文件到目录: /etc/php.d 4.执行 ./screw a.php 生成加密后 ...
- 鸿蒙内核源码分析(ELF解析篇) | 你要忘了她姐俩你就不是银 | 百篇博客分析OpenHarmony源码 | v53.02
百篇博客系列篇.本篇为: v53.xx 鸿蒙内核源码分析(ELF解析篇) | 你要忘了她姐俩你就不是银 | 51.c.h.o 加载运行相关篇为: v51.xx 鸿蒙内核源码分析(ELF格式篇) | 应 ...
- P4180-[BJWC2010]严格次小生成树【Kruskal,倍增】
正题 题目链接:https://www.luogu.com.cn/problem/P4180 题目大意 \(n\)个点\(m\)条边的一张无向图,求它的严格次小生成树. \(1\leq n\leq 1 ...
- AT1983-[AGC001E]BBQ Hard【dp,组合数学】
正题 题目链接:https://www.luogu.com.cn/problem/AT1983 题目大意 给出\(n\)个数对\((a_i,b_i)\) 求 \[\sum_{i=1}^n\sum_{j ...
- 小米路由器4a千兆版刷openwrt
现在网上搜小米路由器4a千兆版刷机的都是刷的padavan的,很少能找到openwrt的刷机教程. 首先刷openwrt系统的时候要先刷入引导程序breed,网上有一篇帖子写的很详细(https:// ...