草庐IT

tuple_list

全部标签

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++ - 我可以将新的 std::tuple 放入内存映射区域,然后再读回吗?

我有一些打包的结构,我将把它们写入内存映射文件。它们都是POD。为了适应我正在做的一些通用编程,我希望能够编写一个std::tuple几个打包结构。我担心写一个std::tuple的成员到我映射区域的地址,然后将该地址转换回std::tuple会坏掉的。我写了一个小示例程序,它似乎可以工作,但我担心我有未定义的行为。这是我的结构:structFoo{charc;uint8_tpad[3];inti;doubled;}__attribute__((packed));structBar{inti;charc;uint8_tpad[3];doubled;}__attribute__((pac

c++ - mpl::transform on boost::fusion::tuple

以下代码无法在g++(GCC)4.6.020110603(预发布版)和-std=c++0x和Boost1.46上编译。1。我错过了一个包含或者这实际上是一个错误吗?如果是后者,如何解决?#include#include#include#include#include#include#include#includenamespacempl=boost::mpl;templatestructMeta{Tt;typedefmpl::vector,std::function,std::function>MplVector;typedefTFusionSequence;//workstypede

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

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

c++ - 从 std::tuple 成员中移除引用

我在STL元组的帮助下实现了一些变量的保存/恢复功能,如下所示:doublea=1,b=2;intc=3;autotupleRef=std::make_tuple(std::ref(a),std::ref(b),std::ref(c));//hereI'msavingcurrentstateofa,b,cstd::tuplesaved=tupleRef;//heregoesblockofcode,wherea,b,andcgetspoiled......................////nowI'mrestoringinitialstateofa,b,ctupleRef=save

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++ - 使用 std::stack 而不是 deque、vector 或 list 的优点和缺点是什么

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

c++ - GDB:我们如何从 std::tuple 中提取值

我们如何提取/打印std::tuple中的单个值?这是名为test.cc的文件中的示例程序。#include#includeusingnamespacestd;intmain(){autot=make_tuple(111,222);cout(t)(t)编译它g++--std=c++11-gtest.cc在gdb中运行gdb--args./a.out...(gdb)startTemporarybreakpoint1at0x400836:filetest.cc,line7.Startingprogram:/home/fmlheureux/a.outTemporarybreakpoint1,