草庐IT

int_void

全部标签

c++ - 为什么 "const T*"在 "void*"中被简单地转换为 "operator delete"?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Deletingapointertoconst(Tconst*)voidoperatordelete(void*);...constchar*pn=newchar,*pm=(char*)malloc(1);deletepn;//allowed!!free(pm);//errorDemo.可以理解,free()是一个函数,所以constvoid*不能转换为void*。但为什么在operatordelete(默认或重载)的情况下允许这样做?它在功能上不是错误的构造吗?

c++ - 拥有大型二维数组 : static int vs int

在解决DP相关问题时,我观察到第一个有效但第二个段错误。实际原因是什么?仅使用int的内存限制是多少?intmain(){staticinta[3160][3160];return0;}intmain(){inta[3160][3160];return0;} 最佳答案 因为您可能没有足够的堆栈内存来存储这个大数组。第二个示例在堆栈上创建一个数组,而第一个示例创建的数组不在堆栈上而是在数据/Bss段中的某个位置,因为您使用static限定符明确指定了存储条件.注意c++标准没有规定stack或者heap或者datasegment或者B

c++ - Stringstream 到 vector<int>

我想知道从std::stringstream中写入的最佳方式是什么进入vector.这是stringstream中内容的示例:"31#0053253803335342337"这是我得到的:intbuffer=0;vectoranalogueReadings;stringstreamoutput;while(output>>buffer)analogueReadings.push_back(buffer);然而,似乎发生的是,它读取第一件事,然后到达#00并返回0因为它不是数字。理想情况下,我想要的是,它达到#然后跳过所有字符直到下一个空格。这可以用标志或其他东西实现吗?谢谢。

c++ - 打印 int 指针的值

我一直在研究这个,但我似乎无法让它正常工作。我正在返回一个指针列表的最后一个值,我想打印它,但它打印的是一个非常随机的数字。我假设这是指针的内存地址,但是当我取消引用它时,我的输出仍然做同样的事情。我的指针列表是一个指针列表,例如:listpointerList例如,这是我的方法返回:int*end(){return(pointerList.back());}我就是这样调用它的。int*totry=ca.end();cout这是打印内存地址而不是值。有没有人知道如何解决这个问题?提前致谢!编辑:这是int指针指向的内容:我有一个值列表,例如[0,1,2,3,4,5,6,7,8,9,10

c++ - 如何将元素插入 std::unordered_map<int, vector<Object*>>

我正在尝试创建指向我的对象的指针数组的散列。散列键是对象类型的int,数组是要渲染的对象列表。我想做的是:unordered_map>drawQueue;drawQueue.clear();//newemptydrawqueuefor(...){drawQueue.at(type).push_back(my_obj);}所以我对STL东西的细微差别还不够熟悉,因为我得到一个异常,说out_of_bounds,这是当key不存在时发生的情况。所以我想我需要先创建key,然后添加到vector中:if(drawQueue.count(type)){//keyalreadyexistsdra

C++ 为什么在与 void 指针一起使用时 sprintf_s 格式会发生变化?

这是工作的原始代码://...unsigned__int64num=57;sprintf_s(buffer,sizeof(buffer),"%llu",num);但是,当我尝试将这部分提取到此函数中时:voidaddBuffered(void**attributeValue,char*format){sprintf_s(buffer,sizeof(buffer),format,*attributeValue);}通过调用:addBuffered((void**)&num,"%d");我必须将sprintf_s中的格式参数从%llu更改为%d以获得正确的值。有人可以解释为什么会发生这种情

c++ - 我如何在 void* 和 boost shared_ptr 之间进行转换

我有这些行:typedefboost::shared_ptrA_SPtr;void*f(void*var){...我希望能够做这样的事情:A_SPtrinstance=(void*)(var);我该怎么做?另外,我怎样才能将意义从shared_ptr转换为void*? 最佳答案 只需将指针转换为指向和来自void*的共享指针。shared_ptr到void*:f(reinterpret_cast;(&A_SPtr));void*回到shared_ptr:A_SPtrinstance=*reinterpret_cast(boost::

c++ - C 与 C++ 中 void* 的转换

在C中,void指针被隐式类型转换为另一种类型。请看下面的程序:intmain(){void*p;int*ptr,i=5;p=&i;ptr=p;程序compilessuccessfully在C环境下运行时。但是,如果相同的程序在C++环境下运行,我将得到以下error:prog.cpp:Infunction‘intmain()’:prog.cpp:8:error:invalidconversionfrom‘void*’to‘int*’这意味着在C++中,我们需要明确类型化一个void指针。那么,为什么new运算符的返回类型是void*?如何,它正在转换为所需的类型?

c++ - 推导非类型模板参数 Unsigned Int/size_t

我正在尝试推断一个非类型模板参数。#includetemplatevoidgetsize(unsignedints){std::cout(4);//orevengetsize();//Isthispossible?}但是我得到了错误:deduce_szie_t.cpp:Infunction'intmain()':deduce_szie_t.cpp:9:15:error:nomatchingfunctionforcallto'getsize(unsignedint)'deduce_szie_t.cpp:9:15:note:candidateis:deduce_szie_t.cpp:4:6

c++ - 常量 QList<int> 警告 = QList<int>() << 0; gcc 4.7.2 的段错误

因此主题行中提到的代码会导致Qt4.8.3和gcc4.7.2出现段错误这在.cpp文件中的任何类/结构之外,适用于gcc4.4constQListwarnings=QList()Traces给出了这两个提示:__do_global_ctors()__static_initialization_and_destruction_0所以当它插入后面的列表时,似乎“警告”还不可用。如果我把它改成这样,就可以与4.7.2一起工作:globalscope:QListwarnings;这是一些函数:warnings=QList()我想知道为什么会这样?编辑:我想我最初从我的问题中删掉了太多东西,但是