基于运算符重载的那些事

由于对运算符重载不是多么理解诶,于是就百度了一下,结果发现一个解释很有趣的百度知道,分享看看。


代码如下:

回答:
+-*/这样的运算符重定义,比如你自定义了一个类a,然后你可以自己重载它的这些运算符,比如+返回什么,-返回什么等等。
public class a{
    public string t{get;set;}
    public static a operator +(a a1, a a2)
   {
         a b=new a();
         b.t=a1.t+a2.t;
         return b;
   }
}

大概这个意思。

追问:

大侠,说真的没看明白,能不能更通俗点

回答:

像这样,如你现在创建了一个自定义类叫 苹果,正常情况下,如果你定义二个变量 苹果A和苹果B实例化它们,然后你想知道 苹果A-苹果B 能得到什么,默认这二个变量是不能直接运算的,如果你要实现 苹果 类的 "-" 运算,那么你必须重载它的 运算符"-",然后自己在里面实现你的操作。 比如 你可以实现说两个不同的菜果相减返回一个烂苹果或返回null

追问:

大侠,能否就你说的这个苹果类,对其的“-”运算符进行重载,结果得出两个苹果的质量差,烦请您在写出这个Demo,最好写详细点,加个注释什么的,谢谢了,就当带个徒弟咯,
    (*^__^*) 嘻嘻……

回答:

public class Apple{
        public decimal Weight{get;set;}
        public static decimal operator +(Apple a1, Apple a2)
       {
             return a1.Weight-a2.Weight;
       }
    }

Apple a=new Apple{Weight=200};
    Apple b=new Apple{Weight=300};

Console.Write(b-a);

试试这个可以不。

追问:

谢谢,为了这个问答更完美,我修改下回答者得一些疏漏:
    上面代码第三行应该是“-”号,更正下
    public static decimal operator - (Apple a1, Apple a2)

下面这三句应该放在Main()函数中,这样就完美了
    ---------------------------------
    Apple a=new Apple{Weight=200};
    Apple b=new Apple{Weight=300};
    Console.Write(b-a);
    --------------------------------

二楼:

我觉得楼上两位说的很好,很明确了,我换一种方式解释一下。
要回答楼主的问题,那么就要先明确2个概念,运算符,重载
 运算符
运算符指的就是+、-、*、/ 等此类用于算术运算的符号,这些符号在写在程序代码里面,我们的编译器可以识别出来,是因为我们已经为编译器定义好了规矩(语法),所以你会发现有些有些东西可以用+连接,而有些却不行,那是因为系统没有自定这样的规矩。
 重载
重载一个语言特性,意思就是说,编程语言允许存在多个个名字一样,但是参数不一样的方法(函数)。随手写写两个方法看看:
int Add(int a,int b);
double Add(double a,double b);
我们定义了两个Add方法,但是他们的参数不一样,这是合法,这个时候我们就可以说Add方法有2个“重载”。

现在,假如你把Add方法看作是“+”号,那么这个运算符重载的意思不就出来了吗,“+”号可以加两个整形(int)数,也可以加两个双精度(double)数,就是因为有运算符重载这种特性!

通过运算符重载,你能让“+”让所有的东东都能相加在一起!

三楼:

示例已经有人给了,我通俗地讲您通俗地听吧。
咱们都知道1+1=2,是因为数学家是这么规定的,我们也是这么学的。而且只要您在地球上就不会有人来推翻这个结论,除非他很无知无聊。
像这些普遍存在的规律已经被广大人民群众所接纳了,作为一门程序语言的设计者,他们肯定也会按照常识来设计语言。所以在任何一门语言中1+1=2都是成立的。程序能认识1跟2是两个数,还能认识+,-,x,÷四则运算。凡是数值的四则运算都会符合人们的正常思维习惯得到正确的结果。电脑之所以能正确地处理数值的四则运算归根到底不是因为电脑具有人工智能。而是程序语言的设计者已经为程序设计好了解释规则。电脑只是按照这种规则处理数据。

设计一门语言的时候只能把那些最普遍的规律实现出来,至于那些特殊的规律需要让这些规律的制定者去实现。

比如说 “马+马=马”;“驴+马=骡子” 这或许还在常理之中。可能有怪胎会定义“人+妖=人妖”……
计算机能认识数值已经很不错了。您也不会期待它能认识“马”是什么东西吧。这时候您定义了一个类,类的名字叫做“马”。并在里面写了一些“马”的属性。渐渐地马的形象就饱满了。计算机终于能认识“马”了。可是“马”实例化出来的对象它不是数值,计算机不知道“马+马”等于什么,这时候您就需要为“马”制定四则运算。于是乎电脑又知道了“公马”+“母马”=“小马驹”。这是同类对象的运算符重载。
然后您又定义了“驴”这个类。电脑也认识“驴”了。
最后您还需要定义“驴+马=骡子”,这就是不同类对象的运算符重载了。

其实string对象的+运算就是最简单最常用的运算符重载了。甚至int+double在C#中也是需要定义的。

(0)

