草庐IT

char_set

全部标签

c++ - 如何从 QString 获取 const char *

我从一个UTF8编码的XML文件中读取了一个字符串。我将这个值存储在QString对象中,并将它与其他一些信息连接起来。我可以在QtCreator调试器中看到QString包含所需的值。我需要将此字符串传递给另一个采用constchar*参数的库。请问如何获取constchar*?我试过toLocal8bit()、toLatin1()、toUtf8()都没有成功。好像我错过了什么...... 最佳答案 Ineedtopassthisstringtoanotherlibrarythattakesaconstchar*argument.

c++ - 二进制表达式 ('ostream'(又名 'basic_ostream<char>')和 'ostream' 的无效操作数)

我正在努力cout但是,编译时出现“二进制表达式的无效操作数('ostream'(又名'basic_ostream')和'ostream')”错误。#includeusingnamespacestd;ostream&Print(ostream&out){out为什么这不起作用?我怎样才能解决这个问题?谢谢!! 最佳答案 您可能正在寻找的语法是std::cout.pointer函数被视为操纵器。内置operator将指针指向Print并用cout调用它.#includeusingnamespacestd;ostream&Print(o

c++ - 从 map<key, set<datatype>> 访问元素

我正在使用如下所示的数据结构:map>data;到目前为止,我在使用foreach循环处理map时没有遇到任何问题,但是,现在我需要像这样打印出map中的数据:KEY:elem1,elem2,elem3KEY2:elem1,elem2,elem3由于末尾缺少逗号,我不能再使用foreach循环了(可以吗?)。由于我是C++、C++11及其提供的所有乐趣的新手,所以我很迷茫。我想到了:for(autoi:data){cout我知道自己想要什么,只是对语法一无所知,C++引用也帮不上什么忙。感谢您的回答,同时我将自己浏览C++引用资料。 最佳答案

c++ - "cout<<(char*)NULL"在这里做 "close(1)"吗?

这个问题在这里已经有了答案:Whydoesstd::coutoutputdisappearcompletelyafterNULLissenttoit(3个答案)关闭8年前。在下面的代码中我使用了cout在这一行之后,我的程序没有在输出屏幕上打印任何内容。这是否意味着我已经完成了close(1)与cout这里?这里到底发生了什么?这是一个错误吗?请分享您的想法。#includeusingnamespacestd;voidf(){cout我在gcc和DevCpp编译器上都试过了,观察到相同的行为。

c++ - 是否有任何 std::set 实现不使用红黑树?

有没有人见过STL的实现,其中STL::set不是实现为红黑树?我问的原因是,在我的实验中,B树优于std::set(和其他红黑树实现)2到4倍,具体取决于值B.我很好奇,当似乎有更快的数据结构可用时,是否有令人信服的理由使用红黑树。 最佳答案 Google的一些人实际上构建了一个B-treebasedimplementationoftheC++standardlibrarycontainers.它们的性能似乎比标准二叉树实现要好得多。不过有一个问题。C++标准保证从映射或集合中删除元素只会使指向映射或集合中相同元素的其他迭代器无效

c++ - 迭代 boost::icl::interval_set

我正在迭代boostinterval_set,我期望每个迭代器都是一个boostinterval,其值将通过upper访问和lower方法:boost::icl::interval_setoutages;//...//Insertintervalsintothedatabasefor(boost::icl::interval_set::iteratorit=outages.begin();it!=outages.end();it++){DATA_ACQUISITION::InsertInterval(db,it->lower(),it->upper())}但我在两个lower都收到错误

c++ - 在 C++ 中创建指针数组的 char* 和 int* 数据​​类型有什么区别?

在为int数据类型创建指针数组时,以下代码有效:intvar[]={10,100,200,1000};int*ptr[]={&var[0],&var[1],&var[2],&var[3]};在为char数据类型创建指针数组时,以下是合法的:char*names[]={"MathewEmerson","BobJackson"};但是如果我为int数据类型创建一个指针数组,如下所示:intvar[]={10,100,200,1000};int*ptr[]={var[0],var[1],var[2],var[3]};我收到一个编译器错误。我明白为什么我在上述int数据类型数组的声明方法中遇到

c++ - char 是唯一具有强制大小的类型吗?

在C++标准中:sizeof(char),sizeof(signedchar)andsizeof(unsignedchar)are1.C++中是否有任何其他类型具有固定的sizeof?空结构符合这个定义吗? 最佳答案 没有。如您所说,sizeof(signedchar)、sizeof(unsignedchar)和sizeof(char)由标准定义为1.请注意,char必须是signed或unsigned,但它始终被视为不同类型。sizeof任何其他内容都取决于实现,但要受到某些约束(例如sizeof(long)不能小于sizeof(

c++ - 为什么 char 数组的 alignof 总是 1?

我正在阅读一些关于C++中对齐的内容,但我不确定为什么仅包含char数组成员的类的对齐不是数组的大小,但事实证明始终为1。例如#includestructFoo{charm_[16];};//shouldn'tthishavea16bytealignment?!intmain(){std::coutLiveonColiru在上面的代码中很明显sizeof(Foo)是16,但是它的对齐是1,看代码的输出。为什么alignof(Foo)在这种情况下是1?请注意,如果我将charm_[16];替换为intm_;之类的基本类型,那么alignof(Foo)就会变成我想要的已经预料到了,即siz

c++ - 以类似于初始化字符串文字的方式初始化 char 数组

假设我正在对一个char数组进行初始化:charcharArray[]={'h','e','l','l','o','','w','o','r','l','d'};我还有以下字符串文字的初始化:charstringLiteral[]="helloworld";第一个数组和第二个字符串的内容之间的唯一区别是第二个字符串的末尾有一个空字符。当涉及到初始化char数组的问题时,是否有宏或其他东西允许我们将初始化文本放在两个双引号之间,但数组没有额外的空终止字符?对我来说没有意义的是,当不需要终止空字符时,我们应该使用首先提到的初始化语法并为初始化文本中的每个字符写两个单引号,以及virgule