C++运算符重载之加号运算符重载

简介: 加号运算符重载作用:实现两个自定义数据类型相加的运算1.成员函数实现 + 号运算符重载2.全局函数实现 + 号运算符重载3.运算符重载 可以发生函数重载



加号运算符重载

作用:实现两个自定义数据类型相加的运算

1.成员函数实现 + 号运算符重载

classPerson

{

public:

   Person() {};

   Person(inta, intb)

   {

       this->m_A=a;

       this->m_B=b;

   }

   

   //1.成员函数实现 + 号运算符重载

   Personoperator+(constPerson&p) {

       Persontemp;

       temp.m_A=this->m_A+p.m_A;

       temp.m_B=this->m_B+p.m_B;

       returntemp;

   }

public:

   intm_A;

   intm_B;

};

voidtest() {

   Personp1(10, 10);

   Personp2(20, 20);

   //1.成员函数方式

   Personp3=p2+p1;  //相当于 p2.operaor+(p1)

   cout<<"mA:"<<p3.m_A<<" mB:"<<p3.m_B<<endl;

 

}

intmain() {

   test();

   system("pause");

   return0;

}

2.全局函数实现 + 号运算符重载

classPerson

{

public:

   Person() {};

   Person(inta, intb)

   {

       this->m_A=a;

       this->m_B=b;

   }

   

public:

   intm_A;

   intm_B;

};

 

//2.全局函数实现 + 号运算符重载

Personoperator+(constPerson&p1, constPerson&p2) {

   Persontemp;

   temp.m_A=p1.m_A+p2.m_A;

   temp.m_B=p1.m_B+p2.m_B;

   returntemp;

}

voidtest() {

   Personp1(10, 10);

   Personp2(20, 20);

   

   

   //2.全局函数方式

   Personp3=p2+p1;  //相当于 operaor+(p1,p2)

   cout<<"mA:"<<p3.m_A<<" mB:"<<p3.m_B<<endl;

}

intmain() {

   test();

   system("pause");

   return0;

}

3.运算符重载 可以发生函数重载

classPerson

{

public:

   Person() {};

   Person(inta, intb)

   {

       this->m_A=a;

       this->m_B=b;

   }

   

public:

   intm_A;

   intm_B;

};

//3.运算符重载 可以发生函数重载

Personoperator+(constPerson&p2, intval)  //注意全局函数的运算重载的函数名是编译器给的。

{

   Persontemp;

   temp.m_A=p2.m_A+val;

   temp.m_B=p2.m_B+val;

   returntemp;

}

voidtest() {

   Personp1(10, 10);

   Personp2(20, 20);

   //3.运算符重载也可以发生函数重载,如下person + int

   Personp4=p3+10; //相当于 operator+(p3,10)

   cout<<"mA:"<<p4.m_A<<" mB:"<<p4.m_B<<endl;

}

intmain() {

   test();

   system("pause");

   return0;

}

总结1:对于内置的数据类型的表达式的的运算符是不可能改变的,即1+1=2不可变,不会为3.

总结2:不要滥用运算符重载,即你写的函数名是加法,可是函数的实现是减法,可以运行但是这叫滥用。

目录
相关文章
|
2月前
|
存储 编译器 C++
【c++】类和对象(下)(取地址运算符重载、深究构造函数、类型转换、static修饰成员、友元、内部类、匿名对象)
本文介绍了C++中类和对象的高级特性,包括取地址运算符重载、构造函数的初始化列表、类型转换、static修饰成员、友元、内部类及匿名对象等内容。文章详细解释了每个概念的使用方法和注意事项,帮助读者深入了解C++面向对象编程的核心机制。
121 5
|
7月前
|
编译器 C++
C++进阶之路:何为运算符重载、赋值运算符重载与前后置++重载(类与对象_中篇)
C++进阶之路:何为运算符重载、赋值运算符重载与前后置++重载(类与对象_中篇)
62 1
|
8月前
|
程序员 编译器 C++
C++中的运算符重载(Operator Overloading)
C++中的运算符重载(Operator Overloading)
67 1
|
4月前
|
C++
C++(十五) 运算符重载
C++中的运算符重载允许对已有运算符的功能进行重新定义,从而扩展语言功能、简化代码并提升效率。重载遵循特定语法,如 `friend 类名 operator 运算符(参数)`。重载时需注意不可新增或改变运算符数量、语义、优先级、结合性和返回类型。常见示例包括双目运算符 `+=` 和单目运算符 `-` 及 `++`。输入输出流运算符 `&lt;&lt;` 和 `&gt;&gt;` 也可重载。部分运算符只能作为成员函数重载。
|
7月前
|
存储 编译器 C++
【C++】:拷贝构造函数和赋值运算符重载
【C++】:拷贝构造函数和赋值运算符重载
37 1
|
7月前
|
C++ 索引
C++核心技术要点《运算符重载》
C++核心技术要点《运算符重载》
60 2
|
6月前
|
自然语言处理 程序员 C++
C++基础知识(五:运算符重载)
运算符重载是C++中的一项强大特性,它允许程序员为自定义类型(如类或结构体)重新定义标准运算符的行为,使得这些运算符能够适用于自定义类型的操作。这样做可以增强代码的可读性和表达力,使得代码更接近自然语言,同时保持了面向对象编程的封装性。
|
6月前
|
Java 程序员 C++
|
6月前
|
编译器 C++
【C++】详解运算符重载,赋值运算符重载,++运算符重载
【C++】详解运算符重载,赋值运算符重载,++运算符重载
|
7月前
|
编译器 C++
【C++】类和对象③(类的默认成员函数:赋值运算符重载)
在C++中,运算符重载允许为用户定义的类型扩展运算符功能,但不能创建新运算符如`operator@`。重载的运算符必须至少有一个类类型参数,且不能改变内置类型运算符的含义。`.*::sizeof?`不可重载。赋值运算符`=`通常作为成员函数重载,确保封装性,如`Date`类的`operator==`。赋值运算符应返回引用并检查自我赋值。当未显式重载时,编译器提供默认实现,但这可能不足以处理资源管理。拷贝构造和赋值运算符在对象复制中有不同用途,需根据类需求定制实现。正确实现它们对避免数据错误和内存问题至关重要。接下来将探讨更多操作符重载和默认成员函数。