相关推荐

  • C++运算符重载的方法详细解析

    运算符重载实质上是函数的重载 重载运算符的函数一般格式如下: 函数类型    operator  运算符名称    (形参表列) {对运算符的重载处理} 例如,想将"+"用于Complex(复数)的加法运算,函数的原型可以是这样的: 复制代码 代码如下: Complex operator + (Complex & c1,Complex &c2); 其中,operator是关键字,时候专门用于定义重载运算符的函数的,运算符名称就是C++提供给用户的预定运算符. 注意:函数

  • C++运算符重载 成员函数与友元函数详解

    复制代码 代码如下: #include<iostream>using namespace std;class A{    int x,y;    public:    A(int xx,int yy):x(xx),y(yy){}    A(){x=0;y=0;}    A operator+(const A&b) //不加const限定,也可以    { return A(x+b.x,y+b.y); }    A operator-()    { return A(-x,-y); } 

  • 基于运算符重载的那些事

    由于对运算符重载不是多么理解诶,于是就百度了一下,结果发现一个解释很有趣的百度知道,分享看看. 复制代码 代码如下: 回答:+-*/这样的运算符重定义,比如你自定义了一个类a,然后你可以自己重载它的这些运算符,比如+返回什么,-返回什么等等.public class a{    public string t{get;set;}    public static a operator +(a a1, a a2)   {         a b=new a();         b.t=a1.t+

  • Python运算符重载详解及实例代码

    Python运算符重载 Python语言提供了运算符重载功能,增强了语言的灵活性,这一点与C++有点类似又有些不同.鉴于它的特殊性,今天就来讨论一下Python运算符重载. Python语言本身提供了很多魔法方法,它的运算符重载就是通过重写这些Python内置魔法方法实现的.这些魔法方法都是以双下划线开头和结尾的,类似于__X__的形式,python通过这种特殊的命名方式来拦截操作符,以实现重载.当Python的内置操作运用于类对象时,Python会去搜索并调用对象中指定的方法完成操作. 类可以

  • Python运算符重载用法实例分析

    本文实例讲述了Python运算符重载用法.分享给大家供大家参考.具体如下: 在Python语言中提供了类似于C++的运算符重在功能: 一下为Python运算符重在调用的方法如下: Method         Overloads         Call for __init__        构造函数         X=Class() __del__         析构函数         对象销毁 __add__         +                 X+Y,X+=Y __

  • Python运算符重载用法实例

    本文实例讲述了Python运算符重载用法.分享给大家供大家参考.具体分析如下: python中,我们在定义类的时候,可以通过实现一些函数来实现重载运算符. 例子如下: # -*- coding:utf-8 -*- ''''' Created on 2013-3-21 @author: naughty ''' class Test(object): def __init__(self, value): self.value = value def __add__(self, x): return

  • c++ *运算符重载

    运算符重载,对象和指向对象的指针 直接上code 复制代码 代码如下: #include <iostream> using namespace std;  class test {     public:         int a;         test() : a(0){}         test &operator*(){             cout << "operator*" << endl;             c

  • c++运算符重载基础知识详解

    实际上,很多C++运算符已经被重载.eg:将*运算符用于地址,将得到存储在这个地址中的值,将他用于2个数字时,得到的将是他们的乘积.C++根据操作数的数目和类型来决定采用哪种操作. C++允许将运算符重载扩展到用户定义的类型.例如,允许使用+将两个对象相加.编译器将根据操作数的数目和类型决定使用加法定义.运算符重载可以使代码看起来更自然.例如,将2个数组相加是一种常见的运算.通常,需要使用下面这样的for循环来实现: 复制代码 代码如下: for (int i = 0; i < 20; i++)

  • 深入解析C++编程中的运算符重载

    C++中预定义的运算符的操作对象只能是基本数据类型,实际上,对于很多用户自定义类型,也需要有类似的运算操作.例如: class complex { public: complex(double r=0.0,double I=0.0){real=r;imag=I;} void display(); private: double real; double imag; }; complex a(10,20),b(5,8); "a+b"运算如何实现?这时候我们需要自己编写程序来说明"

  • jQuery基于函数重载实现自定义Alert函数样式的方法

    本文实例讲述了jQuery基于函数重载实现自定义Alert函数样式的方法.分享给大家供大家参考,具体如下: (function(){ window.alert = function(text) { text=text.toString().replace(/\\/g,'\\').replace(/\n/g,'<br />').replace(/\r/g,'<br />'); //解析alert内容中的换行符 var alertdiv='<div id="alertd

  • C++运算符重载规则详解

    C++允许重载的运算符和不允许重载的运算符 C++中绝大部分的运算符允许重载,具体规定见表 不能重载的运算符只有5个: .  (成员访问运算符) .*  (成员指针访问运算符) ::  (域运算符) sizeof  (长度运算符) ?:  (条件运算符) 前两个运算符不能重载是为了保证访问成员的功能不能被改变,域运算符和sizeof 运算符的运算对象是类型而不是变量或一般表达式,不具备重载的特征. C++运算符重载的规则 C++对运算符重载定义了如下几条规则. 1) C++不允许用户自己定义新的

随机推荐