草庐IT

char_set

全部标签

c++ - 为什么 is_base_of 都只是普通的 char 类型时会失败

你明白为什么static_assert失败了吗:templatevoidfoo(constT&c){static_assert(std::is_base_of::value,"Tmustbechar");//Fails!}intmain(){charc='a';foo(c);return0;}我交换了T和“char”,仍然失败。 最佳答案 您可能需要考虑添加额外的检查:templatevoidfoo(constT&c){static_assert(std::is_base_of::value||std::is_same::value

c++ - 不允许从 'const unsigned char *const *' 到 'const char *const *' 的 static_cast

我遇到的是我的编译器拒绝将我的unsignedchar指针转换为signedchar指针。我有一段时间感到困惑,因为我一直在使用static_cast来转换符号性最长的时间。然后我做了一点挖掘(好吧,不是很深。我做了一点挖掘!)尽管现在我明白了static_cast防止指针类型转换恰恰是为什么它是更安全和更好的转换方式(比可能调用实现定义行为或未定义行为的传统替代方法)的原因,我仍然不确定我应该为我的情况实际做什么。我这里调用的是签名为的OpenGLAPI函数voidglShaderSource(GLuintshader,GLsizeicount,constGLchar**string

c++ - 如何创建一个 std::set 结构?

我需要创建一个STL::set结构。因此,我写了以下内容:stl::setmySet;//Point-nameofthestructure.然后我尝试将结构实例添加到mySet,如下所示:PointmyPoint;mySet.insert(myPoint);但是,我遇到了几个编译错误(错误C2784、错误C2676):1>C:\ProgramFiles(x86)\MicrosoftVisualStudio10.0\VC\include\xfunctional(125):errorC2784:boolstd::operator&,conststd::vector&):failedtobr

c++ - Boost C++ 序列化一个 char *

我有一个类,我正在尝试序列化一个shared_ptr,但序列化对象的常规方法不起作用:classObject{public:Object();~Object();shared_ptrobjectone;friendclassboost::serialization::access;templatevoidserialize(Archive&ar,constunsignedintversion){ar&objectone;}};我什至尝试过这种方式,但它仍然不起作用:voidserialize(Archive&ar,constunsignedintversion){for(inti=0;

c++ - 为什么boost mpl set允许非唯一类型

我相信我对boost::mpl::set的理解存在根本性的缺陷。我以为它只允许唯一类型。但是下面的代码可以编译:#include#include#include#include#include#include#include#includeusingnamespaceboost::mpl;typedefsetmy_set;//longrepeatedinset?typedefvectormy_vec;//seemsreasonabletypedefaccumulate,plus>>::typeset_size;typedefaccumulate,plus>>::typevec_size

c++ - 如何使用 const getter 对 std::set 进行排序

我有一个std::set容器,其元素是以下类的对象:classLaneConnector{public:constLane*getLaneFrom()const{returnFrom;}constLane*getLaneTo()const{returnTo;}private:Lane*From;Lane*To;}我的比较函数如下:structMyLaneConectorSorter{booloperator()(LaneConnector*c,LaneConnector*d){Lane*a=const_cast(c->getLaneFrom());Lane*b=const_cast(d

c++ - 将 unsigned char[10] 转换为 QBytearray;

我已经看到很多关于此的问题,但到目前为止没有一个对我有用。我已经尝试了2个最常见的答案,但我得到了同样的错误。只是一个unsignedcharbuf[10];这个,QByteArraydatabuf;databuf=QByteArray::fromRawData(buf,10);或者这个,QByteArraydatabuf;databuf=QByteArray(buf,10);我遇到了同样的错误,错误:从“unsignedchar*”到“constchar*”的无效转换[-fpermissive]有什么建议吗?谢谢 最佳答案 这只是

c++ - static const char [] 在类线程安全吗?

staticconst在类线程中是安全的吗?在下面的代码中,我有trailingBytesForUTF8,这是一个staticconst字符数组。可能有许多线程拥有它们自己的CConvertUTF类的对象实例。当多个线程同时访问同一个trailingBytesForUTF8数组时,是否会出现任何可变状态问题,或任何其他线程问题?另请注意,线程永远不会共享CConvertUTF类的相同对象实例。//.hclassCConvertUTFfinal{private:staticconstchartrailingBytesForUTF8[256];public:boolIsLegalUTF8S

c++ - 编写可以使用 std::vector 或 std::set 的模板

我编写了一个异步作业队列类,多年来一直运行良好。它使用std::vector作为底层集合来保存作业,然后按照您的预期稍后处理它们。当我添加作业时,它会在此vector上执行push_back。最近我决定要模板化它使用的底层集合类型以及我编写它的方式,这应该非常简单。现在声明如下:template>classasync_jobqueue{public:只有一个障碍,对于vector类型的容器,我想将东西推到集合的末尾并调用push_back,对于settish类型的容器,我想调用insert。我怎样才能做出关于调用哪个的编译决定?或者有没有我可以使用的方便的适配器?

c++ - char** 和 char*[] 有什么区别

最近需要声明一个字符串数组,于是写下如下语句:constchar**directories={"cricket_batting","cricket_bowling","croquet","tennis_forehand","tennis_serve","volleyball_smash"};但是,g++向我展示了错误:error:scalarobject‘directories’requiresoneelementininitializer所以我把语句改成这样:constchar*directories[]={"cricket_batting","cricket_bowling","c