研发三维GIS系统笔记/框架改造/智能指针重构框架-003

研发,三维,gis,系统,笔记,框架,改造,智能,指针,重构 · 浏览次数 : 14

小编点评

## Content generation summary This document explains how to implement smart pointers for CELLObject objects in a multithreaded and shared-from-this context. **1. Using smart pointers for better performance:** * Cell objects are typically allocated and used extensively. * Sharing the same smart pointer across multiple threads can be inefficient and cause memory leaks. * Smart pointers offer better performance by managing memory automatically and preventing unnecessary allocations. **2. Base class modification:** * CellObject is the base class for all Cell objects. * This allows us to gradually migrate existing Cell objects to use smart pointers. * The `toPtr` method allows converting a shared pointer to a specific type. **3. Code changes for smart pointers:** * CellQuadTree now uses a `NodePtr` to represent child nodes. * `NodePtr` allows us to dynamically allocate and release nodes. * `CELLTask` now uses a `TaskPtr` to represent tasks. **4. Node release and thread safety:** * The code no longer uses `delete` for child nodes. * Instead, they are set to `nullptr` to prevent dangling pointers and memory leaks. * The `CELLTaskSystem` manages the lifecycle of all tasks and prevents memory issues. **5. Overall architecture:** * The code now uses smart pointers for `CELLObject`s and `CELLTask`s. * This improves performance and reduces memory usage. * The `CELLTaskSystem` ensures thread-safety and prevents memory leaks. * The code is well-organized and easy to understand.

正文

1. 使用智能指针重构系统

  原有的系统都是裸指针,在跨模块与多线程中使用裸指针管理起来很麻烦,尤其是多任务系统中会出现野指针

  

1 class CELLTileTask :public CELLTask
2 {
3 public:
4      CELLQuadTree*   _node;
5       TileId          _tileId;
6      CELLImage       _image;
7 };

任务队列中存储了 CELLQuadTree* _node; 在频繁或者剧烈操作相机的情况下,造成大量的瓦片任务,同时瓦片任务中存储的对四叉树对象已经被释放

在进行使用的过程中,就会出现野指针,为了避免这些问题,引入智能指针来解决对象的生命周期的问题。避免野指针的出现。

2.  基类对象改造

  基类对象是被引擎中的所有其他的类继承使用,所以先改造基类,从基类开始支持智能指针。

 1     class   CELLObject :public std::enable_shared_from_this<CELLObject>
 2     {
 3     public:
 4         using   ObjectPtr   =   std::shared_ptr<CELLObject>;
 5     public:
 6         CELLObject()
 7         {}
 8         virtual ~CELLObject()
 9         {}
10         ObjectPtr   ptr()
11         {
12             return  shared_from_this();
13         }
14         
15         template<class T>   
16         std::shared_ptr<T>  toPtr()
17         {
18             return std::dynamic_pointer_cast<T>(ptr());
19         }
20     };
好处1,std::enable_shared_from_this<CELLObject> 这一句很重要,这样对象中继承了智能指针中的引用计数对象,降低访存次数,提升效率
好处2:可以实现智能指针与裸指针的相互转化,可以从裸指针转换成智能指针。

3.  改造代码
  引擎中四叉树节点
  
using   NodePtr =   std::shared_ptr<CELLQuadTree>;

 


class   CELLQuadTree :public CELLObject
    {
    public:
        enum ChildId
        {
            CHILD_LT,
            CHILD_RT,
            CHILD_LB,
            CHILD_RB,
        };
        enum 
        {
            FLAG_HAS_IMAGE  =   1<<0,
            FLAG_HAS_CULL   =   1<<1,
            FLAG_RENDER     =   1<<2,
        };
    public:
        typedef std::vector<CELLQuadTree*>  ArrayNode;
        typedef CELLTerrainInterface        TerrainApi;
        using   NodePtr =   std::shared_ptr<CELLQuadTree>;
    public:
        TerrainApi*     _terrain;
        /// 数据标志
        uint            _flag;
        /// 对应瓦片id
        TileId          _tileId;
        real2           _vStart;
        real2           _vEnd;

        float2          _uvStart;
        float2          _uvEnd;
        /// 对应瓦片的范围(世界坐标)
        aabb3dr         _aabb;
        /// 位置
        ChildId         _cornerId;
        /// 当前瓦片的父节点,这里不能使用智能指针,否则会造成相互引用,造成智能指针无法释放(相互依赖引用)
        CELLQuadTree*   _parent;
        /// 瓦片的孩子节点,注意这里,使用了智能指针
        NodePtr         _childs[4];
        /// 纹理id
        uint            _textureId;
};

4.  节点示释放代码,不在使用delete 操作


for (int i = 0 ;i < 4 ; ++ i)
{
     _childs[i]  =   nullptr;
}

5.   任务系统改造,使用智能指针对象

 1     class   CELLTask :public CELLObject
 2     {
 3     public:
 4         CELLTask()
 5         {}
 6         virtual ~CELLTask()
 7         {}
 8     };
 9 
10     using   TaskPtr     =   std::shared_ptr<CELLTask>;

 

