C++ assignment operator during declaration(声明期间的C++赋值运算符)
本文介绍了声明期间的C++赋值运算符的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
这是我的类Hero,具有两个重载赋值运算符-Hero to Hero和String to Hero。
#include <iostream>
class Hero {
private:
int x;
std::string name;
public:
Hero():x(42), name("JohnDoe") {};
Hero(int a, std::string b):x(a), name(b) {};
void print(){
std::cout<<name<<" : "<<x<<"
";
}
const Hero &operator =(const Hero &other){
std::cout<<"Overloaded Assignment class to class!
";
x = other.x;
name = other.name;
return *this;
}
const Hero &operator =(const std::string N){
std::cout<<"Overloaded Assignment from string!
";
x = 777;
name = N;
return *this;
}
};
int main(){
Hero foo(42, "Hercules");
Hero zak = foo; // Regular assignmnet, not the overloaded
// Hero bar = "HelloWorld"; <<<< Illegal
Hero zoo(HelloWorld",42); << Ok, but here we use constructor, not an assignment operator
Hero bar;
bar = "Ayax"; // "Overloaded Assignment from string!
";
zak = bar; //"Overloaded Assignment class to class!
";
zak.print();
bar.print();
}
和产生的结果:
Overloaded Assignment from string!
Overloaded Assignment class to class!
Ayax : 777
Ayax : 777
为什么不能在声明中使用重载运算符进行变量初始化?
行Hero zak = foo;
编译器使用非重载运算符,字符串Hero bar = "HelloWorld"
是非法的。
推荐答案
在定义时初始化对象时,即使使用=
语法,它也没有使用赋值。
当您这样做时:
Hero zak = foo;
相当于:
Hero zak(foo);
这是复制初始化,因此调用复制构造函数。
的问题
Hero bar = "HelloWorld";
它等同于:
Hero bar = Hero("HelloWorld");
这又相当于:
Hero bar(Hero("HelloWorld"));
由于您没有Hero("HelloWorld")
的构造函数,因此它无效。
这篇关于声明期间的C++赋值运算符的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:声明期间的C++赋值运算符
基础教程推荐
猜你喜欢
- 您如何将 CreateThread 用于属于类成员的函数? 2021-01-01
- C++,'if' 表达式中的变量声明 2021-01-01
- 调用std::Package_TASK::Get_Future()时可能出现争用情况 2022-12-17
- C++ 标准:取消引用 NULL 指针以获取引用? 2021-01-01
- 如何定义双括号/双迭代器运算符,类似于向量的向量? 2022-01-01
- 运算符重载的基本规则和习语是什么? 2022-10-31
- 设计字符串本地化的最佳方法 2022-01-01
- 如何在 C++ 中处理或避免堆栈溢出 2022-01-01
- 什么是T&&(双与号)在 C++11 中是什么意思? 2022-11-04
- C++ 程序在执行 std::string 分配时总是崩溃 2022-01-01