当前位置: 首页 > news >正文

Python 03

继承和多态

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


                class  Person(object):"""人"""def   __init__(self,name,age):self._name = nameself.age = age              @propertydef   name(self):return self._name@propertydef   age(self):return self._age@age.setterdef   grade(self, grade):self._grade = gradedef 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@propertydef title(self):return self._title@title.setterdef title(self, title):self._title = titledef 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 = 200def  B1(self);print(‘B1')

                装饰器代码def deco(func):def warp(a,b):print(a+b)return func(a,b)return warp@decodef 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@qadef 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 lreturn barf1 = foo()res1 = f1(1)print(res1)res2 = f1(2)print(res2)输出结果是               [1][1, 2]
http://www.lryc.cn/news/570423.html

相关文章:

  • 程序显示烫烫烫,屯屯屯
  • python superset 中的SQL Editor 出现乱码错误怎么办
  • 使用Drwtsn32和NTSD进行崩溃进程转储
  • Nsfocus-绿盟科技笔试题目(转)
  • 【AI学习】【Ubuntu 22.04】【安装Ollama】两种方式
  • 电脑上的.ssh目录只做什么的
  • Android 开源项目分类汇总--1
  • linux命令--test
  • Oracle数据库还原DMP文件
  • JSP详细篇——Servlet(一)
  • 在互联网公司中:有些程序员,本质是一群被圈养的羊!
  • 二维前缀和
  • AutoCAD2012安装失败解决办法,Failed Installation aborted, Res
  • Ext4 vs xfs
  • NodeJS的fs模块的readFile和createReadStream区别以及常见方法
  • 《AI辅助编程:从零掌握核心逻辑》工作坊开业
  • 龙影辅助lua脚本调用_skynet之lua服务
  • Apple开发者账号介绍及证书配置详细说明
  • linux没有manconfig文件,linux shell man命令详细介绍
  • anaconda安装及问题解决
  • Goby 漏洞发布|亿赛通电子文档安全管理系统 ClientLoginWeb 接口远程代码执行漏洞_亿赛通电子文档安全管理系统代码执行漏洞(cnvd-2024-59457)
  • 2008入搜狗,见证搜狗浏览器的诞生!说说我在搜狗做测试这些年…
  • windows系统进程详解
  • 134-135Elements-UI组件库
  • CISP 考试教材《第 4 章 知识域:业务连续性》知识整理
  • 腾讯大数据实时分析引擎Hermes揭秘
  • 下载 kaakoo 咔咕 http://job.kaakoo.cn/download.aspx?ID=T679
  • Linux编程:3、进程通信-信号
  • 【三刷C语言】数据的存储
  • 永远的优客李林——Just for you