草庐IT

const-char

全部标签

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

即使在模板中我可以有任何类型,函数to_string对基本字符串不起作用:例如:std::stringstr("mystring");my_class(str);用这个仿函数定义:templatevoidoperator()(valuetypevalue){...private_string_field=std::to_string(value);不起作用。这是错误:error:nomatchingfunctionforcallto‘to_string(std::basic_string&)’避免它的最佳方法是什么。事先,我要求避免仅仅因为一些常见的关键字就链接到不相关的问题。

c++ - std::vector<int, std::allocator<char>> 有效吗?

标准没有说明std::vector的分配器但只需要分配器满足Allocator概念。没有关于分配器的value_type,没有reference_type,什么都没有。我以为std::vector内部重新绑定(bind)A到T的分配器,所以我给了一个vectorstd::allocator它按预期工作。但是,如果std::allocator,GCC会生成错误给出,如下:/usr/lib/gcc/x86_64-pc-linux-gnu/4.9.2/include/g++-v4/ext/alloc_traits.h:Ininstantiationof‘struct__gnu_cxx::__

c++ - 在没有 C++ 11 的情况下使用 char16_t、char32_t 等?

我想要固定宽度的类型,包括字符类型。提供整数类型,但不提供字符类型,除非在使用C++11时,这是我做不到的。是否有一种干净的方法来定义这些类型(char16_t、char32_t等)而不与C++11定义的类型发生冲突,以防源代码与C++11混合?谢谢你:) 最佳答案 我认为,检查是否支持这种类型是平台相关的事情。例如,GCC定义:__CHAR16_TYPE__和__CHAR32_TYPE__如果提供了这些类型(需要ISOC11或C++11支持)。但是,您不能直接检查它们的存在,因为它们是基本类型,而不是宏:InC++,char16_

c++ - 在编译时或运行时将 const char * 映射到 duck-typed T

我有很多类A、B、C、D等,它们都是鸭子类型的,因此具有相同的方法和接口(interface),但不是从同一个类继承的。例如classA{public:voidfoo();voidbar();}classB{public:voidfoo();voidbar();}classC{public:voidfoo();voidbar();}我想在运行时将constchar*映射到这些类之一的相应实例,例如“A”->Aa“B”->Bb这里a是类A的一些实例。或在编译时将'constchar*`映射到相应的类型,例如“A”->A我需要在其他一些函数调用中使用该对象的实例(即调用foo()或bar(

python - 如何使用 boost.python 将预填充的 "unsigned char*"缓冲区传递给 C++ 方法?

我有一个C++类,它有一个成员函数,它接受一个unsignedchar*缓冲区和一个unsignedint长度作为参数并对它们进行操作。我已经用Boost::Python包装了这个类,并希望将一个预填充的缓冲区从Python脚本传递给这个类。Python端缓冲区是使用struct.pack创建的。我不知道如何使参数类型匹配并不断收到Boost.Python.ArgumentError。include/Example.h#ifndefEXAMPLECLASS_H_#defineEXAMPLECLASS_H_#includeclassExampleClass{public:ExampleC

c++ - C++ 包装 C 代码的重复 const 错误

我从C++应用程序中包含并使用了一些C代码,这里是重要的部分:C代码ifdef__cplusplusextern"C"{endif...typedefvoid*problem_type;...intproblematic_fn_proto(constproblem_typeconstarg);ifdef__cplusplus}endif不幸的是,由于duplicate'const'错误,这将无法编译。导致问题的是typedef。如果我只是将函数的原型(prototype)更改为:intproblematic_fn_proto(constvoid*constarg);没有更多的问题。不幸

c++ - 同一函数的 const 和非 const 版本 - 反模式?

最近我检查了大量遗留C++代码,发现了一些我以前从未在生产C++代码中见过的东西:classFoo{public:voidBar(){std::cout(this)->Bar();}};这是一个巨大的反模式吗?我的意思是,该函数要么是const要么是非常量,提供两个版本有什么意义?这是某种“const-correctnesscheat”吗,它允许在这样的情况下调用const函数:voidInvokeBar(constFoo&foo){//ohboy!Ireallyneedtoinvokeanon-constfunctiononaconstreference!foo.Bar();}

c++ - 如何根据构造函数参数填充 const 成员数组?

假设我有这个类(class):templateclassA{public:A(constchar*s)...private:constcharbuf[N];};模板在那里,这样我就可以在没有动态内存分配(要求)的情况下配置数组大小。buf成员是const,因为它旨在在对象初始化后在对象的整个生命周期内保持不变。澄清一下,我也无权访问STL。我有什么选择来定义这个构造函数,以便我可以将s的内容复制到buf中?一个选项是const_cast,但我正在寻找不需要这个的替代方案。 最佳答案 @RichardHodges提供的解决方案要求使用

c++ - 为什么我不允许将返回 const char* 的函数的结果分配给 char*,但可以将字符串文字(常量)分配给 char*?

这个问题在这里已经有了答案:WhatisthetypeofstringliteralsinCandC++?(4个答案)关闭6年前。返回constchar*的函数不能分配给char*constchar*func(){return"Thisisaconststringtwo";}但是char*直接在main中赋值了一个常量字符串:intmain(){char*d="thisisaconststringone";//worksfinechar*e=func();//errorcannotconvertfrom'constchar*'to'char*'return1;}为什么矛盾?

c++ - 为什么这会在 const 方法中返回一个 const X* const 指针?

我在理解以下错误时遇到了麻烦:Error1errorC2440:'=':cannotconvertfrom'constX*const'to'X*const'我正在尝试使用指向const指针的指针在树遍历期间跟踪节点:boolIsValid()const{X*const*previousNode=newX*;returnthis->IsValid(previousNode);}boolIsValid(X*const*previousNode)const{...if(!*previousNode)*previousNode=this;//Error...returntrue;}为什么thi