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

python——面向对象(下)

目录

一、继承

二、私有属性私有方法

三、多态

四、属性和方法

五、异常

六、test


一、继承

故事继续:大猫掌握了 师傅的配方 和 学校的配方,通过研究,大猫在两个配方的基础上,创建了一种全新的煎饼果子配方,称之为 "猫氏煎饼果子配方"。(子类重写父类同名属性和方法)

 子类重写父类同名属性的方法

 

故事继续:大猫的新配方大受欢迎,但是有些顾客希望也能吃到古法配方和 现代配方 的煎饼果子...(子类调用父类的同名属性和方法)

 子类调用父类同名属性

 

故事继续:大猫的煎饼果子店非常红火,终于有一天,他成了世界首富!!

但是他也老了,所以他希望把 师傅的配方 和 学校的配方 以及自己的配方 继续传承下去...(多层继承)

 

 

 

 

二、私有属性私有方法

公有属性和公有方法

类的属性

命名格式:由字母开头,总体由字母、数字和_构成

使用方法:在类外面 :对象名.属性名  在类内部 : self.属性名

类的方法

使用 def 关键字可以为类定义一个方法,与一般函数定义不同,类方法必须包含参数 self,且为第一个参数 

  命名格式:由字母开头,总体由字母、数字和_构成

  使用方法:在类外面 :对象名.方法名(实参表)  在类内部 : self.方法名(实参表)

例子:class Car:

  def setCarInfo(self, num, color):

  self.wheelNum = num

  self.color = color

  def getCarInfo(self):

  print("车子轮子数目是%d,车子颜色是%s"%(self.wheelNum,self.color)) 

  def toot(self): 

  print("车子在鸣笛,嘟嘟....") 

私有属性和私有方法

•Python中以属性命名方式来区分,如果在属性名前面加了2个下划线'__',则表明该属性是私有属性,否则为公有属性(方法也是一样,方法名前面加了2个下划线的话表示该方法是私有的,否则为公有的)。

类的私有属性

  命名格式:__private_attrs  由__开头,总体由字母、数字和_构成

  使用方法: 只在类内部 : self.__private_attrs

类的方法

    命名格式:__private_function  由__开头,总体由字母、数字和_构成

    使用方法:只在类内部 : self.__private_function(实参表)

例子:class People:

    def setName(self, name):

          self.__name = name    #访问私有属性 __name   

    def __getName(self):             # 定义私有方法

  return self.__name

    def printName(self):

  print('姓名是%s'%self.__getName())       # 调用私有方法 __getName()

三、多态

 定义时的类型和运行时的类型不一样,此时就成为多态.

 多态的概念是应用于Java和C#这一类强类型语言中,而Python崇尚“鸭子类型 ”.

鸭子类型:

  虽然我想要一只"鸭子",但是你给了我一只鸟。 但是只要这只鸟走路像鸭子,叫起来像鸭子,游泳也像鸭子,我就认为这是鸭子.

 

四、属性和方法

类属性

定义

  类属性就是类对象所拥有的属性,它被所有类对象的实例对象所共有,在内存中只存在一个副本,这个和C++中类的静态成员变量有点类似。对于公有的类属性,在类外可以通过类对象和实例对象访问

实例属性

定义:一个类的实例对象所拥有的属性

特点:独立的,一对一

拥有者:每个对象都拥有自己的实例属性

语法格式:

class 类名:

  def  方法名(self):

  self.属性名  #实例属性

  .....

#创建类的对象后

对象名.属性名 = 值    # 第一次执行,添加新属性

类方法

类方法:   是类对象所拥有的方法

特点:  @classmethod  在上面修饰 ,方法第一个参数必须是类对象

语法格式:

  @classmethod

  def 类方法名(cls):

  执行代码

访问格式:

  类名.类方法名()

  实例对象名.类方法名()

应用:  访问类属性,并且可以对类属性进行修改

静态方法

静态方法: 是类对象所拥有的方法

特点:  @staticmethod来进行修饰,不需要多定义参数

语法格式:

  @staticmethod

  def 静态方法名():

  执行代码

访问格式:

  类名.静态方法名()

应用:  访问类属性,并且可以对类属性进行修改

 

五、异常

异常 

当Python检测到一个错误时,解释器就无法继续执行了,反而出现了一些错误的提示,这就是所谓的"异常"。

例如:f = open("Good.txt")    #打开一个不存在的文件

Traceback (most recent call last):

  File "error.py", line 3, in <module>

    f = open("Good.txt")

  FileNotFoundError: [Errno 2] No such file or directory: 'Good.txt'

捕获多个异常——try...except...

例子1:

#!/usr/bin/python

try:

  f = open("Good.txt")

  print(num)

except (IOError,NameError):

  pass

执行结果: 不会出现错误提示

例子2:

#!/usr/bin/python

try:

  f = open("Good.txt")

  print(num)

except (IOError, NameError):

  print('find error')

执行结果: find error

 捕获异常信息描述并存储

获取一个异常的信息描述,并存储

语法格式:

  try :

  可能会出现异常的语句

  except  异常类型 as 存储位置变量名:

  pass   #表示直接略过     #或者执行的语句

