• 9.面向对象:类和对象、实例变量、类变量



    类和对象:

    • 类的定义:用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。
    • 类的优势:将一个对象的功能集中于一体,便于操作,降低了代码的重复。
    • 实例化:创建一个类的实例,类的具体对象。
    • 对象:通过类定义的数据结构实例。对象包括两个数据成员(类变量和实例变量)和方法。

    使用 class 语句来创建一个新类:

    class Dog:
        #self 代表的是类的实例,代表当前对象的地址
        def __init__(self,name):##称为类的构造函数,进行初始化成员变量
            self.name=name
        def bulk(self):###自定义函数
            print("%s:汪汪!"%self.name)
    
    d1=Dog("奥巴马")##创建对象,传入__init__所需的变量,self默认自动传入
    
    d1.bulk()#调用方法
    print(d1)

    为什么要有self:

    以类变量和实例变量为解释,对于共有属性,一般会在共有部分定义,不需要__init__,而比如说因为人人都有自己的名字,那么名字应该是一个人私有的。而类的函数由于为了节约资源,并不会拷贝给每一个对象,每一个对象都要从类的定义区中调用方法,对于涉及对象特有属性的方法,调用方法的时候必须传入自身对象self才能使函数获得私有的数据,而调用这个私有的数据使用”self.变量名”.

    image

    附:

    什么是新式类:https://www.cnblogs.com/wenbronk/p/7141224.html


    实例变量和类变量:

    • 实例变量是对于每个实例都独有的数据,而类变量是该类所有实例共享的数据
    • 变量使用的顺序是:实例变量--》类变量,如果实例变量中没有才会去类变量中找
    • 但即使是类中的变量,也是需要使用self.变量名来使用
    class Dog:
        age=8
        def __init__(self,name):
            self.name=name
        def bulk(self):
            print("汪汪")
    
    d1=Dog("包子")
    d2=Dog("馒头")
    d1.age=10
    print("Dog:",Dog.age,"	D1:",d1.age,"	D2:",d2.age)
    
    
    -------------------------
    结果:
    Dog: 8     D1: 10     D2: 8
    • 节约论:python为了简洁性,不会复制一份类的数据给每一个对象,每一个对象之后存有其特有的属性,当其需要使用属性或方法时,先看自己有没有,如果没有再去类中找


    类变量的创建:

    • 可以在声明类的时候定义

    image

    • 也可以使用赋值来定义:

    image

    image


    实例变量的创建:

    • 可以在__init__中定义

    image

    • 也可以使用赋值来定义:

    image


  • 相关阅读:
    oracle 用户与表空间关系
    关于数据库主从表、主键PRIMARY KEY 外键约束 FOREIGN KEY 约束----NOT NULL,DEFAULT,CHECK
    数据库中主键与外键
    MySQL性能测试工具sysbench的安装和使用
    Linux VNC server 安装配置
    Linux 用户管理【UID和GID】
    性能测试之稳定性测试
    NoSql Cassandra
    数据库事务处理原理
    思考问题
  • 原文地址:https://www.cnblogs.com/progor/p/8419345.html
Copyright © 2020-2023  润新知