草庐IT

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

c++ - C++ 中的 "new"和 "malloc"和 "calloc"有什么区别?

这个问题在这里已经有了答案:关闭13年前.“new”和“malloc”和“calloc”和其他家族有什么区别?(何时)除了“new”之外我还需要什么吗?其中一个是使用其他实现的吗? 最佳答案 new和delete是C++特定的功能。它们在C中不存在。malloc是老式的C做事方式。大多数时候,您不需要在C++中使用它。malloc分配未初始化的内存。分配的内存必须用free释放。calloc与malloc类似,但使用常量(0)初始化分配的内存。它需要用free释放。new通过调用构造函数(如果它是一个对象)来初始化分配的内存。用ne

c++ - 如何正确替换全局new和delete运算符

首先,至少有4-5个主题与SO上的主题相似。我阅读了它们中的每一个,但我觉得它们并没有真正帮助我解决这个特定问题。如果其他人发现重复的问题,我深表歉意。在发布此之前,我已经完成了我的搜索,因为这似乎是一个非常常见的问题。我在Windows7上使用VisualStudio.NET2003。我有自己的new/delete重载,指向我自己对malloc()和free()的自定义调用以进行诊断。我的新/删除重载在一个头文件中,我已经包含在几个文件中。问题是,代码库几乎是意大利面条,没有简单的方法可以确保所有东西都使用这些重载。第三方库包含黑盒。我们也到处使用STL。在我的测试中,我发现STL仍

c++ - 对于 "-fno-exceptions", "new T"会发生什么?

我想知道,如果我使用-fno-exceptions选项编译我的程序以禁用异常处理,newT是否仍会抛出bad_alloc?或者编译器(GCC和clang支持该选项)是否会将newT的使用隐式转换为new(nothrow)T? 最佳答案 按照我的理解,operatornew是由libstdc++定义的。如果您现在使用-fno-exceptions编译自己的代码,则无法捕获任何异常,但您仍将链接到会引发异常的普通版本的libstdc++。所以是的,newT会抛出异常,即使使用-fno-exception。但是,如果您也使用-fno-ex

c++ - new char 实际上是否保证了类类型的对齐内存?

通过newchar[sizeof(T)]分配一个缓冲区,保证为T类型分配正确对齐的内存,其中的所有成员T有它们自然的、实现定义的对齐方式(也就是说,您没有使用alignas关键字来修改它们的对齐方式)。我在这里的一些答案中看到了这个保证,但我并不完全清楚标准是如何达到这个保证的。标准的5.3.4-10给出了基本要求:本质上newchar[]必须与max_align_t对齐。我缺少的是表示alignof(T)将始终是最大值为max_align_t的有效对齐方式。我的意思是,这似乎很明显,但结构的对齐结果是否必须最多为max_align_t?甚至第3.11-3点说可能支持扩展对齐,所以编译