捕获多条异常,并存储

语法格式: 

  try :

  可能会出现异常的语句

  except  (异常类型1[, 异常类型2,....,异常类型N]) as 存储位置变量名:

  pass   #表示直接略过     #或者执行的语句

捕获所有异常信息——try...expect ...as...

获取所有异常的信息描述

语法格式:

  try :

  可能会出现异常的语句

  except :

  pass   #表示直接略过     #或者执行的语句

捕获所有异常,并存储

语法格式: 

  try :

  可能会出现异常的语句

  except  Exception as 存储位置变量名:

  pass   #表示直接略过     #或者执行的语句

异常传递一般会出现在try嵌套使用时和多函数之间调用,这两种情况下:

如果try嵌套,那么如果里面的try没有捕获到这个异常,那么外面的try会接收到这个异常,然后进行处理,如果外边的try依然没有捕获到,那么再进行传递。。。

抛出自定义异常—— raise语句

raise语句 : 可以引发一个异常。异常/错误对象必须有一个名字。自定义一个异常类,且它们应是Error或Exception类的子类。

语法格式:

class 自定义异常类名(Error或者Exception):

  #异常类的方法....

  def __init__(self, ......):

  ......

抛出异常语句格式:

  raise 异常类名(传参列表)

例子:如图

 

异常处理中抛出异常

在使用try...except...中,如果出现异常,可以选择捕捉该异常,自己处理;也可以选择抛出该异常,让系统处理(默认处理)。

语法格式:添加一个判断条件,若条件为真,表示捕捉异常自己处理;若为假,可以抛出异常,系统默认处理

  try:

  可能产生异常的语句

  except  Exception as 存放位置:

  if 条件:

  处理该异常

  else:

  #重新抛出异常

  raise     

 

 

六、test

2.创建员工类Employee,属性有姓名name、能力值ability、年龄age(能力值为100-年龄),功能有doWork(),该方法执行一次,该员工的能力值-5,创建str方法,打印该员工的信息
3.创建老板类Boss,属性有金钱money,员工列表employeeList(存储员工类对象),工作量work,功能有雇佣员工addEmployee(),雇佣后将员工添加至列表中,雇佣一人money减5000,金额不足时不能雇佣新员工;开始工作startWork(),工作开始后,依次取出员工列表中的员工开始工作,员工能力值减少的同时总的工作量work也减少,当工作量work为0时,工作结束,调用endWork(该方法为Boss类方法,打印员工的能力值信息)方法,如果所有员工使用完后,依然没有完成工作,则提示老板需要雇佣新员工,并打印剩余工作量
4.创建Boss类对象,默认执行雇佣3个员工,年龄分别为30,40,50,然后死循环开始工作,直至工作完成。

class Employee():
    def __init__(self,name,age):
        self.name = name
        self.ability = 100 - age
        self.age = age
        #print(self.name,self.ability,self.age)
    def dowork(self):
        if(self.ability > 5):
            self.ability -= 5
            return
        else:
            return
    def str(self):
        print(self.name,self.ability,self.age)
class Boss():
    def __init__(self,money,work):
        self.money = money
        self.employeeList = []
        self.work = work
    def addEmployee(self,emp):
        self.employeeList.append(emp)
        if self.money < 5000:
            print("余额不足")
            return False
        self.money -= 5000
    def startWork(self):
        for i in self.employeeList:
            if (i.ability > 0):
                i.dowork()
                self.work -= 1
            if self.work == 0:
                self.endWork()
                break
        if self.work > 0:
            print("员工不足")
            print("剩余工作量为 %d" %self.work)
    def endWork(self):
        for i in self.employeeList:
            print(i.ability)



emp1 = Employee("1",30)
emp2 = Employee("2",40)
emp3 = Employee("3",50)
bos1 = Boss(20000,3)
bos1.addEmployee(emp1)
bos1.addEmployee(emp2)
bos1.addEmployee(emp3)
bos1.startWork()


http://www.kler.cn/a/5687.html

相关文章:

  • C 中的循环
  • Jenkins使用
  • 【计算机视觉 | 目标检测】DETR风格的目标检测框架解读
  • QT之QCamera
  • Java多态
  • 阶乘约数——蓝桥杯python组国赛题(C++、唯一分解定理)
  • 利用 Docker 搭建主从服务器
  • Spring MVC 之 ViewResolver
  • 索马里ECTN/BESC/CTN证书
  • 【新2023Q2押题JAVA】华为OD机试 - 服务依赖
  • 启动优化小结
  • UDSonLIN(ISO14229-7)诊断协议
  • tsconfig.json参数详解
  • 【Redis】高可用:Redis的主从复制是怎么实现的?
  • C语言中void的高级应用
  • spring boot 集成 postgresql mybatis-plus swagger pagehelper
  • Hystrix学习笔记
  • Android Webview隐藏部分div
  • 【从零开始学习 UVM】7.3、Driver Sequencer Handshake —— get() 和 put() 方法详解【了解即可】
  • 【二阶锥规划】考虑气电联合需求响应的气电综合能源配网系统协调优化运行【IEEE33节点】(Matlab代码实现)