zoukankan      html  css  js  c++  java
  • 面向对象

    一.函数式编程和面向对象的对比

      面向过程:根据业务逻辑从上到下写垒代码

      函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可

      面向对象:对函数进行分类和封装,让开发“更快更好更强...”

      面向对象编程是一种编程方式,此编程方式的落地需要使用 “类” 和 “对象” 来实现,所以,面向对象编程其实就是对 “类” 和 “对象” 的使用。

      类就是一个模板,模板里可以包含多个函数,函数里实现一些功能

      对象则是根据模板创建的实例,通过实例对象可以执行类中的函数

    请开发一个消息提醒的功能(邮件/短信/微信)

      函数:

    def email(em,text):
        """
        发送邮件
        :return:
        """
        print(em,text)
    
    def msg(tel,text):
        """
        发送短信
        :return:
        """
        print(tel,text)
    
    def wechat(num,text):
        """
        发送微信
        :return:
        """
        print(num,text)
    ####便携功能
    if 1==1:
        msg("15258569","网购买了一个学位课")
        email("alex@sb.com","网购买了一个学位课")
        wechat("xxxx","网购买了一个学位课")
    #结果:15258569 网购买了一个学位课
    #    alex@sb.com 网购买了一个学位课
    #    xxxx 网购买了一个学位课

      面向对象:

    class Message:
        def email(self,em, text):
            """
            发送邮件
            :return:
            """
            print(em, text)
    
        def msg(sellf,tel,text):
            """
            发送短信
            :return:
            """
            print(tel, text)
    
        def wechat(self,num, text):
            """
            发送微信
            :return:
            """
            print(num, text)
    if 1==1:
        obj = Message()
        obj. msg("15258569","网购买了一个学位课")
        obj.email("alex@sb.com","网购买了一个学位课")
        obj.wechat("xxxx","网购买了一个学位课")
    #结果:15258569 网购买了一个学位课
    #    alex@sb.com 网购买了一个学位课
    #    xxxx 网购买了一个学位课

    总结:

      函数:定义简单/调用简单

      面向对象:定义复杂/调用复杂,    好处:归类,将某些类似的函数写在一起

      1.函数式编程可能会比面向对象好

      2.Python中支持两种编程方式

      3.面向对象方式格式:

         定义:

                   class   类名:         ----定义了一个类

          def  函数名(self):    ---在类中编写了一个"方法" 

          调用:

           x1 = 类名()      ----创建了一个对象/实例化一个对象

           x1.函数名()      ----通过对象调用其中一个方法

      4. 实例

    class Account:
        def login(self):
            user = input("请输入用户名")
            pwd = input("请输入密码")
            if user =="alex" and pwd =="sb":
                print("登录成功")
            else:
                print("登录失败")
    obj = Account()
    obj.login()

    对比  打印

      函数

    """
    完成以下功能:
        老狗/20岁/男/上山去砍柴
        老狗/20岁/男/开车去东北
        老狗/20岁/男/喜欢大宝剑
    """
    def kc(name, age, gender):
        data = "%s,性别%s,今年%s岁,喜欢上山砍柴" % (name, gender, age)
        print(data)
    
    def db(name, age, gender):
        data = "%s,性别%s,今年%s岁,喜欢开车去东北" % (name, gender, age)
        print(data)
    
    def bj(name, age, gender):
        data = "%s,性别%s,今年%s岁,喜欢大宝剑" % (name, gender, age)
        print(data)
    
    kc('老狗', 20, '')
    db('老狗', 20, '')
    bj('老狗', 20, '')
    # 结果:老狗,性别男,今年20岁,喜欢上山砍柴
    #     老狗,性别男,今年20岁,喜欢开车去东北
    #     老狗,性别男,今年20岁,喜欢大宝剑

      面向对象:

    class LaoGou:
        def __init__(self, name, age, gender):  # 特殊的方法,如果 类名() ,则该方法会被自动执行 (构造方法)
            self.n1 = name
            self.n2 = age
            self.n3 = gender
    
        def kc(self):
            data = "%s,性别%s,今年%s岁,喜欢上山砍柴" % (self.n1, self.n3, self.n2)
            print(data)
    
        def db(self):
            data = "%s,性别%s,今年%s岁,喜欢开车去东北" % (self.n1, self.n3, self.n2)
            print(data)
    
        def bj(self):
            data = "%s,性别%s,今年%s岁,喜欢大宝剑" % (self.n1, self.n3, self.n2)
            print(data)
    obj = LaoGou('老狗', 20, '')
    obj.kc()
    obj.db()
    obj.bj()
    #结果:老狗,性别男,今年20岁,喜欢上山砍柴
    #    老狗,性别男,今年20岁,喜欢开车去东北
    #    老狗,性别男,今年20岁,喜欢大宝剑

    总结:

      1.构造方法

        实例:

    class Foo:
        def __init__(self,name):    #构造方法,目的进行数据初始化 
            self.name = name
            self.age = 18
    obj = Foo("")

      通过构造方法,可以将数据进行打包,以后使用时,去其中获取即可.

       2.应用

      a. 将数据封装到对象中,以供自己在方法中调用

    class FileHandler:
        def __init__(self, file_path):
            self.file_path = file_path
            self.f = open(self.file_path, 'rb')
        def read_first(self):
            # self.f.read()
            # ...
            pass
        def read_last(self):
            # self.f.read()
            # ...
            pass
        def read_second(self):
            # self.f...
            # ...
            pass
    obj = FileHandler('C:/xx/xx.log')
    obj.read_first()
    obj.read_last()
    obj.read_second()
    obj.f.close()

      b.将数据封装到对象中,以供其他函数调用 

    def new_func(arg):
        arg.k1
        arg.k2
        arg.k6
    class Foo:
        def __init__(self,k1,k2,k6):
            self.k1 = k1
            self.k2 = k2
            self.k6 = k6
    obj = Foo(111,22,333)
    new_func(obj)

    二.面向对象代码如何编写

      1.规则

    class Foo:
        def __init__(self, name):
            self.name = name
        def detail(self, msg):
            print(self.name, msg)
    obj = Foo("")
    obj.detail("")

      2.什么时候写?

       方式一方向:归类+提取公共值

       方式二正向:在指定类中编写和当前类相关的所有代码 + 提取公共值

    三.面向对象的三大特性:封装/继承/多态 

      1.封装:

       将相关功能封装到一个类中:

    class Message:
        def email(self):pass
        def msg(self):pass
        def wechat(self):pass

       将数据封装到一个对象中:

    class Person:
        def __init__(self, name, age, gender):
            self.name = name
            self.age = age
            self.gender = gender
    obj = Person('孙福来', 18, '')

      2.继承:

    class Base:  # 父类,基类
        def f2(self):
            print('f2')
    class Foo(Base):  # 子类,派生类
        def f1(self):
            print('f1')
    obj = Foo()
    obj.f1()
    obj.f2()
    #结果: f1   f2

    原则:先在自己类中找,没有就去父类

    总结:

      1.继承编写

      class Foo(父类):

        pass

      2.支持多继承(先找左/再找右)

      3.为什么要有多继承?

        提供代码重用性

      3.多态

        多种形态或多种状态

    三.面向对象的多继承 

      a.先找左再找右

      b.经典类和新式类

      py2:  经典类: 一条道走到黑(深度优先)

         新式类: 如果自己或自己的前辈只要有人继承object,那么此类就是新式类

      py3: 新式类

    经典类和新式类的查找成员的顺序不一样.

      经典类:  一条道走到黑(深度优先)

      新式类:  C3算法实现

    C3算法

      获取第一个表头 和 其他表尾进行比较

        不存在则拿走.

        如果存在,则放弃,然后获取第二个表的表头再次和其他表的表尾进行比较.

      简单:

        经典类:一条道走到黑(深度优先)

        新式类:留个跟. (科学C3算法)

    注意事项:

      super是遵循__mro__执行顺序.

  • 相关阅读:
    计算器修正代码
    AsEnumrable和AsQueryable的区别
    c# 解释器模式与sping.net表达式的结合应用(金融里经常需要用到公式,这个公式是抽象的需要自己解释)
    Spring.net 间接调用被AOP拦截的方法失效(无法进入aop的拦截方法)
    信息熵公式的由来(转)
    期望风险、经验风险与结构风险之间的关系(转)
    梯度(转)
    奇特的数学问题(转)
    最大似然估计和最大后验估计(转)
    贝叶斯思想以及与最大似然估计、最大后验估计的区别(转)
  • 原文地址:https://www.cnblogs.com/chenxi67/p/9542762.html
Copyright © 2011-2022 走看看