草庐IT

c++ - 如何访问 std::list 的第一个元素?

我有一个列表std::list*l;.此列表不为空且具有一些值。我的问题是如何正确访问项目?我不需要遍历列表。我只想要第一个项目。std::list::iteratorit=l->begin();if(it!=l->end()){//accessingTintvalue=(*it)->value();//Isthissafe?}或者我还应该检查null吗?if(it!=l->end()&&(*it)){//accessingTintvalue=(*it)->value();} 最佳答案 如果你被迫使用std::listmyList;

c++ - 什么语言规则允许 C++11 推断这是一个 initializer_list 对?

在C++11中,初始化std::map似乎是合法的如下:std::mapmyMap={{"One",1},{"Two",2},{"Three",3}};直觉上,这是有道理的——大括号括起来的初始化器是一个字符串对列表,std::map::value_type是std::pair(可能具有一些const资格。但是,我不确定我是否理解此处的输入方式。如果我们在这里去掉变量声明,只用大括号括起来的初始化器,编译器就不会知道它正在查看std::initializer_list>。因为它不知道括号对代表std::pair秒。因此,编译器似乎以某种方式推迟了将类型分配给大括号括起来的初始化程序的行

C++ 数组下标运算符模板

在尝试使对存储类的访问变得更容易一些之后,我最终陷入了一种我没有太多知识的境地。而且,要找到和我做同样事情的人并不容易。我想做的是,有一个类在内部将值数组存储为字符串,但允许从用户端进行简单的类型转换。我计划做的是使用数组下标运算符返回他们通过模板指定的任何类型。虽然,这听起来比实际工作要好得多。这是我正在做的一个简单示例,让您了解它应该如何工作。classStringList{public:templateToperator[](constinti)}从那里,我会定义一些特定的模板,如果需要,任何用户都可以很容易地定义更多。但是,最大的问题是,我不知道如何用模板调用下标运算符。考虑到

c++ - 将 future 存储在列表中

我想将使用异步生成的多个线程的future存储在一个列表中,以便稍后检索它们的结果。futuref=async(doLater,parameter);list>l;l.push_back(f);但是编译器打印出如下错误信息/usr/include/c++/4.7/bits/stl_list.h:115:71:error:useofdeletedfunction'std::future::future(conststd::future&)[with_Res=int;std::future=std::future]'我是做错了什么还是列表不应该存储future?如果不是,应该使用什么?

c++ - 将对象添加到 std::list 时调用对象的析构函数

我有一个Foo对象和一个std::list保存它的实例。我的问题是,当我向列表中添加一个新实例时,它首先调用ctor,然后调用dtor。然后是另一个实例上的dtor(根据this指针)。单个实例已添加到列表中,但由于调用了它的dtor(及其父实例),因此无法按预期使用该对象。下面是一些简化的代码来说明问题:#include#includeclassFoo{public:Foo(){intbreakpoint=0;}~Foo(){intbreakpoint=0;}};intmain(){std::listli;li.push_back(Foo());} 最佳答

c++ - std::string::clear 和 std::list::clear 是否从内存中删除数据

在string::clear函数的描述中,它说:clear:Erasesthecontentsofthestring,whichbecomesanemptystring(withalengthof0characters).在list::clear函数的描述中,它说:clear:Removesallelementsfromthelistcontainer(whicharedestroyed),andleavingthecontainerwithasizeof0.清除是覆盖字符串和列表的内存还是只是释放它们? 最佳答案 这两个函数都不需

c++ - STL列表、 vector 和集合的底层数据结构是什么?

STL列表、vector和集合的底层数据结构是什么?我的解决方案:vector:(动态分配)数组列表:?设置:堆(或所有叶节点尽可能靠左的二叉树,并将最小/最大元素保持在顶部)对吧? 最佳答案 根据评论,澄清一下,这些是最常见的选择,但根据所需的复杂性和其他因素,这些实现的支持可能会有所不同:Vector=动态调整数组大小列表=DoublyLinkedList设置=Red/BlackTree(平衡二叉搜索树)我认为您可能会混淆堆和BST。堆被形象化为一棵树,但它实际上建立在可索引列表结构(例如数组或vector)之上。C++通过al

gcc 4.8.1 : list-initialization for copy constructor doesn't work 中的 C++11

我鼓励这个问题:如果我有classA{public:};intmain(){Aa{};Ab{a};}gcc给出:moves.cc:Infunction‘intmain()’:moves.cc:15:7:error:toomanyinitializersfor‘A’Ab{a};但是当我使用Ab(a)而不是Ab{a}时,所有编译都正确。如果我声明默认构造函数,它也会编译。为什么会这样? 最佳答案 该类是一个聚合,因此列表初始化将执行聚合初始化,并且不会考虑隐式声明的构造函数。因为没有数据成员,所以只有空列表可以是有效的聚合初始化器。Bu

c++ - 以 3 函数的中位数进行的比较次数?

截至目前,我的函数找到3个数字的中位数并对它们进行排序,但它总是进行3次比较。我在想我可以在某处使用嵌套的if语句,这样有时我的函数只会进行两次比较。intmedian_of_3(intlist[],intp,intr){intmedian=(p+r)/2;if(list[p]>list[r])exchange(list,p,r);if(list[p]>list[median])exchange(list,p,median);if(list[r]>list[median])exchange(list,r,median);comparisons+=3;//3comparisonsfore

c++List的详细介绍

c++List详细使用writeinfront作者:@不进大厂不改名专栏:@c++作者简介:大一学生希望能向其他大佬和同学学习!本篇博客简介:本文主要讲述了一种新容器list的使用方法,相信你在学了后,能够加深对STL的理解。本章目标1.List的介绍2.迭代器的使用3.list的元素获取4.list容量相关5.list的操作函数6.总结c++中List的详细介绍c++List详细使用1.List的介绍2.迭代器的使用3.list的元素获取4.list容量相关5.list的操作函数6.总结1.List的介绍List介绍1.list是可以在是可以在常数范围内在任意位置插入和删除的序列式容器,并且