文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python 03

2023-01-31 05:43

关注

刚才我们提到了,可以在已有类的基础上创建新类,这其中的一种做法就是让一个类从另一个类那里将属性和方法直接继承下来,从而减少重复代码的编写。提供继承信息的我们称之为父类,也叫超类或基类;得到继承信息的我们称之为子类,也叫派生类或衍生类。子类除了继承父类提供的属性和方法,还可以定义自己特有的属性和方法,所以子类比父类拥有的更多的能力,在实际开发中,我们经常会用子类对象去替换掉一个父类对象,这是面向对象编程中一个常见的行为,对应的原则称之为里氏替换原则。下面我们先看一个继承的例子。


                class  Person(object):
                                """人"""
                                      def   __init__(self,name,age):
                                               self._name = name
                                                self.age = age              
                          @property
                           def   name(self):
                                 return self._name

                         @property
                                def   age(self):
                            return self._age

                         @age.setter
                        def   grade(self, grade):
                                  self._grade = grade

                        def study(self, course):
                          print('%s的%s正在学习%s.' % (self._grade, self._name, course))
                    class Teacher(Person)
                    def __init__(self, name, age, title):
                        super().__init__(name, age)
                            self._title = title

                            @property
                            def title(self):
                                return self._title

                            @title.setter
                            def title(self, title):
                                self._title = title

                            def teach(self, course):
                            print('%s%s正在讲%s.' % (self._name, self._title, course))
                            def main():
                            stu = Student('王大锤', 15, '初三')
                            stu.study('数学')
                            stu.watch_av()
                            t = Teacher('骆昊', 38, '老叫兽')
                            t.teach('Python程序设计')
                            t.watch_av()
                            if __name__ == '__main__':
                            main()
                        子类在继承了父类的方法后,可以对父类已有的方法给出新的实现版本,这个动作称之为方法重写(override)。通过方法重写我们可以让父类的同一个行为在子类中拥有不同的实现版本,当我们调用这个经过子类重写的方法时,不同的子类对象会表现出不同的行为,这个就是多态(poly-morphism)。

     列表生成式
     a = [x for x in range(100000000000) if   x %  2==0]
     优点:计算速度快,因为一次性已经加载到内存中了,适合数据量不太大的情况
     缺点:占用内存
     生成器
     a = (x   for    x     in    range(10000000000)    if   x  %  2 ==0)
     优点:节约内存空间
     缺点:计算速度慢,因为要生成

     继承代码:
           class    A(object):
                    def  __init__(self):
                        self.a = 100                            
                             def A1(self):
                                 print("A1)                                          
                    在类名中写上继承的类                          
            class   B(A):
                     def   init(self):
                              A.init(self)
                                self.b = 200
                                def  B1(self);
                             print(‘B1')

                装饰器代码
                def deco(func):
                   def warp(a,b):
                   print(a+b)
                   return func(a,b)
             return warp
                                                @deco
                            def qa(a,b):
                                print("a,b")
                    qa(100,20)

     装饰器参数代码
        #装饰器将前面两个数字的求和,函数本身第三个数乘上这个和。
                     def qa(func): 
                        def warp(num1,num2,num3):
                        num = num1 + num2 
                        return func(0,num,num3)
                        return warp

                        @qa
                        def SUM(num1,num2,num3):
                        print(num1,num2,num3)
                        print(num2*num3)

                    SUM(5,8,9)

                 闭包
                                     def foo():
                                            l = []
                                            def bar(i):
                                                l.append(i)
                                                return l
                                        return bar
                f1 = foo()
                res1 = f1(1)
                print(res1)
                res2 = f1(2)
                print(res2)
                输出结果是               
                                 [1]
                                 [1, 2]
阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