Spo*_*aur 4 c++ templates memory-management
做这样的事情是否使用动态内存分配?
template <class T, int _size>
class CArray
{
public:
...
private:
T m_data[_size];
};
Run Code Online (Sandbox Code Playgroud)
当我创建对象时,有人可以向我解释幕后发生了什么吗?
CArray<SomeObject, 32> myStupidArray;
Run Code Online (Sandbox Code Playgroud)
And*_*ant 11
不,它将被就地分配(例如,在堆栈上,或作为包含对象的一部分).
使用模板,参数在编译时进行评估,以便您的代码有效地成为;
class CArray
{
public:
...
private:
SomeObject m_data[32];
};
Run Code Online (Sandbox Code Playgroud)
如其他答案中所述,模板在编译时进行评估.如果您感兴趣,可以让g ++吐出类层次结构,您可以在其中验证其大小:
template <class T, int _size>
class CArray
{
public:
private:
T m_data[_size];
};
int main(int argc, char **argv) {
CArray<int, 32> myStupidArray1;
CArray<int, 8> myStupidArray2;
CArray<int, 64> myStupidArray3;
CArray<int, 1000> myStupidArray4;
}
Run Code Online (Sandbox Code Playgroud)
编译-fdump-class-hierarchy:
g++ -fdump-class-hierarchy blah.cc
Run Code Online (Sandbox Code Playgroud)
应该有一个blah.cc.t01.class在当前目录中命名的文件:
Class CArray<int, 32>
size=128 align=4
base size=128 base align=4
CArray<int, 32> (0x40be0d80) 0
Class CArray<int, 8>
size=32 align=4
base size=32 base align=4
CArray<int, 8> (0x40be0e80) 0
Class CArray<int, 64>
size=256 align=4
base size=256 base align=4
CArray<int, 64> (0x40be0f80) 0
Class CArray<int, 1000>
size=4000 align=4
base size=4000 base align=4
CArray<int, 1000> (0x40be6000) 0
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2885 次 |
| 最近记录: |