草庐IT

new_point

全部标签

c++ - 将 _msize 与 new[] 一起使用安全吗?

将Microsoft特定的_msize()函数与新的[]一起使用是否安全?例子:int*i=newint[100];size_ts=_msize(i);coutMSDN确实只描述了malloc&Co的用法。我已经使用VisualStudio2010测试了代码,它看起来可以工作!但我想知道是否有一些预期的问题或任何特殊情况? 最佳答案 如果有人为您的类型覆盖operatornew,则可能会出现问题。写起来一样简单constsize_ts=100;int*i=newint[s];或者,如果你真的写C++std::vectori(100)

c++ - 一起使用 "new"和 "if"语句 - 语法相关

对不起大家。我的意思是在我发布的代码中有一个星号。请重新回答。我正在为同事做代码审查,我看到弹出以下语句:if((someClass*object1=newsomeClass)){//Dowork}这个说法和下面的说法一样吗?someClass*object1=newsomeClass;if(object1){//Dowork}我只是想看看它们是否相等,这样我们就不会遇到任何错误。 最佳答案 您不能在第一种形式的if条件内创建对象,除非类型立即出现在括号内,因此:if(someClass*object1=newSomeclass(.

c++ - new 不分配内存

这应该每秒用大约100MB填满我的内存。我使用gnome-systemmonitor和htop跟踪内存使用情况。但不知何故它没有。为什么?#include"unistd.h"#includeintmain(intargc,char*argv[]){while(true){std::cout运行:g++-std=c++11-O0main.cpp;./a.out 最佳答案 因为您没有使用它,所以Linux会进行惰性分配,因此在您使用它之前它不会实际映射任何内存页。如果你输入一些代码:char*test=newchar[100000000

c++ - 使用 new 并能够检查指针是否为 0(空)

有人告诉我这样做,int*i=newint();我将无法检查我的指针是否为0。new发送异常以防失败。但是,如果我出于某种原因不想使用异常怎么办。有什么方法可以检查我的指针是否正确分配? 最佳答案 阅读文档:http://www.cplusplus.com/reference/new/operator%20new/(2)nothrowallocationSameasabove(1),exceptthatonfailureitreturnsanullpointerinsteadofthrowinganexception.以及示例:st

c++ - 我应该在我的 C++ WIn32 应用程序中重写 operators new/delete

我知道Microsoft自己曾经建议通过调用HeapCreate()和HeapAlloc()来覆盖operatornew,但那是不久前的事了。有关详细信息,请参阅KB139638。在Win32上重写new/delete是否仍然有益?推荐的实现方式是什么?TIA。 最佳答案 这篇文章说你可以做,而不是说你应该。其中的代码写得很糟糕,一点也不有趣,而且它不是线程安全的。通常,提供的new和delete实现可以很好地满足所有一般编程需求。只有当您确定了重新实现可以解决的特定问题时,您才应该考虑重新实现它们。

c++ - 在 valgrind 中将 QSharedPointer 与 new[] 一起使用会产生 "Mismatched free()/delete/delete[]"

我有以下代码:QPair,int>someclass::somefunction(){intsiz=data_size();QSharedPointerbuffer(newunsignedint[siz]);//Fillthebuffer...returnqMakePair(buffer,siz);}在某些时候,此函数返回的QSharedPointer将超出范围,构造函数中设置的指针将被释放。使用valgrind3.6.1,出现“不匹配的free()/delete/delete[]”错误。我对QSharedPointer的使用有什么问题吗?还是我只能忍受这个valgrind警告?

c++ - 通过 new 赋值一个复杂的构造函数

我有一个困惑。以下是一段代码。我想使用new创建一个包含五个类对象的动态数组,但我想运行一个循环以使用循环计数器分配构造函数的第一个参数。类似的东西。classA{public:A(int_x,int_y):x(_x),y(_y){}private:intx,y;};intmain(){A*a=newA[5];//compilererrorfor(i=0;i谁能告诉我正确的语法是什么,因为我没有简单的构造函数? 最佳答案 这一行A*a=newA[5];要求A是默认可构造的。因此,一个简单的选择是将默认构造函数添加到A:A():x()

c++ - 函数指针 : is the simple canonical use bad from a performance point of view? 如果是的话,c++11-ish 的替代方案是什么?

我在我的c++代码中经常使用函数指针,总是以符合这个简单规范示例的方式使用(例如,函数具有相同的I/O,但所需的操作只是在运行时已知):#includeusingnamespacestd;intadd(intfirst,intsecond){returnfirst+second;}intsubtract(intfirst,intsecond){returnfirst-second;}intoperation(intfirst,intsecond,int(*functocall)(int,int)){return(*functocall)(first,second);}intmain()

c++ - C/C++ : extract a subset of one enum to form a new enum

假设我有一个列出所有人员的主枚举:typedefenumall_personnel{//maleTONY,MIKE,JIM,//femaleJESSICA,MARY,}all_personnel_t;现在我想为male和female定义其他两个枚举(因为,例如,一些函数只接受males或females枚举参数),但我想使用与主枚举中相同的名称标识符。在C/C++中有可能吗?还是有其他方法?似乎以下内容不起作用(编译器提示redeclarationofenumerator‘TONY’等:typedefenummale_personnel{TONY,MIKE,JIM,}male_perso

c++ - 如何删除 STD::List 中最近的 "Point"对象到某个 x,y?

我有一个点类:classPoint{public:intx,y;Point(intx1,inty1){x=x1;y=y1;}};和点列表:std::listpointList;std::list::iteratoriter;我正在将点推送到我的pointList(尽管如果尚未推送任何点,该列表可能还不包含任何点)。我有两个问题:如何从列表中删除最接近任意点(x,y)的点?假设我有x,y(5,12),我想在列表中找到最接近该点的点并将其从STD::List中删除。我知道我必须使用距离公式并且我必须使用迭代器遍历列表但是我在概念化如何在我迭代时跟踪哪个点最近时遇到了一些问题通过列表。如何返