草庐IT

NEW_FLAG

全部标签

c++ - 为什么 C++ 中的 new 在失败时不返回 NULL

为什么new在失败时不返回NULL?为什么它只在失败时抛出异常?因为它在成功时返回一个指向对象的指针,为什么不在失败时呢?这种行为有什么具体原因吗? 最佳答案 在C++中引入异常之前:失败的new-expression产生了一个空指针。在一个失败的构造函数中,分配了一个空指针到this.引入异常后:一个失败的普通人new-expression抛出异常。在失败的构造函数中抛出异常。一个区别是构造函数的失败报告现在也适用于创建没有动态分配的对象。另一个区别是代码使用new-表达式现在可以更简单,因为错误处理可以从每个这样的代码位置移出并

c++ - "new int(100)"有什么作用?

PossibleDuplicate:isthisavariableorfunction我错误地使用了类似的东西:int*arr=newint(100);它通过了编译,但我知道这是错误的。应该是int*arr=newint[100];我写错了编译器会怎么想? 最佳答案 第一行分配一个int并将其初始化为100。想想int(100)作为构造函数调用。由于这是一个标量分配,尝试访问arr[1]或使用delete[]释放内存将导致未定义的行为。 关于c++-"newint(100)"有什么作用?

c++ - malloc 和放置 new vs. new

过去几天我一直在研究这个问题,到目前为止,除了教条式的论点或诉诸传统(即“这是C++方式!”)之外,我还没有真正找到任何令人信服的东西。如果我正在创建一个对象数组,那么使用的令人信服的原因(除了易用性)是什么:#defineMY_ARRAY_SIZE10//...my_object*my_array=newmy_object[MY_ARRAY_SIZE];for(inti=0;i超过#defineMEMORY_ERROR-1#defineMY_ARRAY_SIZE10//...my_object*my_array=(my_object*)malloc(sizeof(my_object)

c++ - 为什么 new[] 表达式会调用析构函数?

来自C++17标准(草案here),[expr.new]:Ifthenew-expressioncreatesanobjectoranarrayofobjectsofclasstype,accessandambiguitycontrolaredonefortheallocationfunction,thedeallocationfunction,andtheconstructor.Ifthenew-expressioncreatesanarrayofobjectsofclasstype,thedestructorispotentiallyinvoked.new[]为什么会调用析构函数?

c++ - std::shared_ptr 初始化:make_shared<Foo>() vs shared_ptr<T>(new Foo)

这个问题在这里已经有了答案:Differenceinmake_sharedandnormalshared_ptrinC++(8个回答)关闭7年前。两者有什么区别:std::shared_ptrp=std::shared_ptr(newint);和std::shared_ptrp=std::make_shared();?我应该更喜欢哪一个?为什么?P。S.很确定这个问题一定已经回答过了,但我找不到类似的问题。 最佳答案 这两个例子都过于冗长了:std::shared_ptrp(newint);//or'=shared_ptr(newi

c++ - C++ 中何时需要#include <new> 库?

根据thisreference对于operatornew:Globaldynamicstorageoperatorfunctionsarespecialinthestandardlibrary:Allthreeversionsofoperatornewaredeclaredintheglobalnamespace,notinthestdnamespace.ThefirstandsecondversionsareimplicitlydeclaredineverytranslationunitofaC++program:Theheaderdoesnotneedtobeincludedfor

c++ - C++ `new` 运算符可以在现实生活中抛出异常吗?

new操作符在现实生活中能抛出异常吗?如果是这样,除了杀死我的应用程序之外,我还有其他处理此类异常的选项吗?更新:是否有任何现实世界的、新重的应用程序检查故障并在没有内存时恢复?另见:HowoftendoyoucheckforanexceptioninaC++newinstruction?Isitusefultotestthereturnof“new”inC++?WillnewreturnNULLinanycase? 最佳答案 是的,如果分配失败,new可以并且将会抛出。如果内存不足或尝试分配的内存块太大,就会发生这种情况。您可以捕

c++ - 是否可以防止对象的堆栈分配并只允许使用 'new' 对其进行实例化?

是否可以阻止对象的堆栈分配,只允许在堆上使用“new”启动它? 最佳答案 您可以这样做的一种方法是将构造函数设为私有(private),并且只允许通过返回指针的静态方法进行构造。例如:classFoo{public:~Foo();staticFoo*createFoo(){returnnewFoo();}private:Foo();Foo(constFoo&);Foo&operator=(constFoo&);}; 关于c++-是否可以防止对象的堆栈分配并只允许使用'new'对其进行实例

C++,是否可以直接调用构造函数,而不需要new?

如果我已经有对象的内存,我可以不使用new显式调用构造函数吗?classObject1{char*str;public:Object1(char*str1){str=strdup(str1);puts("ctor");puts(str);}~Object1(){puts("dtor");puts(str);free(str);}};Object1ooo[2]={Object1("I'mthefirstobject"),Object1("I'mthe2nd")};do_smth_useful(ooo);ooo[0].~Object1();//calldestructorooo[0].Ob

c++ - make_shared 真的比 new 更高效吗?

我正在用C++11中的shared_ptr和make_shared进行试验,并编写了一个小玩具示例来查看调用make_shared时实际发生的情况>。作为基础架构,我使用llvm/clang3.0以及XCode4中的llvmstdc++库。classObject{public:Object(conststring&str){cout("make_shared");coutptr_res2(newObject("new"));cout现在请看一下输出:Createsmart_ptrusingmake_shared...Constructormake_sharedCopyconstruct