草庐IT

const-char

全部标签

c++ - 自动转换模板<T>到模板<const T>

下面的这段应该主要用于T={char,constchar}的字符串View是主要的预期模板实例化目标。cmp函数应该类似于strcmp来比较View。.问题是虽然char*愉快地转换为constchar*我不知道如何获得SVec转换为SVec一样开心。最后一行(cout)无法编译。我必须明确地进行转换(cmp(SVec(rv),rvc))。它可以像char*一样自动吗?至constchar*?代码(大大简化):templateclassSVec{protected:T*begin_;size_tsize_;public:SVec(T*begin,size_tsize):begin_(b

c++ - 为什么 static const char * template struct 成员没有初始化

我有一些C++11模板代码,我正在尝试移植到VisualC++Compiler2015。原始代码工作得很好,但是我需要重写它以解决constexpr的问题。Theoriginalcode(simplifiedexample)#includestructString{staticconstexprconstchar*value{"STRING"};};templateclassDerived{public:staticconstexprconstchar*value{Base::value};};templatestructFoo{staticconstexprconstchar*val

c++ - 类型的模板特化和 const 限定符

为什么编译器期望模板在(具体)类型上单独特化T和constT?让我举个例子。我有一个由类类型键控的无序映射Keystd::unordered_mapdata;要编译它必须专门化std::hash在类型上Key作为namespacestd{templateclasshash{/*implementation*/};}但是,当我将map类型更改为std::unordered_mapdata;编译器没有使用我的特化,而是选择了通用的std::hash,这只不过是一个编译时断言,直到我专门化std::hash.撇开使用const限定映射键类型的实用程序,为什么不constT折叠到T在寻找这种情

c++ - boost::lexical_cast<signed char> 无法处理负数?

这个简短的C++程序的行为方式让我感到困惑:#include#include#include#includeintmain(void){signedcharc=-2;assert(c==-2);c=boost::lexical_cast(std::string("-2"));std::cout使用g++5.2.1和boost-1.58.0,我得到:terminatecalledafterthrowinganinstanceof'boost::exception_detail::clone_impl>'what():badlexicalcast:sourcetypevaluecouldn

c++ - 期望 const std::string & 的函数的链接器错误

尝试链接共享库(gtkmm)时,我收到其签名包含std::stringconst&的函数的链接器错误。例如,如果函数声明为voidset_icon_from_file(conststd::string&);g++报告undefinedreferenceto`Gtk::Window::set_icon_from_file(std::stringconst&)'我正在使用pkg-config中的链接器标志,而其他函数(例如,将基本类型作为参数的函数)不会发生这种情况,因此我怀疑链接器配置正确。readelf我的目标文件给了我45:00000000000000000NOTYPEGLOBALD

c++ - const 应该用于捕获错误还是用于文档?

假设我有一个不可变类C。从用户的角度来看,我们永远无法更改任何C对象的功能行为。但是,出于性能原因,假设我们有一个toString方法可以将对象转换为字符串并返回它。我不想每次都做这个计算,所以我将结果存储在一个成员变量中,这样如果用户再次调用toString,它会很快。我是否使toString函数成为const(并且只使用const_cast来存储结果),因为只要我们将接口(interface)与实现,toString应该被视为不修改对象,或者我应该将它设为非常量,因为它会帮助编译器捕获错误? 最佳答案 拥有const对象的要点是

python - 如何将 char 指针从 python 传递给 C++ API?

我正在尝试从我的python代码中调用以下C++方法:TESS_APITessResultRenderer*TESS_CALLTessTextRendererCreate(constchar*outputbase){returnnewTessTextRenderer(outputbase);}我对如何将指针传递给方法有困难:遵循正确的方法吗?textRenderer=self.tesseract.TessTextRendererCreate(ctypes.c_char)或者我应该这样做:outputbase=ctypes.c_char*512textRenderer=self.tess

c++ - cout 是否保证有 ctype<char> 刻面?

给定:autofoo="ABCDEFGHIJKLMNOPQRSTUVWXYZ"s我可以通过以下方式将所有字符转换为小写:use_facet>(cout.getloc()).tolower(data(foo),next(data(foo),foo.size()));LiveExample但这取决于cout.getloc()包含ctypefacet.假设我使用的是未修改的cout我可以假设cout.getloc()将包含facetctype还是我需要在使用前确认这一点:has_facet>(cout.getloc()) 最佳答案 来自c

c++ - 指向 char 数组的整数指针

我正在开发一个应用程序(visualstudio上的C++语言),其中所有字符串都使用整数指针引用。例如,我正在使用的类有一个指向数据的整数指针和一个大小变量。{....unsignedshortint*pData;intiLen}我想知道使用int指针代替char指针有什么优势吗?经过深思熟虑,我怀疑原因可能是为了避免在没有空终止的情况下使用char指针可能发生的应用程序崩溃。但我不是100%确定。在调试过程中,我们如何检查指针的内容,其中内容是字符数组或字符串(在VisualStudio上)。调试时查看内容只能看到地址。因此,我在调试时遇到了困难。使用printf可以显示内容,但我

c++ - 函数指针引用参数转换为const

示例代码:classFoo;typedefvoid(*fnptr)(Foo&foo);fnptrgFn;voidmyfoo(constFoo&foo){}intmain(){gFn=&myfoo;}使用clang失败并出现以下错误:main.cpp:9:9:error:assigningto'fnptr'(aka'void(*)(Foo&)')fromincompatibletype'void(*)(constFoo&)':typemismatchat1stparameter('Foo&'vs'constFoo&')gFn=&myfoo;^~~~~~~1errorgenerated.G