草庐IT

new_order

全部标签

c++ - 为什么语言中内置了非放置 `new` 和 `delete` 而不仅仅是常规函数?

为什么没有展示newexpression和deleteexpression实现为语言内置而不是常规函数?如果我们有...向操作系统请求/归还内存的一种方式一种显式调用构造函数的方式(placementnew)一种显式调用析构函数的方式(~T())...为什么非放置new和delete不能只是标准库中的常规函数​​?示例:templateT*library_new(Ts&&...xs){auto*ptr=/*requestenoughmemoryfor`T`fromOS*/;new(ptr)T(std::forward(xs)...);returnptr;}templatevoidlib

c++ - 为什么语言中内置了非放置 `new` 和 `delete` 而不仅仅是常规函数?

为什么没有展示newexpression和deleteexpression实现为语言内置而不是常规函数?如果我们有...向操作系统请求/归还内存的一种方式一种显式调用构造函数的方式(placementnew)一种显式调用析构函数的方式(~T())...为什么非放置new和delete不能只是标准库中的常规函数​​?示例:templateT*library_new(Ts&&...xs){auto*ptr=/*requestenoughmemoryfor`T`fromOS*/;new(ptr)T(std::forward(xs)...);returnptr;}templatevoidlib

c++ - new char[10] 和 new char(10) 有什么区别

在C++中,有什么区别char*a=newchar[10];和char*a=newchar(10);谢谢! 最佳答案 第一个分配10个字符的数组。第二个分配一个初始化为10的字符。或者:第一个应替换为std::vector,第二个应该放入智能指针中。 关于c++-newchar[10]和newchar(10)有什么区别,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/3902011

c++ - new char[10] 和 new char(10) 有什么区别

在C++中,有什么区别char*a=newchar[10];和char*a=newchar(10);谢谢! 最佳答案 第一个分配10个字符的数组。第二个分配一个初始化为10的字符。或者:第一个应替换为std::vector,第二个应该放入智能指针中。 关于c++-newchar[10]和newchar(10)有什么区别,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/3902011

c++ - 是否可以完全禁用默认的 C++ new 运算符?

因为我们的应用程序有硬性能和内存限制,我们的编码标准禁止使用默认堆——即没有malloc,没有默认new。每个内存分配都必须选择几个特定分配器之一;像//declaredgloballyvoid*operatornew(size_tsize,CustomAllocHeap*heap,constchar*perpetrator_name){returnheap->Allocate(size,perpetrator_name);}//imagineabunchofCustomAllocHeap'sdeclaredgloballyorstatically,thusVector*v=new(g

c++ - 是否可以完全禁用默认的 C++ new 运算符?

因为我们的应用程序有硬性能和内存限制,我们的编码标准禁止使用默认堆——即没有malloc,没有默认new。每个内存分配都必须选择几个特定分配器之一;像//declaredgloballyvoid*operatornew(size_tsize,CustomAllocHeap*heap,constchar*perpetrator_name){returnheap->Allocate(size,perpetrator_name);}//imagineabunchofCustomAllocHeap'sdeclaredgloballyorstatically,thusVector*v=new(g

c++ - 如何防止通过 'new' 运算符分配类? (我想确保我的 RAII 类始终分配在堆栈上。)

我想确保我的RAII类始终分配在堆栈上。如何防止通过“new”运算符分配类? 最佳答案 您需要做的就是将类的新运算符声明为私有(private):classX{private://Preventheapallocationvoid*operatornew(size_t);void*operatornew[](size_t);voidoperatordelete(void*);voidoperatordelete[](void*);//...//TherestoftheimplementationforX//...};将“operat

c++ - 如何防止通过 'new' 运算符分配类? (我想确保我的 RAII 类始终分配在堆栈上。)

我想确保我的RAII类始终分配在堆栈上。如何防止通过“new”运算符分配类? 最佳答案 您需要做的就是将类的新运算符声明为私有(private):classX{private://Preventheapallocationvoid*operatornew(size_t);void*operatornew[](size_t);voidoperatordelete(void*);voidoperatordelete[](void*);//...//TherestoftheimplementationforX//...};将“operat

c++ - 谁删除了在构造函数中有异常的 "new"操作期间分配的内存?

我真的不敢相信我找不到一个明确的答案......在使用new操作符初始化的情况下,如何释放C++类构造函数引发异常后分配的内存。例如:classBlah{public:Blah(){throw"oops";}};voidmain(){Blah*b=NULL;try{b=newBlah();}catch(...){//Whatnow?}}当我尝试这个时,b在catchblock中为NULL(这是有道理的)。在调试时,我注意到控制在到达构造函数之前进入了内存分配例程。MSDN网站上的seemstoconfirmthis:WhennewisusedtoallocatememoryforaC+

c++ - 谁删除了在构造函数中有异常的 "new"操作期间分配的内存?

我真的不敢相信我找不到一个明确的答案......在使用new操作符初始化的情况下,如何释放C++类构造函数引发异常后分配的内存。例如:classBlah{public:Blah(){throw"oops";}};voidmain(){Blah*b=NULL;try{b=newBlah();}catch(...){//Whatnow?}}当我尝试这个时,b在catchblock中为NULL(这是有道理的)。在调试时,我注意到控制在到达构造函数之前进入了内存分配例程。MSDN网站上的seemstoconfirmthis:WhennewisusedtoallocatememoryforaC+