在C++中使用“restrict”类型限定符和“unique_ptr”的限制别名
Restricted Aliasing using `restrict` type qualifier and `unique_ptr` in C++
为了限制指针别名,到目前为止,我已经使用了__restrict__
类型限定符,如GNU GCC编译器提供的C++扩展部分中所述。例如以下功能,
void fn (int *__restrict__ rptr, int &__restrict__ rref)
{
/* ... */
}
接受一个受限指针和一个受限引用作为其参数。
随着unique_ptr
被引入C++标准,我想知道GCC编译器是否会通过使用unique_ptr
来提供相同的优化(或更好的)机器代码。
应该仍然使用像__restrict__
这样的扩展吗?在最近的C++标准中,是否有更好的方法来产生相同的优化(针对指针和引用)?
__restrict__
和unique_ptr
做不同的事情。__restrict__
承诺没有其他内容引用此对象(因此编译器可以进行优化)。unique_ptr
管理堆分配对象的生存期。它不允许优化器做出任何假设。
如果有一种方式可以说"这个unique_ptr
是引用这个对象的唯一方式",那就太好了,但我不知道GCC是否支持这一点。
相关文章:
- 为什么 std::unique 不调用 std::sort?
- CLANG 编译器 说:变量"PTR"可能未初始化
- 在以唯一ptr为值的C++映射中,动态内存何时会被销毁
- 将 ptr 传递给 ptr 到 A 作为参数传递给 A 的函数是不好的做法吗?
- 为共享 ptr 向量实现复制 c'tor?
- 字符和整数中 **(ptr+1) 的值差异
- C++:在不中断共享的情况下通过引用传递共享 PTR?
- 生成"unique"矩阵
- 如何将派生类从基 ptr 分配给 nlohmann::json
- 引用 std::shared:ptr 以避免引用计数
- 我对 std::unique(算法)C++有问题
- 为什么我不能在不进行任何转换的情况下将浮点数放入任何类型的 ptr 中?
- 在调用函数时,ptr** 和 ptr*& 之间是否有区别,或者首选C++?
- 另一种类型的智能ptr,比如具有弱refs的unique_ptr
- 尝试打印出 *ptr++ 的值,以了解它是如何工作的
- 如何控制共享 ptr 引用计数?
- std::shared_ptr::unique(),复制和线程安全
- 如何在C++03中用自定义谓词调用std::unique
- C++中的指针否定 (!ptr == NULL)
- C++14 unique_ptr并使用已删除的函数'std::unique-ptr' unique_ptr错误