草庐IT

array_new

全部标签

c++ - 在同一指针上多次使用 "new"

当我做类似的事情时会发生什么int*ptr=newint;*ptr=5;//...dosomestuffhereptr=newint;//...reuseptrtodosomeotherstuff相对于int*ptr1=newint;*ptr1=5;//...dosomestuffheredeleteptr1;int*ptr2=newint;//...useptr2now????同样的事情会发生在硬件层面吗?换句话说,在第一种情况下,ptr=newint;是否从其先前的指针/值对继续前进,那些旧值会发生什么变化?它们会被替换吗?它们会漂浮在某个地方吗? 最佳

c++ - 将 `std::vector` 替换为 `std::array`

我有一个代码如下:intn;intget_the_number();voidsome_computations();intmain(){n=get_the_number();some_computations()return(0);}get_the_number函数获取一些输入并返回整数n,它在调用后不会被修改。在some_computation函数中有如下代码std::vectormy_array;for(inti=0;i问题:由于my_array的大小是先验已知的,是否可以用替换std::vector>std::array?此外,在肯定的情况下,我是否应该期望在效率方面有所提高?我

c++ -::new 是什么意思?

检查MSdirectX11DXUT示例时,出现以下代码:templateHRESULTCGrowableArray::SetSize(intnNewMaxSize){intnOldSize=m_nSize;if(nOldSize>nNewMaxSize){assert(m_pData);if(m_pData){//Removingelements.Calldtor.for(inti=nNewMaxSize;i这可以在我的DXSDK版本(2010年6月)的第428行的DXUTmisc.h中找到。我想知道那个::new东西....我正在尝试使用Google搜索堆栈溢出,但当我键入“::ne

c++ - new 未调用,但已分配内存

我写了一个简单的Trie执行。这是源代码:#include#includetypedefunsignedintuint;classTrie{public:classNode{public:Node(constchar&_value);~Node();charget_value()const;voidset_marker(constuint&_marker);uintget_marker()const;booladd_child(Node*_child);Node*get_child(constchar&_value)const;voidclear();private:charm_val

c++ - C 和 C++ : Array element access pointer vs int

如果您执行myarray[i]或将myarray[i]的地址存储在指针中,是否存在性能差异?编辑:这些指针都是在我的程序中一个不重要的步骤中计算出来的,性能不是标准。在关键部分,指针保持静态并且不被修改。现在的问题是这些静态指针是否比一直使用myarray[i]更快。​​ 最佳答案 对于这段代码:intmain(){inta[100],b[100];int*p=b;for(unsignedinti=0;i在g++中使用-O3优化构建时,语句:a[i]=i;产生汇编输出:mov%eax,(%ecx,%eax,4)和这个声明:*p++=

C++:malloc 等同于 new 吗?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Whatisthedifferencebetweennew/deleteandmalloc/free?我是c++小白,想知道是否memblock=(char*)malloc(currentByteLength);相当于memblock=newchar[currentByteLength]在C++中?

c++ - 为什么用 new 创建的 C++ 数组与 C 样式数组的行为不同?

我正在自学C++,因此一直在编写一些示例代码来真正巩固我对指针和数组的理解。我是这样写的:intmyints[]={20,40,60,80,100};//Cstylearray?shouldbestoredonstack?ismyint'stypepointertointoranarrayofint?howdoesitdifferfrommyotherints?int*myotherints=newint[5]{20,40,60,80,100};//newalwaysreturnspointer,isthisaC++stylearray?//doesthispointergetcrea

c# - 使用new时的数组初始化

在C#中我可以这样做:char[]a=newchar[]{'a','a','a'};但是我可以用C++做类似的事情吗?我试过:char*a=newchar[]{'a','a','a'};但它无法编译。 最佳答案 这是C++规范中的错误(不允许编译这个简单的构造)。您需要提供尺寸char*a=newchar[3]{'a','a','a'};参见http://www.open-std.org/jtc1/sc22/wg21/docs/cwg_active.html#1469.请注意,如果您将类型名称括在括号中,它是一个type-id而不是

c++ - 使用 new 创建一个结构数组

我在这里遇到了一些困难的情况,我希望有人能帮助我。我有以下内容,structCandyBar{std::stringname;doubleweight;intcalories;};现在,创建一个包含许多CandyBar的结构数组非常简单,我已经这样做了;intmain(){CandyBarbars[]={{"Mangotart",2.3,100},{"YoYo",3.2,130},{"OrangeBall",1.7,98}};return0;}但是,现在我想使用new创建相同的结构。当我想到它时它非常简单,但是它崩溃并且不起作用。CandyBar*bars=newCandyBar;(*

c++ - new[] 比 Win32 的 VirtualAlloc 快吗?

我正在测试一些字符串池分配器的性能:我考虑了提供的那个here调用VirtualAlloc然后分割出子分配,以及使用标准C++(不直接调用任何Win32API)和new[]的类似实现。我希望VirtualAlloc版本更快,因为我认为开销应该比C++new[]少;但我观察到的结果恰恰相反:使用new[]似乎比使用较低级别的VirtualAlloc产生更快的代码。我跑了几次测试(代码是用VS2010SP1编译的),输出是这样的:StringpoolusingVirtualAlloc:1280.07msStringpoolusingnew[]:799.193ms这是为什么?为什么new[]