草庐IT

path_files_list

全部标签

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++ - 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

c++ - 尝试打开 COM 端口 C++ 时出现 FILE_NOT_FOUND

我正在尝试使用C++打开一个用于读写的com端口,但我似乎无法通过实际打开它的第一阶段。我在handle上得到一个INVALID_HANDLE_VALUE使用GetLastErrorFILE_NOT_FOUND。我在网上搜索了几天,我的想法很新鲜。我也在这个网站上搜索了所有关于COM的问题。我已经扫描了现有的端口(或者我相信是这样)以获得正确的端口名称。我还尝试了_T("COM1")与斜线、不带斜线、带冒号、不带冒号和不带_T的组合我在64位机器上使用Windows7。这是我得到的代码我很高兴对此有任何意见voidSendToCom(char*data,intlen){DWORDcbN

c++ - 试图从 __FILE__ 中剥离项目路径

以下代码(main.cpp):#include#includestd::vectorsplit(std::stringhaystack,constcharlimiter){std::vectorreturn_value;while(haystack.find(limiter)!=std::string::npos){return_value.push_back(haystack.substr(0,haystack.find(limiter)));haystack=haystack.substr(haystack.find(limiter)+1);}return_value.push_b

c++ - cpplint.py 和 cmake : how to specify include files

假设我有一个目录结构如下的项目:myproject├──.git[...]├──CMakeLists.txt└──src├──CMakeLists.txt├──foo.cc└──foo.h如果在src/foo.cc中,我包含像#include"foo.h"这样的头文件,然后运行​​Google的cpplint.py在它上面,它提示src/foo.cc:8:Includethedirectorywhennaming.hfiles[build/include][4]所以我将它包含为#include"./foo.h"。现在我收到另一个投诉:src/foo.cc:8:src/foo.ccsho

C++ 复制构造函数被调用而不是 initializer_list<>

基于这段代码structFoo{Foo(){coutilist){cout输出是:默认构造函数抄袭者抄袭者在第三种情况下,我将b放入应该调用initializer_list构造函数的大括号初始化中。相反,复制构造函数带头。你们有人能告诉我这是如何工作的吗?为什么? 最佳答案 正如NicolBolas所指出的,此答案的原始版本是不正确的:撰写本文时的cppreference错误地记录了在列表初始化中考虑构造函数的顺序。以下是使用标准n4140草案中存在的规则的答案,该标准非常接近官方C++14标准。原答案的文字仍然包含在内,以备记录。