python开发面向对象基础:组合&继承
一,组合
组合指的是,在一个类中以另外一个类的对象作为数据属性,称为类的组合 人类装备了武器类就是组合
1.圆环,将圆类实例后传给圆环类
#!/usr/bin/env python
#_*_coding:utf-8_*_ #circle,圆类
from math import pi
class Circle:
def __init__(self,radius):
self.radius = radius
def perimeter(self):
return 2 * pi * self.radius
def area(self):
return pi * self.radius **2 # c1 = Circle(10)
# print(c2.area()) #圆环(不判断半径版本),就是圆的组合,利用了上面圆的类
class Ring:
def __init__(self,outside_radius,inside_radius):
self.outside_circle = Circle(outside_radius) #实例化一个圆形,作为self.outside_circle属性的值
self.inside_circle = Circle(inside_radius) #再实例化一个圆形
def area(self):
return self.outside_circle.area() - self.inside_circle.area()
def perimeter(self):
return self.inside_circle.perimeter() + self.outside_circle.perimeter() # r1 = Ring(20,10) #这是傻瓜版本,没有考虑谁的半径大,谁是外圈内圈
# print(r1.area())
# print(r1.perimeter()) #圆环(判断半径版本)
class Ring:
def __init__(self,outside_radius,inside_radius):
outside_r = max(outside_radius,inside_radius) #判断谁大谁是外环
inside_r = min(outside_radius,inside_radius) #
self.outside_circle = Circle(outside_r) #实例化一个圆形,作为self.outside_circle属性的值
self.inside_circle = Circle(inside_r) #再实例化一个圆形
def area(self):
return self.outside_circle.area() - self.inside_circle.area()
def perimeter(self):
return self.inside_circle.perimeter() + self.outside_circle.perimeter() # 将判断在实例化的时候判断
# outer = input('外半径:')
# inner = input('内半径:')
# if outer.isdigit() and inner.isdigit() and int(outer) > int(inner):
# r1 = Ring(int(outer),int(inner))
# print(r1.perimeter())
# print(r1.area()) # 将判断给类方法里面去判断
# r1 = Ring(20,10)
# print(r1.area())
# print(r1.perimeter())
二,.多组合
#!/usr/bin/env python
#_*_coding:utf-8_*_ # 老师 课程 生日
# 第一种组合,在里面组合
class Teacher:
def __init__(self,name,salary,friend,course_name,course_period,course_price):
self.name = name
self.salary = salary
self.bf = friend
self.course = Course(course_name,course_period,course_price) #这里实例化Course class Course:
def __init__(self,name,period,price):
self.name = name
self.period = period
self.price = price egg = Teacher('egon',200,'yuan','python','6months',20000) #传入老师,课程的属性
print(egg.bf)
print(egg.course.name) # egg.course就是Course的实例,相当于python # 第二种组合,在外面组合将课程先实例化后传入,适用于共性一样的
class Teacher:
def __init__(self, name, salary, friend, python):
self.name = name
self.salary = salary
self.bf = friend
self.course = python class Course:
def __init__(self, name, period, price):
self.name = name
self.period = period
self.price = price python = Course('python', '6months', 20000)
#将python课程实例写这里,那么所有教Python的老师都可以这么写
egg = Teacher('egon', 200, 'yuan', python) #Python实例化后传入,就不需要每次传入很多参数,较少内存
print(egg.bf)
print(egg.course.name) # 第三种组合,在外面组合,适用于每个人都有的,但是又不一样的
class Teacher:
def __init__(self,name,salary,friend,python):
self.name = name
self.salary = salary
self.bf = friend
self.course = python class Birth:
def __init__(self,year,month,day):
self.year = year
self.month = month
self.day = day # egg = Teacher('egon', 200, 'yuan', 'python')
# egg_birth = Birth(1965,2,2)
# print(egg_birth.year)
# 将整个生日类的东西给了交给了egg的birth,可以调用所有属性和方法
# 如果写在老师类里面,那就太多了属性,代码就不易读
# 重新定个新类,然后绑定给老师
# egg.birth = egg_birth
# print(egg.birth.year)
三,继承
继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类,父类又可称为基类或超类,新建的类称为派生类或子类
#!/usr/bin/env python
#_*_coding:utf-8_*_ # 子类会继承父类的所有属性和方法
class Animal: #父类 基类 超类
def __init__(self,name,life_value,aggr):
self.name = name
self.life_value = life_value
self.aggr = aggr class Person(Animal): #子类 派生类
pass class Dog(Animal): #子类 派生类
pass egg = Person('egon',1000,50)
print(egg.name)
print(egg.aggr) # class Dad:pass
# class Ma:pass
# class Son1(Dad,Ma):pass 多继承
# class Son2(Dad):pass # print(Son1.__bases__) __bases__查看父类
# print(Son2.__bases__)
# print(Dad.__bases__) --obj是所有类的鼻祖
3.1 继承与抽象
先抽象,在继承
抽象分成两个层次:
1.将奥巴马和梅西这俩对象比较像的部分抽取成类;
2.将人,猪,狗这三个类比较像的部分抽取成父类。
抽象最主要的作用是划分类别(可以隔离关注点,降低复杂度)
继承:是基于抽象的结果,通过编程语言去实现它,肯定是先经历抽象这个过程,才能通过继承的方式去表达出抽象的结构。
抽象只是分析和设计的过程中,一个动作或者说一种技巧,通过抽象可以得到类
3.2 经典类与新式类
#!/usr/bin/env python
#_*_coding:utf-8_*_ #python2
#class Dad: #经典类 这个是不会集成obj的类
#class Dag(object) #新式类 #python3
#不存在经典类
#class Dad == class Dag(object) #新式类
四,派生
当然子类也可以添加自己新的属性或者在自己这里重新定义这些属性(不会影响到父类),需要注意的是,一旦重新定义了自己的属性且与父类重名,那么调用新增的属性时,就以自己为准了。
#!/usr/bin/env python
#_*_coding:utf-8_*_ #继承
class Pet:
def eat(self):
pass
def sleep(self):
pass
def drink(self):
pass class Cat(Pet): #Pet类的一个派生类,也叫子类
def catch(self):pass #Pet类的一个派生方法 class Dog(Pet):
def watch_door(self):pass # 中华气死猫 = Cat()
# 中华气死猫.catch()
# 中华气死猫.eat() #1.人狗大战继承版本
class Animal: #父类 基类 超类
def __init__(self,name,life_value,aggr):
self.name = name
self.life_value = life_value
self.aggr = aggr #攻击力
def eat(self):
self.life_value += 10 class Person(Animal): #子类 派生类
def attack(self,enemy): #人的派生方法
enemy.life_value -= self.aggr class Dog(Animal): #子类 派生类
def bite(self,person): #狗的派生方法
person.life_value -= self.aggr # egg = Person('gon',100,10)
# dahei = Dog('dahei',200,20)
# print(dahei.life_value)
# dahei.eat()
# print(dahei.life_value)
# print(egg.life_value)
# dahei.bite(egg)
# print(egg.life_value) #2.如果属性多,增加对象属性,又要用父类的又要用自己的
class Animal: #父类 基类 超类
def __init__(self,name,life_value,aggr):
self.name = name
self.life_value = life_value
self.aggr = aggr #攻击力
def eat(self):
self.life_value += 10 class Person(Animal): #子类 派生类
def __init__(self,money):
self.money = money #派生属性
def attack(self,enemy): #人的派生方法
enemy.life_value -= self.aggr class Dog(Animal): #子类 派生类
def __init__(self,breed):
self.breed = breed
def bite(self,person): #狗的派生方法
person.life_value -= self.aggr # ha2 = Dog('牛头梗',20000,100)
# 报错 _ __init__() takes 2 positional arguments but 4 were given
# 在继承中,如果子类有的方法就执行子类的,如果没有执行父类的
# 本例中子类有自己的Init方法,需要2个参数,加上self算一个,当然这个不需要传 #3.有父类的对象属性,又有子类的属性,super方法来更改__init__
class Animal: #父类 基类 超类
def __init__(self,name,life_value,aggr):
self.name = name
self.life_value = life_value
self.aggr = aggr #攻击力
def eat(self):
self.life_value += 10 class Person(Animal): #子类 派生类
def __init__(self,money,name,life_value,aggr):
super().__init__(name,life_value,aggr)
self.money = money #派生属性 def attack(self,enemy): #人的派生方法
enemy.life_value -= self.aggr class Dog(Animal): #子类 派生类
def __init__(self,breed,name,life_value,aggr):
# Animal.__init__(self,name,life_value,aggr) #让子类执行父类的方法,就是父类名.方法名(参数),连self也得传(经典类的继承)
super().__init__(name,life_value,aggr) #super关键字——新式类,跟上面的经典类效果一样
# super(Dog,self).__init__(name,life_value,aggr) #super关键字关键字——新式类解释上面的写法跟经典类一样,只是简化了
self.breed = breed
def bite(self,person): #狗的派生方法
person.life_value -= self.aggr # dahei = Dog('狼','dahei',2000,100)
# print(dahei.life_value) #4.有父类的对象属性,又有子类的属性,super方法
class Animal: #父类 基类 超类
def __init__(self,name,life_value,aggr):
self.name = name
self.life_value = life_value
self.aggr = aggr #攻击力
def eat(self):
self.life_value += 10 class Person(Animal): #子类 派生类
def __init__(self,money,name,life_value,aggr):
super().__init__(name,life_value,aggr) #
self.money = money #派生属性 def attack(self,enemy): #人的派生方法
enemy.life_value -= self.aggr class Dog(Animal): #子类 派生类
def __init__(self,breed,name,life_value,aggr):
#Animal.__init__(self,name,life_value,aggr) #让子类执行父类的方法,就是父类名.方法名(参数),连self也得传
super().__init__(name,life_value,aggr) #super关键字——新式类
#super(Dog,self).__init__(name,life_value,aggr) #super关键字关键字——新式类
self.breed = breed
def bite(self,person): #狗的派生方法
person.life_value -= self.aggr def eat(self): # 父类方法的重写
super().eat() #子类执行父类的eat方法,如果没有的话,就会执行下面代码,也可以在外面引用
print('dog is eating~~~ ') dahei = Dog('狼', 'dahei', 2000, 100)
print(dahei.life_value)
dahei.eat()
super(Dog,dahei).eat() #父类方法的重写,在外面引用父类的方法,dahei就是self
print(dahei.life_value) # 父类方法的重写不推荐用,因为这样还不如直接改了父类
python开发面向对象基础:组合&继承的更多相关文章
- python开发面向对象基础:接口类&抽象类&多态&钻石继承
一,接口类 继承有两种用途: 一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类Interface,接口类中定义了一些接口名(就是函数名)且并未实 ...
- PYTHON开发--面向对象基础入门
面向对象 一:面向对象初级 1.思考:首先在python中,以前我们以前用到的几乎都是函数式编程,但是有时候函数式编程其中代码重复利用率太高,我们往往会把这些重复代码写进一个函数日后去调用,所以呢,今 ...
- python 之 面向对象基础(继承与派生,经典类与新式类)
7.2 继承与派生 7.21继承 1.什么是继承? 继承是一种新建类的的方式,在python中支持一个子类继承多个父类.新建的类称为子类或者派生类,父类又可以称为基类或者超类,子类会”遗传“父类的属性 ...
- python笔记4 内置函数,匿名函数.递归函数 面向对象(基础, 组合,继承)
内置函数 eval和exec eval :执行字符串中的代码并将结果返回给执行者,有返回值 exec:执行字符串中的代码,往往用于执行流程语句,没有返回值. s1 = '1+2' s2 = 'prin ...
- python开发面向对象基础:封装
一,封装 [封装] 隐藏对象的属性和实现细节,仅对外提供公共访问方式. [好处] 1. 将变化隔离: 2. 便于使用: 3. 提高复用性: 4. 提高安全性: [封装原则] 1. 将不需要对外提供的内 ...
- PYTHON开发--面向对象基础二
一.成员修饰符 共有成员 私有成员, __字段名 - 无法直接访问,只能间接访问 1. 私有成员 1.1 普通方法种的私有成员 class Foo: def __init__(self, n ...
- python开发面向对象基础:人狗大战学面向对象
一,通过函数写人狗大战这个故事 #!/usr/bin/env python #_*_coding:utf-8_*_ #1.函数 人模子 def person(name,level,life_value ...
- Python(面向对象编程——2 继承、派生、组合、抽象类)
继承与派生 ''' 继承:属于 组合:包含 一. 在OOP程序设计中,当我们定义一个class的时候,可以从某个现有的class继承,新的class称为子类(Subclass),而被继承的class称 ...
- 24 - 面向对象基础-多继承-super-mro-Mixin
目录 1 类的继承 2 不同版本的类 3 基本概念 4 特殊属性和方法 5 继承中的访问控制 6 方法的重写(override) 6.1 super 6.2 继承中的初始化 7 多继承 7.1 多继承 ...
随机推荐
- 使用Mybatis时报错Cause: java.sql.SQLSyntaxErrorException: ORA-00911: 无效字符
首先保证sql语句在oracle中的编写是正确的,然后在配置文件中插入时就报这样的错误.有可能是因为sql语句后面多了“:”分号,在标签中写分号是错的.如果我写成了 insert into emplo ...
- 第三方库PIL简单使用
PIL为第三方库,需要简单安装,最容易的安装方法 pip install PIL 详细内容见http://effbot.org/imagingbook/ 下面展示一个简单用例:(字母验证码简单实现) ...
- WPF DataGrid 分组
public ListCollectionView collection; collection = new ListCollectionView(obj.empData); collection.G ...
- js获取一周的日期范围
function getWeek() { this.nowTime = new Date(); this.init = function() { this.dayInWeek = this.nowTi ...
- input type=file 怎么样调取用户手机照相机
input 有个属性accept="image/*" 这样就可以了,同时在网上看到了其他答案,试了下没啥效果.写记录下来 如下: 使用input:file标签, 去调用系统默认相机 ...
- LeetCode OJ:Insertion Sort List (插入排序链表)
Sort a linked list using insertion sort. 用插入排序来排序一个list,额, 我写的好麻烦啊, debug了好久,至少提交了5次...写吐了快,先贴代码,写的也 ...
- Linux系统下的shutdown命令用于安全的关闭/重启计算机
Linux系统下的shutdown命令用于安全的关闭/重启计算机,它不仅可以方便的实现定时关机,还可以由用户决定关机时的相关参数.在执行shutdown命令时,系统会给每个终端(用户)发送一条屏显,提 ...
- android事件传递机制以及onInterceptTouchEvent()和onTouchEvent()总结
老实说,这两个小东东实在是太麻烦了,很不好懂,我自己那api文档都头晕,在网上找到很多资料,才知道是怎么回事,这里总结一下,记住这个原则就会很清楚了: 1.onInterceptTouchEvent( ...
- ActiveReports报表控件V11 SP1版本正式发布!
无需编码,即可轻松搞定商业报表六大需求的 ActiveReports 报表控件,于今日宣布正式发布 V11 SP1 版本,并在其 官方网站 提供免费下载. V11 版本是 ActiveReports ...
- linux 下看所有用户 及所有组
俺的centos vps上面不知道添加了多少个账户,今天想清理一下,但是以前还未查看过linux用户列表,google了一下,找到方便的放:一般情况下是 cat /etc/passwd 可以查看所有用 ...