Python学习-面向对象

作者: 残阳夕露 | 来源:发表于2018-07-13 22:30 被阅读101次
查看所有Python相关学习笔记

面向对象

  • 面向对象知识点汇总:
1. 获取属性:  
    > 1-实例对象.属性  ---    . 是调用的意思  
    > 2-类属性(静态属性)---这个属性是属于所有类的对象    
         1-对象.属性         
         2-类.属性
2. 初始化方法===构造方法--```def ____init__(self):```
    > 作用:只要创建实例,就会被调用
3. self--本身--->指实例的本身--->t1   --t1 = Tiger(200)
    > 可以改其他字符 ---但不建议改--->规范
4. 实例方法:
    > 定义:def tell(self):----self 是具体的调用实例  
    > 作用:每个实例个体都有自己的输出
5. 静态方法==类方法
    @staticmethod 修饰,没有self
6. from  random import randint #取随机---
    > 要点:游戏-每一次的弹出的房间号是随机的
        2-randint(0,2)可以取: 0,1,2  闭区间
7. 计算游戏时间:time.time()---秒
8. 继承:
    class SouthTiger(Tiger,WonTiger):#括号内是 多个或一个父类名
9. 子类对象调用父类被重写的方法:
    super(SouthTiger,h1).roar()
  • 面向对象
    • 静态属性
    • 实例属性(self)
    • 静态方法(@staticmethod)(可以访问静态属性:类名.属性)(不可以访问实例属性)
    • 实例方法(self)(可以访问实例属性:self.属性)
    • 类方法(cls)(@classmethod)(不可以访问实例属性)(使用较少,基本不用)
    class Tiger:
        '老虎'
        classname = 'tiger'#静态属性
        def __init__(self,weight = 200):#实例属性
            self.weight = weight
        def tellWeight(self):#实例方法
            print( f'my weight is {self.weight}')
        def roar(self):
            print('wow!!!')
            self.weight -= 5
        @staticmethod # 静态方法
        def roar2():
            print(Tiger.classname)
    
  • 对象的继承
    class SubClassName (ParentClass1[,ParentClass2]):
        pass
    
    class NeTiger(Tiger):
        '继承虎'
        color = 'red'
        classname= 'dongbei tiger'
        def __init__(self,weight=200):
            Tiger.__init__(self,weight) #调用父类的初始化方法
        @staticmethod
        def jump():
            print('两米高')
    

类和对象

对象对象 = 属性 + 方法

Python中的类名约定以大写字母开头
Python中的函数名约定以小写字母开头

面向对象简介OO=Object Oriented

  • 封装 信息隐蔽技术
  • 继承 继承是子类自动共享父类之间数据和方法的机制
# Mylist继承了list的方法和属性
class Mylist(list):
    pass
list2 = Mylist()
list2.append(5)
print(list2)
# 执行结果
[5]
  • 多态 名字一样,实现不一样
class A:
    def fun(self):
        print('我是A')
class B:
    def fun(self):
        print('我是B')
a = A()
b = B()
a.fun()
b.fun()
# 执行结果
我的A
我的B

面向对象编程

OOA:面向对象分析
OOD:面向对象设计
OOP:面向对象编程

  • self是什么?

Python的self相当于C++的this指针
同一个类可以生成无数个对象,self相当于门牌号

class Ball:
    def setName(self,name):
        self.name = name
    def kick(self):
        print('我叫%s,该死的,谁踢我...' % self.name)
a = Ball()
a.setName('球A')
b = Ball()
b.setName('球B')
c = Ball()
c.setName('土豆')
a.kick()
c.kick()
# 执行结果
我叫球A,该死的,谁踢我...
我叫土豆,该死的,谁踢我...
  • 构造方法__init__(self,param1,param2...) Python的魔法方法
class Ball:
    def __init__(self,name='qiu'):
        self.name = name
    def kick(self):
        print('我叫%s,该死的,谁踢我...' % self.name)
