草庐IT

assignment-operator

全部标签

c++ - 不能重载 operator<< 作为成员函数

我正在尝试重载operator作为成员函数。如果简单地这样做,它就可以工作:friendostream&operator在我的头文件和MyClass.cc文件中:ostream&operator但是,如果我尝试使用friend关闭并使其成为成员函数,然后它会提示operator只能接受一个论点。为什么?ostream&MyClass::operator我在thisquestion阅读它不能是成员函数,但不知道为什么? 最佳答案 作为成员函数重载时,a被解释为a.operator,所以它只需要一个显式参数(this作为隐藏参数)。由于

c++ - 不能重载 operator<< 作为成员函数

我正在尝试重载operator作为成员函数。如果简单地这样做,它就可以工作:friendostream&operator在我的头文件和MyClass.cc文件中:ostream&operator但是,如果我尝试使用friend关闭并使其成为成员函数,然后它会提示operator只能接受一个论点。为什么?ostream&MyClass::operator我在thisquestion阅读它不能是成员函数,但不知道为什么? 最佳答案 作为成员函数重载时,a被解释为a.operator,所以它只需要一个显式参数(this作为隐藏参数)。由于

C++ 数组分配错误 : invalid array assignment

我不是C++程序员,所以我需要一些有关数组的帮助。我需要将一个字符数组分配给某个结构,例如structmyStructure{charmessage[4096];};stringmyStr="hello";//Ineedtocreate{'h','e','l','l','o'}charhello[4096];hello[4096]=0;memcpy(hello,myStr.c_str(),myStr.size());myStructuremStr;mStr.message=hello;我得到error:invalidarrayassignment如果mStr.message和hello

C++ 数组分配错误 : invalid array assignment

我不是C++程序员,所以我需要一些有关数组的帮助。我需要将一个字符数组分配给某个结构,例如structmyStructure{charmessage[4096];};stringmyStr="hello";//Ineedtocreate{'h','e','l','l','o'}charhello[4096];hello[4096]=0;memcpy(hello,myStr.c_str(),myStr.size());myStructuremStr;mStr.message=hello;我得到error:invalidarrayassignment如果mStr.message和hello

c++ - 为什么不为 std::vector 重载 operator+=()?

我已经开始学习C++,所以由于缺乏知识/经验,我不知道为什么像我将要描述的那样对新手来说如此简单的东西现在还没有出现在STL中。要将vector添加到另一个vector,您必须输入:v1.insert(v1.end(),v2.begin(),v2.end());我想知道在现实世界中人们是否只是重载+=运算符以使其不那么冗长,例如templatevoidoperator+=(std::vector&v1,conststd::vector&v2){v1.insert(v1.end(),v2.begin(),v2.end());}那么你就可以了v1+=v2;我还为push_back设置了这个

c++ - 为什么不为 std::vector 重载 operator+=()?

我已经开始学习C++,所以由于缺乏知识/经验,我不知道为什么像我将要描述的那样对新手来说如此简单的东西现在还没有出现在STL中。要将vector添加到另一个vector,您必须输入:v1.insert(v1.end(),v2.begin(),v2.end());我想知道在现实世界中人们是否只是重载+=运算符以使其不那么冗长,例如templatevoidoperator+=(std::vector&v1,conststd::vector&v2){v1.insert(v1.end(),v2.begin(),v2.end());}那么你就可以了v1+=v2;我还为push_back设置了这个

c++ - 为什么 auto_ptr<T> 没有定义 operator!() ?

标题几乎概括了我的问题。为什么不能做以下检查空指针?auto_ptrp(some_expression);//...if(!p)//error必须改为这样做:if(!p.get())//OK为什么不auto_ptr只需拥有operator!()定义? 最佳答案 它的设计似乎有错误。这将在C++0x中修复。unique_ptr(替换auto_ptr)包含explicitoperatorbool()const;引用新C++标准:Theclasstemplateauto_ptrisdeprecated.[Note:Theclasstemp

c++ - 为什么 auto_ptr<T> 没有定义 operator!() ?

标题几乎概括了我的问题。为什么不能做以下检查空指针?auto_ptrp(some_expression);//...if(!p)//error必须改为这样做:if(!p.get())//OK为什么不auto_ptr只需拥有operator!()定义? 最佳答案 它的设计似乎有错误。这将在C++0x中修复。unique_ptr(替换auto_ptr)包含explicitoperatorbool()const;引用新C++标准:Theclasstemplateauto_ptrisdeprecated.[Note:Theclasstemp

c++ - void operator()() 的功能

我对voidoperator()()的功能感到困惑。你能告诉我,例如:classbackground_task{public:voidoperator()()const{do_something();do_something_else();}};background_taskf;std::threadmy_thread(f);这里,为什么我们需要operator()()?第一个和第二个()是什么意思?其实,普通算子的操作我都知道,但是这个算子比较困惑。 最佳答案 你可以重载()操作符来调用你的对象,就好像它是一个函数:classA{

c++ - void operator()() 的功能

我对voidoperator()()的功能感到困惑。你能告诉我,例如:classbackground_task{public:voidoperator()()const{do_something();do_something_else();}};background_taskf;std::threadmy_thread(f);这里,为什么我们需要operator()()?第一个和第二个()是什么意思?其实,普通算子的操作我都知道,但是这个算子比较困惑。 最佳答案 你可以重载()操作符来调用你的对象,就好像它是一个函数:classA{