• C++中预定义的运算符的操作对象只能是基本的数据类型


    C++中预定义的运算符的操作对象只能是基本的数据类型。但实际上,对于许多用户自己定义的类型(例如类),也需要有类似的操作。这就必须在C++中重新定义这些运算符,赋予已有运算符新的功能,使它能够用于特定类型执行特定的操作。运算符重载的实质是函数的重载,它提供了C++的可扩展性,也是C++最吸引人的地方。
    举个例子来说,”+”操作符可以对两个int形数据进行操作,但是无法对两个类进行相加,重载操作符就是重新定义”+”,扩展它的功能,使其满足对其它对象的功能。
     
    运算符重载的一般格式:
     
     函数类型  operator 运算符名称(形参列表){
     
    。。。
     
    函数体部分
     
    。。。
     
    }
     
     
    运算符重载的规则:
     
    (1) C++不允许用户定义新的运算符,比如“%¥“,它只能对已有的C++运算符进行重载。
     
    (2) C++不允许重载的运算符目前有5个,分别为
     
    “.“成员访问操作符;
     
    “.*”成员指针访问运算符;
     
    “::”域运算符;
     
    “sizeof ”:长度运算符;
     
    “?:“三目操作符”
     
    (3)不能改变运算符的优先级和结合性;
     
    (4) 重载运算符的函数不能有默认的参数。否则,就改变了运算符参数的个数不变的规定。
     
    (5) 重载运算符函数的参数不能全是标准数据类型,以防止用户篡改用于标准类型数据的运算性质,避免混乱。例如
     
    int operator + (int a,int b)(return a-b);
     
    (6)运算符重载函数可以是
     
    类的成员函数
     
    类的友元函数
     
    普通函数
     
    下面将对各种重载函数进行说明:
     
     /////////////////////////////////////////////////////////////////////////////////////////////////////
     
    A.类的成员函数的重载
     
    当运算符重载为类的成员函数时,函数的参数比原来的操作数要少一个(后置单目运算符除外),这是因为成员函数用this指针隐式的访问了类的一个对象,它充当了运算符函数最左边的操作数。因此:
     1.双目运算符重载为类的成员函数时,函数只是显式的说明一个参数,该形参是运算符的右操作数。
     2.前置单目运算符重载为类的成员函数时,不需要显式的说明参数,即函数没有形参
     3.后置单目运算符重载为类的成员函数时,函数要带一个整形的形参
     
    目就是操作数,单目就是一个操作数的操作符,比如正负号,++ --,作用域操作符;双目就是两个操作数的。
    前置自增/自减是先将自身变量改变在参与表达式运算,而且前置运算返回的是左值也就是变量,比如++i = 6,
    而后置的是先用本来的数值参与表达式运算,再改变其自身的值,并且后置运算返回的是右值也就是常量i++ = 6就是错的,这一点很重要,比如
    i = 6;
    cout << i++ << ++i << endl;
     
    还有一个需要注意的地方就是红色字体标出const不能省去,因为不能对一个引用直接赋为一个左值。


    #include "stdafx.h"
    #include <iostream>
    using namespace std;

    class complex
    {
    public:
        complex(){}
        complex(const int &real,const int &imgc)
        {
           i=real;
           j=imgc;
        }

        complex operator*(complex &ptr)
        {
           complex temp;
           temp.i=ptr.i+i;
           temp.j=ptr.j+j;
           cout<<temp.i<<temp.j<<endl;
      
           return temp;
        }
    private:
        int i;
        int j;
    };

     
    int _tmain(int argc, _TCHAR* argv[])
    {
        complex obj(10,20);
        complex cbj(12,-9);
        obj.operator *(cbj);

        return 0;


     B.类的友元函数的重载
     
     当运算符重载为类的友元函数时,由于没有隐含的this指针,因此操作数的个数没有发生变化,所有的操作数必须通过函数的形参进行传递,函数的参数与操作数自左向右一一对应。

    class complex
    {
    public:
        complex(){}
        complex(const int &real,const int &imgc)
        {
           i=real;
           j=imgc;
        }

        friend complex operator+(complex &qtr,complex &ptr)
        {
           complex temp;
           temp.i=ptr.i+qtr.i;
           temp.j=ptr.j+qtr.j;
           cout<<temp.i<<temp.j<<endl;
           return temp;
        }

    private:
        int i;
        int j;
    };


    int _tmain(int argc, _TCHAR* argv[])
    {
        complex obj(10,20);
        complex cbj(12,-9);

        obj+cbj;
        return 0;

    C.普通非成员函数的重载
     
    #include <iostream>
    using namespace std;
    class complex
    {
    public:
        complex(){}
        complex(const int &real,const int &imgc)
        {
           i=real;
           j=imgc;
        }
    public:
        int i;
        int j;
    };

    complex operator+(complex &qtr,complex &ptr)
    {
       complex temp;
       temp.i=ptr.i+qtr.i;
       temp.j=ptr.j+qtr.j;
       cout<<temp.i<<temp.j<<endl;
       return temp;
    }

    int _tmain(int argc, _TCHAR* argv[])
    {
    complex obj(10,20);
    complex cbj(12,-9);
    obj+cbj;
    return 0;



    由于我们把i和j设为了私有成员,所以该函数的编译时错误的。所以程序中我们重新设置为了公有数据成员。





  • 相关阅读:
    虚拟化技术
    软件产业的知识经济 (蔡学墉)
    关于内存对齐
    Reverse Engineering
    [转]今天的操作系统 
    BasicBIOS & CMOS
    [bbk5355]第18集 Chapter 08 Handling Exceptions(01)
    [bbk1452]第1集 在Apache中使用SSL
    Linux>User Manager
    如何更新linux系统时间
  • 原文地址:https://www.cnblogs.com/fireae/p/3685542.html
Copyright © 2020-2023  润新知