草庐IT

const-char

全部标签

c++ - 在 C 中初始化一个 char 数组。哪种方式更好?

以下是初始化char数组的两种方式:charcharArray1[]="foo";charcharArray2[]={'f','o','o','\0'};如果两者等同,人们会希望每个人都使用上面的第一个选项(因为它需要更少的击键)。但是我看到过作者总是不厌其烦地使用第二种方法的代码。我的猜测是,在第一种情况下,字符串“foo”存储在数据段中,并在运行时复制到数组中,而在第二种情况中,字符存储在代码段中,并在运行时复制到数组中.出于某种原因,作者对数据段中的任何内容都过敏。编辑:假设数组声明为局部函数。问题:我的推理是否正确?您喜欢哪种风格?为什么? 最佳答案

c++ - 为什么 "gptr"类型的basic_streambuf是char_type*而不是const char_type*?

设置流缓冲的三个“gptr”的basic_streambuf成员,setg声明为:protected:voidsetg(char_type*gback,char_type*gptr,char_type*egptr);我想知道:为什么每个gptr的类型都是char_type*而不是constchar_type*?在这里使用const_cast为这些gptrs使用constchar指针是否安全? 最佳答案 它不是const,因为streambuf接口(interface)不知道您如何填充缓冲区。例如,underflow和uflow方法可

c++ - 为什么 const_cast 需要说明你要转换到什么?

根据标准(§5.2.11),const_cast会丢弃cv限定符(const或volatile)。这是一个简单的例子。首先你声明两个函数接受一个指针和一个引用:classBar{...};voidfoo_ptr(Bar*);voidfoo_ref(Bar&);然后你创建一个常量引用:Barb;constBar&cb=b;然后您可以使用适当的const_cast调用任一函数:foo_ptr(const_cast(&cb));foo_ref(const_cast(cb));这是我的问题:既然const_cast不能做其他类型转换的设计目的,那么您要转换成什么不是很明显吗?换句话说,为什么语

c++ - 无法从 char (*)[10] 转换为 char** 作为返回

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Declaringafunctionthatreturna2Darrayinaheaderfile?我正在尝试为二维数组创建一个简单的getter函数,但我似乎无法找出发送它的正确语法。目前,我有以下内容:classSample{public:char**get2D();private:staticconstintx=8;staticconstinty=10;chartwo_d[x][y];};char**Sample::get2D(){returntwo_d;};

c++ - 在 std::operator << [With _Traits = std::char_traits<char> ] 中不匹配 'operator <<'

我有一个带有字符串转换运算符的Foobar类:#includeclassFoobar{public:Foobar();Foobar(constFoobar&);~Foobar();operatorstd::string()const;};我尝试这样使用它://C++源文件#include#include#include"Foobar.hpp"intmain(){Foobarfb;std::stringstreamss;ss我是否需要为Foobar显式创建一个运算符那么为什么会出现这个错误呢?我错过了什么?[编辑]我刚刚发现,如果我将发生错误的行更改为:ss编译成功。呃……!为什么编译器

c++ - 将 'const wchar_t *' 转换为 'unsigned char *'

在C++中是否可以将'constwchar_t*'转换为'unsignedchar*'?我该怎么做?wstringdirName;unsignedchar*dirNameA=(unsignedchar*)dirName.c_str();//Iamcreatingahashfromastringhmac_sha256_init(hash,(unsignedchar*)dirName.c_str(),(dirName.length)+1); 最佳答案 你需要一个字符一个字符地转换。有像wcstombs这样的函数可以做到这一点。

c++ - 为什么 "const T*"在 "void*"中被简单地转换为 "operator delete"?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Deletingapointertoconst(Tconst*)voidoperatordelete(void*);...constchar*pn=newchar,*pm=(char*)malloc(1);deletepn;//allowed!!free(pm);//errorDemo.可以理解,free()是一个函数,所以constvoid*不能转换为void*。但为什么在operatordelete(默认或重载)的情况下允许这样做?它在功能上不是错误的构造吗?

c++ - 为什么 const 模板化引用类型不同于 const 引用类型?

考虑这个模板:templateclassfoo{typedefconstRefTconst_ref_t;typedefconstT&another_const_ref_t;//...};我假设类型const_ref_t和another_const_ref_t将是等效的。两者都是constT&的。但他们不是。唉,下面对它们不等价的证明是相当详尽的。它取决于使用dynamic_cast检查另一个类的类型。classabstractBase{public:virtual~abstractBase(){}};templateclassotherClass:publicabstractBase{

c++ - unsigned char 和 char 指针之间的区别

我对unsignedchar(在WinAPI中也是BYTE)和char指针之间的差异感到有点困惑。目前我正在处理一些基于ATL的遗留代码,我看到了很多如下所示的表达式:CAtlArrayrawContent;CALL_THE_FUNCTION_WHICH_FILLS_RAW_CONTENT(rawContent);returnArrayToUnicodeString(rawContent);//orreturnArrayToAnsiString(rawContent);现在,ArrayToXXString的实现如下所示:CStringAArrayToAnsiString(constCA

c++ - 无法将 char* 转换为 WCHAR* [qt/c++]

我正在开发QT应用程序,我需要包含纯C代码。当我在code::blocks中编译这段代码时,它是成功的,可能是一个警告,但是当我尝试在QTcreator中编译它时,我得到了这4个错误。cannotconvert'char*'to'WCHAR*'forargument'1'to'UINTGetSystemDirectoryW(WCHAR*,UINT)'cannotconvert'char*'to'constWCHAR*'forargument'1'to'HINSTANCE__*LoadLibraryW(constWCHAR*)'cannotconvert'char*'to'WCHAR*'