草庐IT

char_type

全部标签

c++ - 为什么 "initializer-string for array of chars is too long"在 C 中编译良好而不在 C++ 中编译?

以下程序在C中编译正常但有警告,但在C++中编译失败。为什么?这是什么原因?#includeintmain(void){chara[5]="Hello";a[0]='y';puts(a);for(inti=0;i警告:Warning:[Error]initializer-stringforarrayofcharsistoolong[-fpermissive]enabledbydefault但如果程序被编译为C++程序,则C++编译器会给出以下错误:[Error]initializer-stringforarrayofcharsistoolong[-fpermissive]我正在使用GC

c++ - 错误 : no matching function for call to ‘std::vector<std::__cxx11::basic_string<char>>::push_back(int&)’

我是C++的新手。当我运行我的代码时出现此错误:(BigSorting.cpp:Infunction‘intmain(int,constchar**)’:BigSorting.cpp:13:22:error:nomatchingfunctionforcallto‘std::vector>::push_back(int&)’v.push_back(m);^Infileincludedfrom/usr/include/c++/8.1.1/vector:64,fromBigSorting.cpp:2:/usr/include/c++/8.1.1/bits/stl_vector.h:1074:

c++ - FMT C++ 库 : allow user to set format specifiers for custom type

我有一个自定义类型,例如structcustom_type{doublevalue;};我想为此类型设置一个自定义的FMT格式化程序。我执行以下操作并且有效:namespacefmt{templatestructformatter{templateconstexprautoparse(ParseContext&ctx){returnctx.begin();};templateautoformat(constcustom_type&v,FormatContext&ctx){returnformat_to(ctx.begin(),"{}",v.value);}};但问题是,输出格式是由模板

c++ - 将 Boost FileSystem3 迭代器转换为 const char*

我正在使用BoostFileSystem3循环遍历目录中的一些文件,我需要将文件名转换为char*以用于另一个库,不幸的是我的C++foo缺失,任何人都可以帮忙吗?intmain(intargc,char*argv[]){pathp(argv[1]);//preadsclearerthanargv[1]inthefollowingcodetry{if(exists(p))//doespactuallyexist?{if(is_regular_file(p))//isparegularfile?coutvec;//storepaths,vecv;//sowecansortthemlate

c++ - double 到 unsigned int/char

我读了here,即:根据C99§6.3.1.4脚注50:Theremainderingoperationperformedwhenavalueofintegertypeisconvertedtounsignedtypeneednotbeperformedwhenavalueofrealfloatingtypeisconvertedtounsignedtype.Thus,therangeofportablerealfloatingvaluesis(−1,Utype_MAX+1).现在,我对以下之间的细微差别感兴趣(这次是针对C++03!):doubled1=257;doubled2=-2

c++ - g++4.9 错误允许 std::vector<C_type_array>

考虑以下代码:#include#include#includeusingnamespacestd;typedefdouble(C_array)[10];intmain(){std::vectorarr(10);//let'sinitializeitfor(inti=0;i我刚从@juanchopanzahttps://stackoverflow.com/a/25108679/3093378那里得知这段代码不应该是合法的,因为一个普通的旧C风格的数组是不可分配/不可复制/可移动的。然而,即使使用-Wall-Wextra-pedantic,g++也会飞过代码。clang++不编译它。当然,

c++ - 检测某些非数字类型 T 的 std::numeric::type<T> 的特化

我想检查一个类型是否在std::numeric_limits中有一个条目。当类型是一个数组时——(或者可能不是一个数字?)我得到一个编译器错误。这使我无法根据std::numeric_limits是否支持该类型来检测和分支。如果有人愿意分享任何见解,我将不胜感激。//thefollowingprovokescompilererroronClang//Functioncannotreturnarraytype'type'(aka'char[20]')static_assert(!std::numeric_limits::is_specialized,"!std::numeric_limi

c++ - 无法使用自动参数化 true_type 检测 T::value()

使用SFINAE,has_value_int和has_value_auto两者都尝试检测类T是否有一个staticconstexpr名为value的函数.使用int参数化true_type,has_value_int效劳于演示类(class)pass和fail.使用auto参数化true_type,has_value_auto总是返回false。使用int有什么区别?并使用auto,为什么auto不工作?具体来说,为什么重载决策更喜欢match_auto(...)至match_auto(int)?#includeusingnamespacestd;//parametrizetrue_t

java - java函数中static const char *的等价性

我经常在C++中使用这个习语:/*returntype*/foo(/*parameters*/){staticconstchar*bar="Bar";/*somecodehere*/}在内部这被添加到字符串文字表中。这段Java代码是否做类似的事情:/*returntype*/foo(/*parameters*/){finalStringbar="Bar";/*somecodehere*/}还是我无意中引入了效率低下的问题? 最佳答案 字符串在Java中是不可变的。这意味着您不必通过提示让JVM知道它不会更改和优化它。字符串文字被保

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

如何将'wchar_t*'转换为'constchar*'?使用C++MFCVS2010。谢谢。 最佳答案 由于问题是关于MFC的,我建议如下:CStringAa="Test";CStringWw=L"Test";a=CStringA(w);w=CStringW(a);我通常需要以下转换:CStringt=_T("Test");//dependsonTCHARtypea=CStringA(t);//doesnotdependonTCHARtypew=CStringW(t);CStringW和CStringA分别有运算符LPCWSTR和