草庐IT

typecasting-operator

全部标签

c++ - 将 Boost 参数与 operator() 一起使用

我想将BoostParameter与重载调用运算符(operator())一起使用:#include#include#includestructadd_argument_tag{structname_;structdescr_;};staticinlineboost::parameter::keyword&name=boost::parameter::keyword::get();staticinlineboost::parameter::keyword&descr=boost::parameter::keyword::get();structconfig{BOOST_PARAMETE

c++ - stringstream::operator>> 只读取,不从流中提取下一个标记

我怎样才能只读取第一个新的“token”(标准的非空白字符序列,由运算符精美地提取>>)而不将其从流中删除?我可以提取字符串,检查它是否需要放回去,并重置内部流迭代器吗?我认为这可能有效,但不知道如何实现...例子:#includeusingstd::string;#includeusingstd::stringstream;intmain(){strings("teststring\\blablie");stringstreamss(s);stringtoken;while(ss>>token){if("\\"==token)break;elsecouttellg和seekg在流提取

c++ - const 重载的 operator[] 函数及其调用

我在类array中定义了两个版本的重载operator[]函数。ptr是指向array对象第一个元素的指针。int&array::operator[](intsub){returnptr[sub];}和intarray::operator[](intsub)const{returnptr[sub];}现在,如果我定义一个const对象integer1只能调用第二个函数......但是如果我创建一个非const对象然后调用如下:cout这里调用了哪个函数? 最佳答案 在您的第二个示例中,将调用非常量版本,因为不需要转换,不需要转换的调

c++ - 如何使用类中定义的 "operator X()"?

我是C++的新手,这个声明让我感到困惑:服务.h:classServiceHandle{public:ServiceHandle(SC_HANDLEh):handle(h){}...operatorSC_HANDLE()const{returnhandle;}protected:SC_HANDLEhandle;};我已经通过此处列出的构造函数之外的其他方式创建了一个ServiceHandle对象。我想让实际的SC_HANDLE传递给ChangeServiceConfig,我该如何得到它?我假设它与运算符(operator)有关,但我不知道如何使用它。 最佳答

c++ - operator== 是成员函数还是友元函数,?

做operator==有好处还是必须做,operator,operator>,operator,operator>>,!=,>=,...作为friend而不是类的方法?我还没有找到一篇很好的文字来解释为什么只交friend......我有一个很好的用例如果C1x;C2y;C3z;我有C3&operator+(C1&,C2&)作为C1和C2的friend,即当类(class)不同时,但问题是为什么是同一个类(class)。 最佳答案 独立函数的论据是这些运算符根据操作数类型应该是对称的。当您的类具有允许将左侧操作数隐式转换为您的类类型

c++ - 如何从 operator new 或 malloc 为 mremap 获取页对齐内存

有没有办法分配一block内存,使其起始地址与给定的页面大小对齐?请注意,我不想在分配block后计算对齐地址。原因是在某些时候我将不得不在block上调用mremap():mremap要求旧地址参数是页面对齐的。 最佳答案 mremap只能安全地用于由mmap分配的内存区域,这些内存区域本质上是页面对齐的。在其他任何事情上使用它都是危险的(正式的,未定义的行为)并且可能看起来有效但可能会以您不会立即看到的方式严重破坏事物。 关于c++-如何从operatornew或malloc为mre

c++ - Cython 不能使用 operator()

当我尝试使用以下Cython代码时,我收到了我在最后发布的有关未定义operator()的错误。看来,当我尝试使用运算符时,Cython不会将其解释为成员函数(注意C++源代码中没有成员访问权限)。如果我尝试调用prng.operator()(),那么Cython将无法转换。在Cython中使用运算符重载是否需要一些特殊的东西?importnumpyasnpcimportnumpyasnpcdefexternfrom"ratchet.hpp"namespace"ratchet::detail":cdefcppclassRatchet:Ratchet()unsignedlongget64

c++ - 在没有类声明的情况下使用 Qt 的 Q_DECLARE_FLAGS 和 Q_DECLARE_OPERATORS_FOR_FLAGS

我有以下枚举声明,我想利用Qt中的QFlags支持来实现额外的类型安全:namespacessp{enumVisualAttribute{AttrBrushColor=0x001,AttrBrushTexture=0x002,AttrPenCapStyle=0x004,AttrPenColor=0x008,AttrPenJoinStyle=0x010,AttrPenPattern=0x020,AttrPenScalable=0x040,AttrPenWidth=0x080,AttrSymbolColor=0x100,AttrTextColor=0x200,AttrTextFontFam

c++ - libstdc++ 和 libc++ : operator>> on bitset 行为差异

考虑以下代码:#include#include#includeintmain(intargc,char*argv[]){std::stringstreamstream;std::bitsetbitset(1);std::cout>bitset;std::cout在g++下用libstdc++编译,结果为:>g++bitset_empty.cpp-obitset_empty>./bitset_emptybefore=1after=1在clang++下用libc++编译,结果为:>clang++-stdlib=libc++bitset_empty.cpp-obitset_empty>./b

c++ - 为什么这个用于检测类型 T 是否具有 void operator(EDT const&) 的 C++ 特性会失败?

我正在尝试使用SFINAE来检测作为模板参数T传递的类型是否具有T::operator()(Pconst&),其中P也是模板参数。我在MemberDetectorIdiom的这个例子之后为我的解决方案建模不幸的是,我无法让它为operator()工作,即使我可以让它为普通方法工作。下面是一些演示我面临的问题的示例代码:#include#include#include#includeusingnamespacestd;structhas{voidoperator()(intconst&);};structhasNot1{voidoperator()(int);};structhasNot