草庐IT

CHAR_BIT

全部标签

c++ - 为什么C++11中signed char的范围是-127到127?

这个问题在这里已经有了答案:Doestherangeforintegervaluesofachardependonimplementation?(5个答案)关闭4年前。我正在通读BjarneStroustrup的《C++编程语言第4版》,但我无法完全理解第141页中提到的以下段落。Eachcharacterhasanintegervalueinthecharactersetusedbytheimplementation.Forexample,thevalueof'b'is98intheASCIIcharacterset.Hereisaloopthatoutputsthetheinteg

c++ - 通过 "\0"而不是 memset() 批量初始化 char 数组

通常由memset初始化的字符数组。我在我的项目代码中发现了由"\0"初始化的char数组。我还编译并检查了,它工作正常。我的问题是这是批量初始化char数组的正确方法吗?例如:chara[20]="\0";printf("%s",a); 最佳答案 是的,这是正确的方法之一。对于c引用C11,第6.7.9章Iftherearefewerinitializersinabrace-enclosedlistthanthereareelementsormembersofanaggregate,orfewercharactersinastri

c++ - 如何将 LPCWSTR 转换为 const char *?

如何将LPCWSTR转换为constchar*?谢谢 最佳答案 使用WideCharToMultiByte功能。请注意,LPCWSTR与constwchar_t*相同,因此如果您在整个应用程序中处理宽字符数据,则可能不需要在全部。 关于c++-如何将LPCWSTR转换为constchar*?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4542521/

c++ - 将 char* 分配给字符串而不复制

这个问题在这里已经有了答案:initializingstd::stringfromchar*withoutcopy(6个答案)关闭9年前。这是一个非常简单的问题,但我发现它很棘手。我想把一个char*当作一个std::string,例如:char*p=...;//readahugechuckfromafilestd::strings(p);//thisisnotwhatIwant所以,如果我使用构造函数,我得到了p的拷贝,这是浪费内存和时间。是否有可能以某种方式避免这种情况,并将std::string内容“分配”到预先存在的地址?任何其他想法都非常受欢迎!谢谢!

c++ - 在 char 数组中搜索子字符串

这个问题在这里已经有了答案:Getasubstringofachar*[duplicate](5个答案)关闭9年前。据我所知,在C++字符串中有一个函数可以执行子字符串搜索:string1.find(string2)。有什么方法可以在char中执行相同的操作?下面是我的问题:#include#includeusingnamespacestd;intmain(){chara[]="helloworld!";charb[]="el";//findsubstringb[]ina[]}假设我需要在字符串中找到子字符串“el”,是否可以这样做?

c++ - 如何处理: redeclaration of C++ built-in type ‘char16_t’

在C++11项目中,我必须使用外部C库。该库主头文件定义typedefuint16_tchar16_t;因此,包含该库的C++程序编译失败,并显示消息:redeclarationofC++built-intype‘char16_t’我唯一的想法是重新打包整个库,但是因为char16_t在这个库中很普遍,所以会非常耗时(如果可能的话)。有没有一些明智的方法来处理这个问题?编辑:我还有另一个想法,即删除有问题的行并将每次出现的char16_t替换为uint16_t,但我将不得不修改第三方库header,我并不特别喜欢这个想法(可能会有更多类似的错误)。所以我也想知道在包含头文件时是否有一些

c++ - 将 shared_ptr 与 char* 一起使用

我无法创建:shared_ptrn_char=make_shared(newchar[size_]{});如何创建char*chr=newchar[size_]{};使用现代指针? 最佳答案 shared_ptrn_char=make_shared(newchar[size_]{});make_shared在内部调用new,因此您永远不会同时使用两者。在这种情况下,您只需调用new,因为make_shared不适用于数组。但是,你仍然需要让它调用正确的删除:C++17之前:您需要明确指定删除器。std::shared_ptrptr(

c++ - 如何在 std::string 中存储 const char*?

char*buffer1="abc";constchar*buffer2=(constchar*)buffer;std::stringstr(buffer2);这行得通,但我想声明std::string对象,即str,一次并多次使用它来存储不同的常量字符*。出路在哪里? 最佳答案 您可以重新分配:constchar*buf1="abc";constchar*buf2="def";std::stringstr(buf1);str=buf2;//Callsstr.operator=(constchar*)

c++ - 将字符串文字分配给 char*

以下代码在C++0x中是合法的、弃用的还是非法的?char*p="foobar";我最初问这个问题here作为评论。 最佳答案 转换char*p="foobar";在C++98/C++03中被弃用,并在C++0x中被移除(即,§4.2/2被移除)。因此,该代码在C++0x中无效。但是,MinGWg++4.4.1仍然只发出警告,不发出错误。C++98/C++03§4.2/2(whichisremovedinC++0x):Astringliteral(2.13.4)thatisnotawidestringliteralcanbeconv

c++ - static_cast<char*> 和 (char*) 之间的区别

这是我的第一个问题:)我有一堆文件,我打开它如下图所示;ifstreamin(filename,ios::binary|ios::in)然后,我希望在unsignedinthold中保存2个字节的数据;unsignedinthold;in.read(static_cast(&hold),2);这对我来说似乎是正确的。但是,当我用编译它时g++-ansi-pedantic-errors-Werror--Wall-omainmain.cpp编译器报错error:invalidstatic_castfromtype‘unsignedint*’totype‘char*’其实我已经通过将stat