博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何让new操作符不分配内存,只调用构造函数
阅读量:4168 次
发布时间:2019-05-26

本文共 1477 字,大约阅读时间需要 4 分钟。

 

问题:c++中的new操作符 通常完成两个工作 分配内存及调用相应的构造出世核函数。

请问:
1)如何让new操作符不分配内存,只调用构造函数?
2) 这样的用法有什么用?

解答:(要求new显式调用构造函数,但不分配内存。)

题目要求不能生成内存 还要调用构造函数 说明这个类里面没有对内部操作 但可以对外部操作 比如static的数

摘录:如果我是用new分配对象的,可以显式调用析构函数吗?

可能不行。除非你使用定位放置 new.

class Fred

{public:
      Fred()
      {
            cout<<"fuck";
            }
     
      };
int main()
{
   
    Fred*f=new((void*)10000)Fred();
    system("pause");  
}   其中这个10000可以是任意数,但不能为0

2)
定位放置new(placement new)有很多作用。最简单的用处就是将对象放置在内存中的特殊位置。这是依靠 new表达式部分的指针参数的位置来完成的:

 

#include <new>        // 必须 #include 这个,才能使用 "placement new"

#include "Fred.h"     // class Fred 的声明
void someCode()
{
   char memory[sizeof(Fred)];     // Line #1
   void* place = memory;          // Line #2
   Fred* f = new(place) Fred();   // Line #3 (详见以下的“危险”)
   // The pointers f and place will be equal
   // ...
}
Line #1 在内存中创建了一个sizeof(Fred)字节大小的数组,足够放下 Fred 对象。Line #2 创建了一个指向这块内存的首字节的place指针(有经验的 C 程序员会注意到这一步是多余的,这儿只是为了使代码更明显)。Line #3 本质上只是调用了构造函数 Fred::Fred()。Fred构造函数中的this指针将等于place。因此返回的 f 将等于place。  
Line #3 本质上只是调用了构造函数 Fred::Fred()。

*********************************************************

placement new的作用就是:创建对象但是不分配内存,而是在已有的内存块上面创建对象。

用于需要反复创建并删除的对象上,可以降低分配释放内存的性能消耗。
#include <iostream>
#include <new>
const intchunk = 16;
class Foo
{
public :
int val( ) { return _val; }
Foo( ) { _val = 0; }
private :
int_val;
};
//预分配内存,但没有Foo对象
char*buf = new char[ sizeof(Foo) * chunk ];
int
main( void )
{
//在buf中创建一个Foo对象
Foo*pb = new (buf) Foo;
//检查一个对象是否被放在buf中
if ( pb->val() == 0 )
{
cout <<"new expressio worked!" <<endl;
}
//到这里不能再使用pb
delete[] buf;
return 0;
}

转载地址:http://ebgxi.baihongyu.com/

你可能感兴趣的文章
2017年5月软考总结
查看>>
Node.js中运行JavaScript代码
查看>>
5月英语总结--I will do it well.
查看>>
认识JS
查看>>
Google浏览器--翻译一定要“出去”吗?
查看>>
bash:ifconfig:未找到命令
查看>>
送给毕业的歌
查看>>
嵌入式100题(017):malloc的底层实现
查看>>
嵌入式100题(018):在1G内存的计算机中能否malloc(1.2G)?为什么?
查看>>
嵌入式100题(019):指针与引用的相同和区别;如何相互转换?
查看>>
嵌入式100题(040):什么是三次握手
查看>>
嵌入式100题(037):Http1.1和Http1.0的区别
查看>>
嵌入式100题(038):HTTPS与HTTP的一些区别
查看>>
嵌入式100题(042):为什么服务端易受到SYN攻击?
查看>>
嵌入式100题(043):什么是四次挥手
查看>>
嵌入式100题(044):为什么客户端最后还要等待2MSL?
查看>>
嵌入式100题(045):为什么建立连接是三次握手,关闭连接确是四次挥手呢?...
查看>>
嵌入式100题(028):static的用法(定义和用途)
查看>>
嵌入式100题(027):char和int之间的转换
查看>>
嵌入式100题(029):const常量和#define的区别(编译阶段、安全性、内存占用等)...
查看>>