6.  任务对象
 1  class   CELLTaskSystem
 2     {
 3     public:
 4         class   TaskThread :public CELLThread
 5         {
 6         public:
 7             bool            _exitFlag;
 8             CELLTaskSystem* _system;
 9         public:
10             TaskThread(CELLTaskSystem* pSystem)
11             {
12                 _system     =   pSystem;
13                 _exitFlag   =   true;
14             }
15         public:
16             virtual void    join()
17             {
18                 _exitFlag   =   true;
19                 CELLThread::join();
20 
21             }
22             virtual bool    onCreate()
23             {
24                 _exitFlag   =   false;
25                 return  false;
26             }
27             virtual bool    onRun()
28             {
29                 while (!_exitFlag)
30                 {
31                     _system->run();
32                 }
33                 return  false;
34             }
35             virtual bool    onDestroy()
36             {
37                 return  false;
38             }
39         };
40 
41         typedef std::vector<CELLThread*>    ArrayThread;
42         typedef std::list<TaskPtr>          ArrayTask;
43     public:
44         CELLTaskObserver*   _observer;
45         ArrayThread         _threads;
       /// 这里使用智能指针队列,而不是裸指针
46 ArrayTask _tasks; 47 CELLSemaphore _semphore; 48 CELLMutex _mutex; 49 };

 



 

与研发三维GIS系统笔记/框架改造/智能指针重构框架-003相似的内容:

研发三维GIS系统笔记/框架改造/智能指针重构框架-003

1. 使用智能指针重构系统 原有的系统都是裸指针,在跨模块与多线程中使用裸指针管理起来很麻烦,尤其是多任务系统中会出现野指针 1 class CELLTileTask :public CELLTask 2 { 3 public: 4 CELLQuadTree* _node; 5 TileId _ti

研发三维GIS系统笔记/实现wgs84投影-002

四叉树代码修改完善 原来的代码中,没有使用投影转换,直接使用的是世界坐标(单位是米), CELLQuadTree::CELLQuadTree( CELLTerrainInterface* pInterface ,CELLQuadTree* parent ,const real2 vStart ,co

研发三维GIS系统笔记/实现wgs84投影-001

1. 工作内容,改造引擎,支持wgs84投影 改造原因:目前投影是墨卡托投影(与Google Map一致) 目前的GIS系统是二维的采用这个坐标系是没有问题的 但不支持wgs84瓦片数据以及高程数据,工作中很多数据是wgs84格式的,尤其很多三维GIS都是采用wgs84投影 wgs84 与merca

如何基于three.js(webgl)引擎架构,研发一套通过配置就能自动生成的3D机房系统

自动化3D机房、微模块、3D机房、3D数据中心、科技感数据中心、三维机房、3d建筑,3d消防,消防演习模拟,3d库房,3d档案室,3d密集架,webGL,threejs,3d机房,bim管理系统

计算机视觉五大核心研究任务全解:分类识别、检测分割、人体分析、三维视觉、视频分析

> 本篇文章深入探讨了计算视觉的定义和主要任务。内容涵盖了图像分类与识别、物体检测与分割、人体分析、三维计算机视觉、视频理解与分析等技术,最后展示了无监督学习与自监督学习在计算机视觉中的应用。 > 作者 TechLead,拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦

[转帖]三星研发出首个基于存算一体技术的GPU大型计算系统 (收录于存算一体芯片赛道投资融资分析)

https://zhuanlan.zhihu.com/p/591850021 陈巍谈芯:产业巨头已经打通存算一体技术的落地通道,存算一体技术加快应用部署。与未使用HBM-PIM(HBM-PIM GPU v.s. HBM GPU)相比,仅用20nm工艺就使7nm集群计算性能提升了2.5倍。这个思路也是

uniapp+vue3聊天室|uni-app+vite4+uv-ui跨端仿微信app聊天语音/朋友圈

原创研发uniapp+vue3+pinia2跨三端仿微信app聊天模板Uniapp-Wechat。 uni-vue3-wchat基于uni-app+vue3+pinia2+uni-ui+uv-ui等技术跨端仿制微信App界面聊天项目,支持编译到H5+小程序端+App端。实现编辑框多行消息/emoj混

研发高阶能力之「技术规划」

企业有三类角色:worker、partner、owner,不同角色基于不同的身份认同,工作在不同的平面,表现出不同的行为,创造出不同的价值,从而分配不同的蛋糕份额

DevOps | 产研协同效能提升之评审、审批流、质量卡点

研发过程中有各种需求的评审、审批流和质量卡点,有的是为了质量把关,有的是为了彰显权力,还有一些是为了信息告知。本文主要讨论在软件开发过程中涉及的评审、审批和质量卡点三种情况,同时探讨对研发流程的影响,在这过程中如何去提效。 同团队内部评审 同团队之间的评审包括产品团队内部的PRD评审,RD团队内部的

一图看懂CodeArts Inspector 三大特性,带你玩转漏洞管理服务

华为云漏洞管理服务CodeArts Inspector是面向软件研发和服务运维提供的一站式漏洞管理能力,通过持续评估系统和应用等资产,内置风险量化管理和在线风险分析处置能力,帮助组织快速感应和响应漏洞,并及时有效地完成漏洞修复工作,更好地应对潜在的安全威胁。