草庐IT

char_type

全部标签

c++ - `mpl::plus< mpl::int_<1>, mpl::int_<2>>::type` 与 `mpl::int_<3>` 不是同一类型?

下面的代码再现了一个我真的不理解boostMPL库的行为:#include#include#includeusingnamespaceboost;intmain(){typedefmpl::int_one;typedefmpl::int_two;typedefmpl::int_three;//Thefollowinglinebreakscompilation...//static_assert(is_same::type,three>::type::value,"Notthesametype");//...whilethisworksstatic_assert(mpl::plus::t

c++ - 从 void* 到 char* 的无效转换 C++ 从文件读取链表

我正在尝试编写一个从文本文件读取到链表的程序这是列表结构。#include#include#includeusingnamespacestd;structVideo{charvideo_name[1024];//videonameintranking;//Numberofviewerhitscharurl[1024];//URLVideo*next;//pointertoVideostructure}*head=NULL;//EMPTYlinkedlist这里是读入代码:voidload(){structVideo*temp;temp=(Video*)malloc(sizeof(Vid

c++ - 解码 Microsoft True Type 字体文件

我正在使用TFTLCD作为显示器(480x800px)的嵌入式平台(STM32F407)工作,并且想让我的用户界面在某种程度上为最终用户定制。我认为最好的字体来源是与Windows兼容的,因为它们最常见。我当前的实现使用我自己的二进制格式的自定义绘制字体和一个给出字符宽度和ascii值的描述符表,但不得不一点一点地绘制我自己的字体是乏味的。我想从SD卡中读取TrueType字体文件,并能够使用其中不同大小的字形,但我还没有看到关于如何实际实现这种魔力的直接实现。有人可以指出我正在寻找的一个很好的c/c++示例吗?作为解决问题的更好方法,我想制作一个简单的gcc命令行程序,它将使用“#”

c++ - pointer_traits 为既不是 X<A, T...> 也没有提供成员 typedef element_type 的类型提供什么?

下面的结果是什么?它是格式错误、未定义的行为还是定义良好且格式正确的行为?structA{};std::pointer_traitsx;我之所以问,是因为好奇想知道,也想知道任意类型是不是指针。我还想包括shared_ptr和friend。我想知道是否有类型特征(谓词),如果没有,我是否可以使用pointer_traits并检测是否声明了element_type。 最佳答案 它表示从20.6.3p1开始格式错误,因为它没有element_type并且不是类模板实例化typedefseebelowelement_type;Type:P

c++ - 如何将int转换为char C++

我在分配时遇到问题,我必须在方法中将时钟的三个变量(inthour、intminutes和boolafternoon)转换为字符串。我尝试将int转换为char,然后用char替换每个字符串。如果转换成功与否,该函数应该返回T/F。这是我目前所拥有的:classTime{private:inthour;intminutes;boolafternoon;public:voidsetHour(inthr);voidsetMinutes(intmin);voidsetAfternoon(boolaft);intgetHour();intgetMinutes();boolgetAfternoo

c++ - std::map<key_type, value_type>::find(different_key_type)

我有一张map:std::mapmyMap;但是,在某些情况下,我想通过比较TyString==TyStringRef来std::map::find一个条目,即myMap.find(TyStringRef("MyString"));原因是TyString包装了一个它自己分配和释放的constchar*。但是,为了只找到一个条目,我不喜欢分配一个新的字符串,而是我只想使用引用(TyStringRef只包装一个constchar*而不分配或释放内存)。当然,我可以将TyStringRef转换为TyString,但这样我就有了上述的内存开销。有解决这个问题的智能方法吗?谢谢!

c++ - 模板化 ostream 重载歧义错误 : basic_ostream<char> vs const char[]

我正在尝试了解ostream重载。考虑一下#includeusingstd::ostream;enumclassA{a1,a2,a3};templateostream&operator编译时出现如下错误test.cpp:13:17:error:ambiguousoverloadfor‘operator}’and‘constchar[3]’)returnout虽然取消注释正常功能和注释模板版本工作正常。为什么二义性不是在正常功能中,为什么是模板化版本 最佳答案 非模板运算符不会引起任何歧义,因为该运算符本身无法解决此调用:return

C++ const char* 和 const char[] 的区别

我读到一个关于两者之间区别的问题:constchar*和constchar[]有一段时间,我认为数组只是指针的语法糖。但是有些事情困扰着我,我有一段类似于以下的代码:namespaceSomeNamespace{constchar*str={'b','l','a','h'};}我明白了,错误:缩放器对象“str”需要初始化器中的一个元素。所以,我尝试了这个:namespaceSomeNamespace{constcharstr[]={'b','l','a','h'};}成功了,起初我认为这可能与应用了额外的操作有关当它是一个constchar*时,GCC从来不喜欢在函数外执行操作(无论

c++ - 在 C++ 中将 char 或 string 转换为 bitset

我正在做关于DES加密的作业,我似乎无法将字符串转换为位集,更不用说将char转换为位集了。谁能告诉我如何在C++中将单个字符转换为位集? 最佳答案 以下内容:charc='A';std::bitsetb(c);//implicitcasttounsignedlonglong应该可以。参见http://ideone.com/PtSFvz如果可能的话,将任意长度的string转换为bitset更难。位集的大小必须在编译时已知,因此实际上没有办法将字符串转换为一个。但是,如果您在编译时知道字符串的长度(或者可以在编译时绑定(bind)它

c++ - 当输入 char 代替 int 时避免无限循环

我正在做一个银行系统项目,需要确保每个输入都是有效的(程序必须是健壮的)。如果输入无效,则用户必须重新输入。但是当我有一个int类型的变量并且用户输入char类型时,一个无限循环开始了。例如:inti;cin>>i;如果用户输入char无限循环开始。我怎样才能避免它并再次要求用户输入?谢谢 最佳答案 无限循环的原因:cin进入失败状态,这使得它忽略对它的进一步调用,直到错误标志和缓冲区被重置。cin.clear();cin.ignore(100,'\n');//100-->askscintodiscard100charactersf