什么是时间内存分配
What is temporal memory allocation?
我正在研究表达模板和mshadow codebase。在这里的Wiki页面中,他们提供了一个示例,该示例是不良解决方案,因为它进行了时间内存分配和交易。那是什么,给定代码做这样的事情是什么?
推荐代码:
// Naive solution for vector operation overloading
struct Vec {
int len;
float* dptr;
Vec(int len) : len(len) {
dptr = new float[len];
}
Vec(const Vec& src) : len(src.len) {
dptr = new float[len];
memcpy(dptr, src.dptr, sizeof(float)*len );
}
~Vec(void) {
delete [] dptr;
}
};
inline Vec operator+(const Vec &lhs, const Vec &rhs) {
Vec res(lhs.len);
for (int i = 0; i < lhs.len; ++i) {
res.dptr[i] = lhs.dptr[i] + rhs.dptr[i];
}
return res;
}
在这种情况下,他们正在谈论在内存中分配一些空间以暂时保持值。
例如,当您做
时a = a + b;
编译器将执行以下
- 分配一个新的内存块
- 计算
a
和b
的总和,并将结果写入该块 - 将临时存储的结果复制到
a
您可以看到,没有理由执行#1或#3,因为总和实际上可以直接进入a
。
现在您可能会问:为什么编译器不能理解a=a+b
和a+=b
是同一件事。答案是因为尽管对于int
,double
,size_t
这始终是正确的,但可以实现这两个操作员做一些不同的类别。看看std::ofstream
如何使用左BITSHIFT操作员来完全不同的东西。
相关文章:
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?