草庐IT

tiny_malloc_from_free_list

全部标签

c++ - va_list 还在 C++ 中使用吗?还是鼓励使用 template<typename...T>?

在C中,定义可变长度参数的唯一方法是使用省略号声明其原型(prototype)并使用va_list、va_start、va_arg,va_end来提取它们。就像printf系列和scanf系列一样。在C++11中,引入了如下新方法。templatevoidfunc(Targ,MoreT...args){//Dosomestufffunc(args);}每种方法的优点和缺点是什么?在C++中是不鼓励使用还是鼓励使用它们中的任何一个? 最佳答案 在C++中强烈不鼓励使用C风格的可变参数函数。风格各不相同,但编写这些类型的函数会让您在某些

c++ - 为什么在这个 'handmade list' 中使用指向指针的指针?

我们在学校有一个项目,尽管该项目是关于什么的,但它涉及使用具有这种特定结构的链表:typedefstruct_node{intcontents;_node*next_node;}*node;在项目之前,我们被分配了一堆函数来学习使用列表(将节点推到列表的前面或后面,计算节点数量,搜索特定节点等)。其实并没有那么难,但是当老师发来基础工程的时候(这样我们每个人都从同一个地方开始),所有的函数都涉及传递一个*node引用。例如:resultTypefunctionName(node*list,...){...}我在项目之前用void函数完成了所有列表函数,因为,至少据我所知,我们正在使用指

c++ - 数组与 std::initializer_list 作为函数参数

我可以通过两种方式编写一个将临时数组(例如{1,2,3})作为参数的函数://usingarraytemplateautofoo1(constT(&t)[N])->void;//usingstd::initializer_listtemplateautofoo2(std::initializer_listt)->void;是否有任何指南可以告诉您哪个更好? 最佳答案 它们是完全不同的东西。还有2或3个其他选择是合理的。templatevoidfoo_a(std::arrayconst&);templatevoidfoo_b(gsl:

c++ - Derived from two Bases - 删除 vector **奇怪**问题

这个问题在这里已经有了答案:Whentousevirtualdestructors?(20个答案)关闭4年前。我花了几个小时试图找出问题出在哪里,但它看起来很奇怪。我以更容易理解的方式重写了我的问题。当它到达它说删除的行时,调试程序会创建一个断点。附言。有趣的是,如果我们采用intb1并将其移动到Base2,它就可以工作。基数1:#pragmaonceclassBase1{public:Base1();~Base1();intb1;};Base2.h:#pragmaonce#include#includeclassDerived;classBase2{public:Base2();~B

c++ - `List x;` 和 `List x()` 有区别吗

标题来自名站C++FAQ作者:编码(marshal)·克莱恩。作者声称以下两个代码示例之间存在差异。SupposethatLististhenameofsomeclass.Thenfunctionf()declaresalocalListobjectcalledx:voidf(){Listx;//Localobjectnamedx(ofclassList)...}Butfunctiong()declaresafunctioncalledx()thatreturnsaList:voidg(){Listx();//Functionnamedx(thatreturnsaList)...}但是

c++ - free.c 抛出异常 "this program has stopped working"

当我使用VisualC++2010Express的调试器运行程序(server.exe)时,它运行完美,但是当我将它作为exe运行时它却没有;它崩溃并显示“Server.exe已停止工作”对话框。接下来我将exe重命名为“ServerInstaller.exe”并且它工作了,所以我认为这是一个权限错误,但它不适用于管理员模式下的“Server.exe”。然后我将VC++中的调试器附加到“Server.exe”程序,它在“free.c”中出现异常。这个文件中的代码是void__cdecl_free_base(void*pBlock){intretval=0;if(pBlock==NULL

c++ - 错误 : no instance of overloaded function "std::make_shared" matches the argument list

查看ApreviousstackQuestionstd:make_sharedvsstd::shared_ptr,我试图在一个uni项目中实现它。这是之前的“问题”:Ican'tthinkofanysituationwherestd::shared_ptrobj(newObject("foo",1));wouldbepreferredtoautoobj=std::make_shared("foo",1);因此我采用了这段代码:std::shared_ptrpT1(newTriangle(pCanvas,30,30,30,60,60,30,255,0,0));并将其修改为这段代码:aut

c++ - std::list<int> 的默认构造函数可以抛出吗?

我(快速)查看了C++标准和在线C++引用,但找不到这个简单问题的答案:可以std::list的默认构造函数吗?扔?如果是这样,为什么会抛出? 最佳答案 简短回答:它可以,但它可以以相当安全的方式实现:默认构造函数构造了一个空列表,因此几乎不需要在进程中实际分配内存。大多数列表实现不会为空列表分配任何内存。但是,默认构造函数不是真正默认构造函数,因为它有一个默认参数:explicitlist(constAllocator&=Allocator());Allocator本身是一个模板参数,因此如果Allocator有一个足够笨(或复杂

c++ - Visual Studio 2010 : "ConfigurationGeneral" rule is missing from the project

我想使用VisualC++2010Professional编译一个64位应用程序,但我一直收到这个错误,我不知道该怎么做:1>------Buildstarted:Project:Test,Configuration:Debugx64------1>Error:The"ConfigurationGeneral"ruleismissingfromtheproject.我在谷歌上搜索过这个问题,但所有的想法都没有解决我的问题。谢谢!如果需要这些信息,我有windows8.1Pro64bits,我使用的是visualstudio2010c++professional。编辑:尝试修复visua

c++ - 使用 std::stack 而不是 deque、vector 或 list 的优点和缺点是什么

我正在编写一个非常简单的std::stack,使用vector作为其底层容器。我意识到我可以用vector容器的push_back()、pop_back()和back()替换所有的push()、pop()和top()函数。我的问题是:当底层容器的受控使用就足够时,为什么还要使用容器适配器?为什么不只使用双端队列、vector或列表?会不会浪费内存或处理时间? 最佳答案 当您的代码显示std::stack时,读者很清楚他们需要在容器上执行哪些操作……它在强制不使用其他操作的同时进行通信和记录。它可以帮助他们快速形成对代码中算法逻辑的印