欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

求栈的长度的C语言函数,c – 编译器如何确定编译器生成的临时函数所需的堆栈大小?...

发布时间:2023/12/20 编程问答 47 豆豆
生活随笔 收集整理的这篇文章主要介绍了 求栈的长度的C语言函数,c – 编译器如何确定编译器生成的临时函数所需的堆栈大小?... 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

考虑以下代码:

class cFoo {

private:

int m1;

char m2;

public:

int doSomething1();

int doSomething2();

int doSomething3();

}

class cBar {

private:

cFoo mFoo;

public:

cFoo getFoo(){ return mFoo; }

}

void some_function_in_the_callstack_hierarchy(cBar aBar) {

int test1 = aBar.getFoo().doSomething1();

int test2 = aBar.getFoo().doSomething2();

...

}

在调用getFoo()的行中,编译器将生成cFoo的临时对象,以便能够调用doSomething1().

编译器是否重用用于这些临时对象的堆栈内存?

“some_function_in_the_callstack_hierarchy”的调用将保留多少堆栈内存?是否为每个生成的临时存储内存?

我的猜测是编译器只为cFoo的一个对象保留内存,并将重用内存用于不同的调用,但如果我添加

int test3 = aBar.getFoo().doSomething3();

我可以看到“some_function_in_the_callstack_hierarchy”所需的堆栈大小更多,而且不仅仅是因为附加的本地int变量.

另一方面,如果我然后更换

cFoo getFoo(){ return mFoo; }

带引用(仅用于测试目的,因为返回对私有成员的引用不好)

const cFoo& getFoo(){ return mFoo; }

它需要的堆栈内存少于一个cFo​​o的大小.

所以对我来说,似乎编译器为函数中的每个生成的临时对象保留了额外的堆栈内存.但这样效率很低.

有人可以解释一下吗?

创作挑战赛新人创作奖励来咯,坚持创作打卡瓜分现金大奖

总结

以上是生活随笔为你收集整理的求栈的长度的C语言函数,c – 编译器如何确定编译器生成的临时函数所需的堆栈大小?...的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。