a = Ball('球A')
b = Ball()
c = Ball('土豆')
a.kick()
b.kick()
c.kick()
# 执行结果
我叫球A,该死的,谁踢我...
我叫qiu,该死的,谁踢我...
我叫土豆,该死的,谁踢我...
  • 公有和私有伪私有

在Python中定义私有变量只需要在变量名或函数名前加上“”两个下划线,那么这个函数或变量就变为私有的了
私有后必须使用内部方法调用或通过'
类名
_变量名'来访问

class Person:
    __name = '测试'
    def getName(self):
        return self.__name
p = Person()
a = p.getName()
print(a)
# 执行结果
测试
测试

继承

单继承
class DerivedClassName(BaseClassName):
    pass

BaseClassName 被继承的类:基类、父类、超类

  • 子类可以调用父类方法
class Parent:
    def hello(self):
        print('正在调用父类的方法')
class Child(Parent):
    pass
p = Parent()
p.hello()
c = Child()
c.hello()
# 执行结果
正在调用父类的方法
正在调用父类的方法
  • 子类重写了父类的方法,将会覆盖掉父类的方法
# 例一:
class Parent:
    def hello(self):
        print('正在调用父类的方法')
class Child(Parent):
    def hello(self):
        print('正在调用子类的方法')
p = Parent()
p.hello()
c = Child()
c.hello()
# 执行结果
正在调用父类的方法
正在调用子类的方法
# 例二
import random as r

class Fish:
    def __init__(self):
        self.x = r.randint(1,10)
        self.y = r.randint(1,10)
    def move(self):
        self.x -= 1
        print('我的位置是:',self.x,self.y)
class Goldfish(Fish):
    pass
class Carp(Fish):
    pass
class Shark(Fish):
    def __init__(self):
        self.hungry = True
    def eat(self):
        if self.hungry:
            print('吃货的梦想就是天天有的吃!!!')
        else:
            print('太撑了,吃不下了!')
print('调用父类.......................')
fish = Fish()
fish.move()
fish.move()
print('子类未重写,可调用父类的move.....')
goldfish = Goldfish()
goldfish.move()
goldfish.move()
print('子类已重写,不可调用父类的move...')
shark = Shark()
shark.eat()
shark.eat()
# shark.move() # AttributeError: 'Shark' object has no attribute 'x'
# 执行结果
调用父类.......................
我的位置是: 7 2
我的位置是: 6 2
子类未重写,可调用父类的move.....
我的位置是: 2 9
我的位置是: 1 9
子类已重写,不可调用父类的move...
吃货的梦想就是天天有的吃!!!
太撑了,吃不下了!

  • 重写父类方法是想继续保持父类方法不被覆盖,可以采用以下两种方法
    • 调用未绑定的父类方法(需要使用父类的名字)
    import random as r
    class Fish:
        def __init__(self):
            self.x = r.randint(1,10)
            self.y = r.randint(1,10)
        def move(self):
            self.x -= 1
            print('我的位置是:',self.x,self.y)
    class Goldfish(Fish):
        pass
    class Carp(Fish):
        pass
    class Shark(Fish):
        def __init__(self):
            self.hungry = True
            Fish.__init__(self)  # 调用未绑定的父类方法
        def eat(self):
            if self.hungry:
                self.hungry = False
                print('吃货的梦想就是天天有的吃!!!')
            else:
                print('太撑了,吃不下了!')
    shark = Shark()
    shark.move() 
    # 执行结果
    我的位置是: 9 6 # move方法调用成功
    
    • 使用super函数(不用给出任何父类的方法)
    import random as r
    
    class Fish:
        def __init__(self):
            self.x = r.randint(1,10)
            self.y = r.randint(1,10)
        def move(self):
            self.x -= 1
            print('我的位置是:',self.x,self.y)
    class Goldfish(Fish):
        pass
    class Carp(Fish):
        pass
    class Shark(Fish):
        def __init__(self):
            self.hungry = True
            super().__init__()  # 使用super
        def eat(self):
            if self.hungry:
                self.hungry = False
                print('吃货的梦想就是天天有的吃!!!')
            else:
                print('太撑了,吃不下了!')
    shark = Shark()
    shark.move() 
    # 执行结果
    我的位置是: 7 5
    
