草庐IT

c++ - 在 C++ 中比较 char 和 Int

在C++中,由于隐式类型转换,可以将int与char进行比较吗?还是我误解了这个概念?比如,我能不能做intx=68;chary;std::cin>>y;//Assumingthattheuserinputs'Z';if(x还是我们需要先将其转换为int?所以if(x(y)){cout 最佳答案 两个版本的问题是您无法确定由负值/大值产生的值(如果char确实是符号字符)。这是实现定义的,因为实现定义了char是指signedchar还是unsignedchar。解决此问题的唯一方法是首先转换为适当的有符号/无符号char类型:if

c++ - 如何将 unsigned char[] 转换为 std::vector<unsigned char>

我正在尝试将其传递给我的项目的另一部分,该部分要求它是一个vectorunsignedcharvch[65];unsignedintsize()const{returnGetLen(vch[0]);}constunsignedchar*begin()const{returnvch;}constunsignedchar*end()const{returnvch+size();std::vectorRaw()const{return(vch,vch+size());}我得到了错误couldnotconvert'(constunsignedchar*)(&((constCPubKey*)th

c++ - 为什么这个编译器错误? - 没有匹配函数调用 'std::basic_ofstream<char>::open(std::string&)'

这适用于VisualStudio,并且适用于一台计算机上的GCC4.9.2。但在不同的计算机上,我认为它是相同的GCC4.9.2编译器,但它给了我这个错误。我错过了什么吗?怎么回事?#include#include#includeusingnamespacestd;intmain(){stringfilename;filename="teststring";ofstreamfout;fout.open(filename);fout.||===Build:Debuginfileiotest(compiler:TDM32GNUGCCCompiler4.9.2dw2)===|F:\Users

c++ - std::string 与静态常量的 char 数组

我想在我的cpp文件中的多个位置使用字符串常量。我应该使用std::string还是char[]?staticconststd::stringkConstantString="ConstantStringValue";staticconstcharkConstantString[]="ConstantStringValue";有人告诉我更喜欢后者,因为它“避免了静态分配”。char数组不是也必须静态分配吗? 最佳答案 是的,是的,它也必须静态分配。总是使用std::string除非你的探查器告诉你它值得惹恼像constchar[]这

c++ - 对于具有 char[] 的结构,浅拷贝是否足够?

我有一个包含字符数组的结构,没有任何其他成员函数。我正在这些结构的两个实例之间进行赋值操作。如果我没记错的话,它正在做浅拷贝。在这种情况下浅拷贝安全吗?我已经在C++中尝试过它并且它有效,但我只想确认这种行为是否安全。 最佳答案 如果通过“浅拷贝”,你的意思是在分配一个包含数组的struct之后,该数组将指向原始struct的数据,然后:它不能。数组的每个元素都必须复制到新的struct中。如果你的结构有指针,“浅拷贝”就会出现。否则,您不能进行浅拷贝。当您将包含数组的struct分配给某个值时,它不能进行浅拷贝,因为这意味着分配给

c++ - 测试 char* 字符串是否包含多字节字符

我从TCP服务器接收到一个字节流缓冲区,其中可能包含形成unicode字符的多字节字符。我想知道是否总有一种方法可以检查BOM以检测这些字符,否则您想怎么做? 最佳答案 如果你知道数据是UTF-8,那么你只需要检查高位:0xxxxxxx=单字节ASCII字符1xxxxxxx=多字节字符的一部分或者,如果您需要区分前导/尾部字节:10xxxxxx=多字节字符的第二个、第三个或第四个字节110xxxxx=2字节字符的第一个字节1110xxxx=3字节字符的第一个字节11110xxx=4字节字符的第一个字节

c++ - std::string 真的包装了一个 C char 数组吗?

我一直认为std::string是作为C字符数组字符串的STL包装器实现的。但是仔细观察这个设计,我注意到它没有给出任何暗示或迹象表明它是一个包裹起来的C弦。据我所知,std::string可以在内部做任何事情!当然有c_str()方法,我认为它返回了内部字符数组,但我怎么知道该方法是否没有创建一个新cchar数组从它存储在里面的任何数据并返回它?说真的,std::string是如何实现的?它(看起来)只是Cchar数组的包装器,还是其他东西?还是两者的混合?或者甚至可以有条件地成为两者? 最佳答案 ForallIknowanstd

C++ char 单引号与双引号和内存内部工作原理

我想知道程序在运行时在内存方面做了什么,因为它遇到以下情况:charchr='a';charchrS[]="a";cout这会产生以下内容:Address:a�c�3�Address:0x7fff33936280为什么获取不到“chr”的内存地址? 最佳答案 因为&chr产生char*(此处隐式添加const)和cout假定它是一个字符串,因此以null结尾,但事实并非如此。然而,&chrS产生char(*)[],它不会衰减到constchar*因此将通过operator输出重载,打印地址。如果您想要constchar*的这种行为您

c++ - const char * 值生命周期

这个问题在这里已经有了答案:Canalocalvariable'smemorybeaccessedoutsideitsscope?(20个答案)关闭7年前。编辑:重复标记中的链接问题已经回答了为什么这个问题中的代码有效的问题。关于字符串文字生命周期的问题在这个问题的答案中得到了回答。我试图了解constchar*指向的字符串如何以及何时被释放。考虑:constchar**p=nullptr;{constchar*t="test";p=&t;}cout离开内部范围后,我希望p成为指向constchar*的悬空指针。但是在我的测试中它不是。这意味着即使在t超出范围之后,t的值实际上仍然有效

c++ - 指向 char 的指针与指向数组的指针

在我决定复习一些所谓的简单示例之前,我认为我对指针有一定的了解。我知道的一件事是,在声明数组时说:intarr[2]{3,5};arr将保存数组中第一个元素的值,因此尝试打印(cout)显然给出了arr[0]的地址.即使我的程序使用指针它仍然相似。我的问题是为什么我可以打印h并且有bonjour作为输出,但我不能对p做同样的事情?当我增加h++时它看起来也像然后再次打印我得到onjour.指针与char有何不同??#include#includeintmain(){char*h="bonjour";intk[4]{3,4,5,6};int*p=k;std::cout