草庐IT

c++ - 使用 placement new[] 有什么问题?做

考虑下面的程序。它已从一个复杂的案例中简化而来。它无法删除以前分配的内存,除非我删除Obj类中的虚拟析构函数。我不明白为什么程序输出的两个地址不同,只有存在虚拟析构函数时才不同。//GCC4.4#includeusingnamespacestd;classArena{public:void*alloc(size_ts){char*p=newchar[s];cout(p);//theprogramfailshere}};structObj{void*operatornew[](size_ts,Arena&a){returna.alloc(s);}virtual~Obj(){}//ifIr

c++ - 通过在此指针上放置 new 重新初始化对象的未定义行为

我看到了关于PiotrPadlewski的cppcon的介绍。说以下是未定义的行为:inttest(Base*a){intsum=0;sum+=a->foo();sum+=a->foo();returnsum;}intBase::foo(){new(this)Derived;return1;}注意:假设sizeof(Base)==sizeof(Derived)和foo是虚拟的。显然这很糟糕,但我很想知道为什么它是UB。我确实了解UB访问realloced指针,但他说,这是一样的。相关问题:Is`new(this)MyClass();`undefinedbehaviourafterdir

c++ - 为什么替换 malloc() 需要链接器的知识,而::operator new() 不需要?

查看链接的问题。Differencebetweenglobaloperatornewandmalloc接受的答案指出,“替换malloc会引发大量蠕虫。它可以做到,但不可移植,因为它需要链接器的知识。”为什么替换malloc需要链接器的知识,为什么替换::operatornew()不需要? 最佳答案 标准C++对覆盖::operatornew做出了规定。虽然实现肯定是困惑的并且与链接器相关,但C++程序可以只定义一个不同的::operatornew并且它可以工作。C++标准明确表示:程序可以用自己的定义替换这些(等等各种限制和细节)

c++ - 使用可选参数重载 new 和 delete 运算符

#include#include#include#includestructfoo{};inlinevoid*operatornew(size_tsize,foo*)throw(std::bad_alloc){std::cout输出(viaideone):mynew1我的想法是,C++会释放一个带有附加参数的新对象,并匹配删除相同的参数,但我显然是不正确的。让上面的代码调用我的重载删除的正确方法是什么? 最佳答案 当你使用任何形式的placementnew时,除了std::nothrow_t版本,你需要明确地销毁对象并以你认为合适的

c++ - 在 new 表达式中分配内存后是否评估初始值设定项?

考虑代码autop=newT(U(std::move(v)));然后初始化程序是U(std::move(v))。让我们假设T(U(std::move(v)))没有抛出。如果在底层内存分配之后评估初始化程序,则代码是强异常安全的。否则,它不是。如果抛出内存分配,v就会被移动。因此,我对内存分配和初始化程序评估之间的相对顺序很感兴趣。它是已定义的、未指定的还是什么? 最佳答案 是的,初始化是在分配之后计算的。引用C++17(N4659)[expr.new]8.3.4/19:Theinvocationoftheallocationfunc

c++ - 在泛型编程中使用 placement new

在泛型代码中使用placementnew在指定地址构造对象时,使用模式与通常的代码有点不同。例如,考虑uninitialized_copy的实现:([uninitialized.copy])templateForuninitialized_copy(Itfirst,Itlast,Fordest){usingT=typenamestd::iterator_traits::value_type;for(;first!=last;++first,(void)++dest)::new(static_cast(std::addressof(*dest)))T(*first);}这篇文章从标准的角

c++ - C++ 中 placement new 执行的完整操作列表是什么?

在thisquestion讨论了在编译器不支持new和放置new时创建工厂方法。显然,如果通过放置new完成的所有必要步骤都以某种方式重现,则可以使用malloc()制作一些合适的解决方案。放置新有什么作用-我将尝试列出并希望不要遗漏任何内容-除了以下内容?递归调用所有基类的构造函数为所有成员变量调用构造函数和初始值设定项(如果有的话)相应地设置vtable指针。还有哪些Action? 最佳答案 Placementnew除了分配内存之外,它做了常规new会做的所有事情。我认为您基本上已经确定了发生的事情,并做了一些小的说明:显然类本

c++ - 我应该使用 shared_ptr<Object> myObject = (shared_ptr<Object>) new Object() 来访问私有(private)构造函数吗?

我正在使用广泛使用以下语法的代码库:shared_ptrmyObject=(shared_ptr)newObject();我注意到我无法使用make_shared访问私有(private)构造函数,但是shared_ptrmyObject=(shared_ptr)newObject();工作得很好。我应该仅仅因为它看起来有效而使用它吗?有什么危险吗?它与make_shared有何不同??我知道this中的答案问题,它在make_shared之间进行比较和:std::shared_ptrp2(newObject("foo"));但我没能找到对我遇到的语法的引用。和上面有什么不同,还是一样

c++ - 为什么添加两个 std::vector 比从 new[] 中添加原始数组慢?

我正在查看OpenMP,部分原因是我的程序需要添加非常大的vector(数百万个元素)。但是,如果我使用std::vector或原始数组,我会看到很大的不同。我无法解释。我坚持认为区别仅在于循环,当然不是初始化。我所指的时间差异,只是计算加法的时间,特别是没有考虑vector、数组等之间的任何初始化差异。我实际上只谈论求和部分。vector的大小在编译时是未知的。我在Ubuntu16.04上使用g++5.x。编辑:我测试了@Shadow所说的内容,这让我开始思考,优化有什么进展吗?如果我使用-O2进行编译,那么,使用初始化的原始数组,我返回以使用线程数进行循环缩放。但是使用-O3或-f

c++ - 关于 malloc 和 new 在各自处理内存分配的机制方面的区别?

这个问题在这里已经有了答案:Whatisthedifferencebetweennew/deleteandmalloc/free?(15个答案)关闭7年前。malloc和new在处理内存分配的机制方面有什么区别?