为智能指针定义类型是不好的做法吗?
Is it bad practice to typedef a smart pointer?
我在当前的项目中使用智能指针,当使用它们时,必须键入长行代码似乎非常麻烦。
因为我想让我的代码更清晰,更容易理解,我开始定义智能指针的类型,像这样:
typedef std::unique_ptr<System> SystemPtr;
所以我的问题是,它是坏的做法定义一个智能指针?
这没什么问题,但是你选的名字太糟糕了。有人读不知道这是一个共享指针,一个唯一的指针,一个侵入式引用计数com指针,或只是一个原始指针到System
。
如果你真的需要简洁,
template<class T>using up=std::unique_ptr<T>;
在使用时比计划up<System>
多一个字符,并且使它更清楚地表明这是一个唯一的指针,并且不需要每个类型的类型定义。此外,在某些情况下,它还会导致双关语。
正如其他人所提到的,它没有语法错误。我想补充的是,在大型项目中寻找或依赖像Intellisense这样的东西来轻松地找到定义可能是不愉快的。程序员依赖于保持"在状态"来完成他们最好的工作。即使是像花60秒追踪一个类型定义这样简单的事情,也会破坏良好的状态。
由于这样的原因,我觉得在像您这样的情况下,一般来说,最好不要随意应用类型定义。通过遍历相关作用域的顶部,您应该能够轻松快速地找到变量的类型。
事实上,你的类型并没有那么长(高级元类型可以有多行长)。
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 通过简单的包装指针C++智能指针性能和差异
- 矢量中的自动指针(智能)
- Std::vector的对象/指针/智能指针传递对象(总线错误:10)