加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 差异:A * a =新A();与A B; A * c =&b;

发布时间:2020-12-16 10:26:12 所属栏目:百科 来源:网络整理
导读:在采访中被问到. A * a =新A(); A b; A * c = b; 1和2有什么区别? 我在第二个语句中说过,对象是在堆栈和堆栈中创建的.我的朋友说对象总是在堆上创建的. 什么是正确的答案? 解决方法 你是对的 – 第二个代码块 – 假设它出现在一个函数中 – 将在堆栈上有b
在采访中被问到.

> A * a =新A();
> A b; A * c =& b;

1和2有什么区别?

我在第二个语句中说过,对象是在堆栈和堆栈中创建的.我的朋友说对象总是在堆上创建的.

什么是正确的答案?

解决方法

你是对的 – 第二个代码块 – 假设它出现在一个函数中 – 将在堆栈上有b和c,但当然取决于A的类型它可能有内部指向堆分配的内存(std) :: string,std :: vector等是这样的例子,如果它们不是空的并且比任何内部缓冲区都大.

也就是说,它本身也会在第一个块的堆栈中 – 它只是它指向的对象 – * a,它必然在堆上.

换句话说,a和c实际上是等价的:基于堆栈的值,但前者指向堆分配的A,而第二个指向另一个堆栈分配的A ….

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读