多继承,既可以调用父类1的方法也可以调用父类2的方法
class Base1:
    def foo1(self):
        print('我的foo1,我未Base1代言')
class Base2:
    def foo2(self):
        print('我的foo2,我未Base2代言')
class C(Base1,Base2):
    pass
c = C()
c.foo1()
c.foo2()
# 执行结果
我的foo1,我未Base1代言
我的foo2,我未Base2代言

组合

把类和实例化放到一个新的类里
把没有继承关系的类放到一起
补充:Mix-in

class Trutle:
    def __init__(self,x):
        self.num = x
class Fish:
    def __init__(self,x):
        self.num = x
class Pool:
    def __init__(self,x,y):
        self.trutle = Trutle(x)
        self.fish = Fish(y)
    def print_num(self):
        print('水池总共有乌龟%d只,小鱼%d只' %(self.trutle.num,self.fish.num))
pool = Pool(4,5)
pool.print_num()
# 执行结果
水池总共有乌龟4只,小鱼5只

类、类对象、实例对象

  • 属性的名字跟方法名相同,属性会覆盖方法
  • 不要试图在一个类里面定义出所有能想到的特性和方法,应该利用继承和组合机制来进行扩展
  • 用不同的词性命名,如属性名用名词,方法名用动词

什么是绑定self

Python严格要求方法需要有实例才能被调用,这种限制其实就是Python所谓的绑定概念。

实例化后,即使删除类,原来实例化的对象任然有效

相关文章

  • python面向对象学习笔记-01

    学习笔记 # 0,OOP-Python面向对象 - Python的面向对象 - 面向对象编程 - 基础 -...

  • Python精简入门学习(十四)

    Python精简入门学习之面向对象(oop) -面向对象 -类和对象

  • python学习笔记目录

    Python学习笔记目录(倒序) Python学习-异常 Python学习-面向对象 Python学习-文件系统 ...

  • Python学习-面向对象

    查看所有Python相关学习笔记 面向对象 面向对象知识点汇总: 面向对象静态属性实例属性(self)静态方法(@...

  • Python 面向对象编程

    Python 面向对象编程(一) Python 面向对象编程(一) 虽然Python是解释性语言,但是它是面向对象...

  • 22.Python编程:封装、继承、多态

    前面学习了面向过程和面向对象的概念,又学习了Python中类和对象的相关知识,其中面向对象最大的特征是:封装、继承...

  • python基础-02

    Python 面向对象 python是一门面向对象的语言 Python内置类属性 python对象销毁(垃圾回收)...

  • 王艳华Pythonday03

    Python的面向对象 Java 面向对象 继承

  • Python是一门纯粹的面向对象语言?

    我之前就在学习Python,而Python自己也说了自己是一门纯粹的面向对象语言.包括int类型都是对象.所谓面向...

  • 10.28

    看海量数据处理部分题目 学习python面向对象

网友评论

  • 渔父歌:关于多态我有一些不同的意见,多态应该是C++里的概念,指的是基类的指针可以指向子类,这样函数就可以把不同类型的子类对象作为参数。
    楼主文章里说的和多态不沾边
    而且对 python来说,多态基本没用
    渔父歌:@残阳夕露 建议你1看看c和c++,C语言对学习编程很有帮助
    残阳夕露:谢谢指正,因为没接触过其他语言,python也是刚刚开始学,所以对一些定义的认知度不够,这几天在外地,后面我针对“多态”再去学习下,然后对文章内容进行调整,再次感谢!
  • WeiFong:写的可真多啊,给几个大拇指你:+1: :+1:
    残阳夕露:@WeiFong 主要是代码贴的多,把自己学习时敲的代码都放上去了😀

本文标题:Python学习-面向对象

本文链接:https://www.haomeiwen.com/subject/cxtepftx.html