草庐IT

max_chars

全部标签

char 类型的 C++ 枚举,被编译器忽略或意外行为?

我用枚举做了一个小测试,这是我拥有的:enumanyoldname:char{aa='a',ab='b',ac='c',ad='d'};intmain(){anyoldnamei_have_an_enum_here=aa;//Wouldexpecti_have_an_enum_heretobeoftypechar?std::cout输出是:98,除非我像这样显式转换为char:std::cout或者将anyoldname改为char。为什么打印的是98而不是b?顺便说一句,sizeof()返回1,即;1个字节,一个char。 最佳答案

c++ - 为什么 std::max 由 const 返回?

我想找到最大值Foo并对其调用inc(),这是一个非常量方法。当然,在寻找最大值时,我不想创建任何拷贝或移动,即我不想要Foofoo=std::max(foo1,foo2)。我尝试编写自己的max,但g++坚持要我返回一个const&。#includeclassFoo{public:Foo(intx):x_(x){std::cout(constFoo&foo)const{returnx_>foo.x_;}voidinc(){++x_;}intx_;};/**Doesn'tcompile.MustreturnconstT&ormustacceptnon-constT&*templatei

c++ - 使用带有 char * 的正则表达式迭代器

我正在尝试将文件读入缓冲区,然后使用正则表达式迭代器。我知道我可以将C++字符串迭代器与正则表达式迭代器一起使用(构造函数是std::regex_iterator),但我想避免将缓冲区复制到字符串中并继续使用低级函数来读取文件(现在我使用open()和read())。structstatbuff;intfile=open(argv[1],O_RDONLY);if(!file)cout我认为我的选择是找到一种使用read()的方法使用C++字符串而不是char*或在char数组上使用正则表达式迭代器的方法。我可以写一个,但我也在努力让我的程序尽可能小。有什么办法可以做到吗?如何将C++字

c++ - 为异质宽度的整数编写 std::min/std::max

我的C++程序使用不同宽度的无符号整数来表示对可以表示的数据的约束。例如,我有一个大小为uint64_t的文件,我希望使用大小为size_t的缓冲区以block的形式读取它。block是缓冲区大小和(剩余)文件大小中较小的一个:uint64_tfile_size=...;size_tbuffer_size=...;size_tchunk_size=std::min(buffer_size,file_size);但这失败了,因为std::min要求两个参数具有相同的类型,所以我必须向上转换然后再向下转换:size_tchunk_size=\static_cast(std::min(sta

c++ - string s怎么改成char * a[]?

我要转型字符串s="aaa,bbb,ccc"进入:char*a[]={"aaa","bbb","ccc"}你能帮我编写程序来处理这个过程吗?我会尝试这样编程:strings="aaa,bbb,ccc";char*a[];charid[]="";strcpy(id,s.c_str());constchar*split=",";char*p;p=strtok(id,split);while(p!=NULL){inti=0;printf("%s\n",p);a[i]=p;i++;p=strtok(NULL,split);}我哪里错了?谁能指点一下? 最佳答案

c++ - 没有 "predicate"的对 vector 上的 max_element

我想找到pairs的vector的最大元素。我的标准是:最大元素是一对中第二个值最高的元素。我这样做了:automax_angle=std::max_element(begin(angles),end(angles),[](conststd::pair&left,conststd::pair&right){returnleft.second不写谓词是否可以做到?由于它是标准结构,是否有更简单的配对方法? 最佳答案 不,你不能,因为默认情况下std::pair是按字典顺序比较的,这意味着从左到右逐元素。因此,您的解决方案是您可以拥有的

c++ - 创建一个字符串如何改变 const char* 指向的值?

我编写了一个函数,它接受一个字符串并返回一个constchar*,其中包含该字符串的编码版本。我调用这个函数,然后创建一个新的字符串。这样做时,我无意中更改了指向我的constchar*的值,我认为这是不可能的。但是,当我不使用我自己的函数,而只是将一个值硬编码到我的constchar数组中时,当我创建一个字符串时该值不会改变。为什么这里有区别,为什么我仍然能够更改constchar数组的值?#include#include#include#include#includeusingnamespacestd;//returns"@username@FIN"constchar*encode

c++ - `reinterpret_cast<char*>(reinterpret_cast<uintptr_t>(&ch) + 1) == &ch +1` 有保证吗?

我正在编写与对齐相关的代码,如果给定的指针正确对齐,却没有标准的功能测试,这让我感到非常惊讶。似乎互联网上的大多数代码都使用(long)ptr或reinterpret_cast(ptr)测试对齐,我也使用了它们,但我想知道使用指向整数类型的强制转换指针是否符合标准。这里是否有任何系统触发断言?charch[2];assert(reinterpret_cast(reinterpret_cast(&ch[0])+1)==&ch[1]); 最佳答案 回答题目中的问题:没有。反例:在旧的Pr1me微型计算机上,一个普通指针是两个16位字。第

c++ - 为什么我不能在 struct 中初始化 char 数组

我尝试通过以下方式在结构声明中初始化一个char数组。但它无法编译并显示错误消息。请告诉我为什么它无法编译。#includestructA{constcharvalue_in_struct[]="a";//thislinegivesmeaerrormessage.};voidt(void){constcharvalue[]="a";//thislinewasokatcompilingstd::cout我从gcc收到以下错误消息。../static_constexpr_array.hpp:16:33:error:initializer-stringforarrayofcharsistoo

c++ - 为什么 C++ char 数据类型 3d array 当传递参数第一个括号为空时

请看下面的代码:#includeusingnamespacestd;intmain(){charmatrix[2][2][2];return0;}intgetMatrixData(charmatrix[][2][2],intx,inty,intz){returnmatrix[x][y][z];}矩阵3d数组作为参数传入函数时,为什么不指定第一个[]大小就可以了?如何解释这个缺失的维度? 最佳答案 您的代码在语法上不正确。假设您的意思是intgetMatrixData(charmatrix[][2][2],intx,inty,intz