草庐IT

list_comp_values

全部标签

c++ - std::list 固定大小

如何创建具有固定元素计数的std::list? 最佳答案 如果您只想要一个固定大小的容器,也许您正在寻找std::tr1::array.(或者对于C++0x只是std::array。)如果您不插入或删除元素,我认为使用std::list没有任何优势。而不是std::array或std::vector. 关于c++-std::list固定大小,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questi

c++ - C/C++ : passing a struct/class with a member array to a function by value

structA{intV[100];};voidf(Aa){a.V[0]=30;}intmain(){Aa;a.V[0]=10;f(a);cout我期望30作为输出,但我得到了10。我知道,如果参数是按值传递的,数组(也是类/结构的成员)也是按引用传递的。相反,当成员时,它们似乎是通过拷贝传递的。是真的吗? 最佳答案 按值将数组作为参数传递给函数会导致它衰减为指向第一个元素的指针,这就像按引用传递一样。将一个包含数组(不是指针)的对象按值传递给函数会导致该对象(包括数组)被复制到函数的参数中。如果您想在调用站点看到该修改,请通过非常

c++ - 编码练习 : return by value or by reference in Matrix multiplication?

我正在引用thisone写这个问题我昨天写的。在一些文档之后,我似乎很清楚我想做的事情(以及我认为可能的事情)几乎是不可能的,如果不是根本不可能的话。有几种实现它的方法,由于我不是经验丰富的程序员,我问你会选择哪一种。我再次解释了我的问题,但现在我有一些解决方案可以探索。我需要什么我有一个Matrix类,我想实现矩阵之间的乘法,这样类的使用非常直观:Matrixa(5,2);a(4,1)=6;a(3,1)=9.4;...//Andsoon...Matrixb(2,9);b(0,2)=3;...//Andsoon...//AfterawhileMatrixi=a*b;我昨天有什么此刻我重

list::sort 的 C++ 自定义比较函数

您好,我在编译一段简单的代码时遇到了问题。我正在创建一个实现一副纸牌的类,我想使用list::short方法创建一个洗牌方法。相关代码:deck.h#ifndef_DECK_H#define_DECK_H#include#include#include"Card.h"#include"RandomGenerator.h"usingnamespacestd;classDeck{private:staticconstintCARD_NUMBER=Card::CARDS_PER_SUIT*Card::SUIT_NUMBER;list*cards;RandomGeneratorrg;publi

c++ - 按值(value)返回总是常量吗?

此代码无法编译:classC{};voidfoo(C&c){}Cbar(){returnC();}intmain(){foo(bar());}foo(bar())行中的编译错误(GCC4.1.2):invalidinitializationofnon-constreferenceoftype'C&'fromatemporaryoftype'C'由于bar()返回一个mutable对象,它应该编译...为什么C++不允许上述代码?编辑:我在ananswerbelow中做了总结所有答案的所有好主意;-) 最佳答案 此处适用的规则是您不能

c++ - std::list、std::vector 方法和 malloc()

在中断处理程序下使用STL:list和STL::vector类型我想避免调用malloc()。问题:防止在STL列表和vector中调用malloc()的最佳方法是什么?创建具有预定义大小的结构然后避免push/pop/erase调用就足够了吗?提前致谢 最佳答案 std::list和std::vector等STL容器具有接受Allocator类型的构造函数。通过提供您自己的分配器而不是使用默认分配器,您可以控制容器分配内存的方式。这个选项很少使用,但是在实时环境中使用你自己的分配器是一个很好的例子,说明了这个特性在哪里有用(并证明

c++ - 使用 C++11 Lambda 函数更改 vector(list, deque...) 中的所有元素

我有以下代码:#include#include#includeintmain(intargc,char*argv[]){std::vectorobj;obj.push_back(10);obj.push_back(20);obj.push_back(30);std::for_each(obj.begin(),obj.end(),[](intx){returnx+2;});for(int&v:obj)std::cout结果是:10、20、30我想使用新C++11标准的Lambda函数更改vector(obj)中的所有元素。这是for_each函数的实现代码:templateFunctio

c++ - 在 initializer_list 中使用临时变量会导致访问错误

这个问题在这里已经有了答案:Doubledeleteininitializer_listvs2013(1个回答)关闭8年前。我正在尝试使用initializer_list来实例化一个类,但出现了连线错误。当尝试使用以下方法创建`ClassB``变量时:ClassBb={{1,{}},{2,{}};将发生内存访问冲突。但是,如果更改为:ClassAa0,a1;ClassBb={{1,a0},{2,a1}};错误消失。我尝试使用VC2013(没有更新1)和gcc-c++4.8.1进行编译。使用gcc-c++4.8.1不会产生任何运行时错误。是VC的bug吗?谁能帮忙确认一下?谢谢!以下是S

c++ - 在键上使用 gpg --list-packets 的输出来获取 mpi 值以生成 s 表达式

我正在尝试使用gpg生成的公钥使用libgcrypt进行加密。我在key上使用了listpackets命令来获取key的内容,并将mpi值解析为一个s表达式。因此,当我尝试使用我的公钥对我的sessionkey进行编码时,我收到错误消息“S表达式中的奇数十六进制数”?我认为列表数据包可能会给我没有前导零的十六进制数字?如果是这样,我需要做什么才能获得可以在libgcrypt中使用的mpi值? 最佳答案 经过gpg和libgcrypt邮件列表的反复试验和建议后,listpackets命令会截断mpi值中的前导零,因此您必须在mpi值前

c++ - 编译器如何传递 `std::initializer_list` 值? (或 : how can I get around a universal overload with one? )

Continuingmysaga,我意识到我可以使用单个std::initializer_list参数来重载我的访问函数:classarray_md{//...my_type&operator[](size_typei){/*Lotsofcode*/}my_typeconst&operator[](size_typei)const{/*sameLotsofcode,with"const"sprinkledin*/}my_type&operator[](std::initializer_listi){/*Lotsofdifferentcode*/}my_typeconst&operato