python中的class(类)

 

编码注释:
在源文件的第一行或第二行写入如下内容:
  # -*- coding:gbk -*-
  # 设置源文件编码格式为:gbk

  # -*- coding:utf-8 -*-
  # 设置源文件编码格式为:UTF-8

 

面向对象编程:
  什么是对象:
     一切皆对象(实例)

类型   对象(实例)
车   --> 车牌号(京P88888) 实例
画   --> 蒙娜丽莎(实例), ....

面向对象是指用类来描述一个对象(实例),用类来建立实例与实例的关联关系
对象 : object
实例 : instance


类 : class

作用:
  用来描述对象
  用来创建对象

类的创建语法:
  class 类名(继承列表):
     "类文档字符串"
     实例方法(类内的函数methed)定义
     类变量定义
     类方法(@classmethod)定义
     静态方法(@staticmethod)定义

最简单类的定义的示例:
  # 定义一个类
  class Dog:
      pass
  # 创建一个Dog实例
  dog1 = Dog()
  dog2 = Dog()
  # 同list
  L = list()  # L是list类的一个对象(实例)
  L2 = list()
  L3 = list(range(10))

类的创建语法说明:
  类名必须是标识符
  类名实质上是变量,它绑定一个类
  类的定义的前后要加两个空行以告诉解释执行器,类的定义已经开始和结束

实例创建表达式:
  类名([创建传参列表])
作用:
  创建一个类的实例对象并返回此实例的引用关系

实例说明:
  实例有自己的作用域和名字空间,可以为该实例添加变量(实例变量/属性)
  实例可以调用类中的方法
  实例可以访问类中的类变量

实例变量:
  在python程序中,每个实例可以有自己的变量,每个实例变量有自己独立的作用域

实例变量的调用语法:
  实例.变量名

实例变量的赋值规则:
  首次为实例变量赋值则创建此实例变量
  再次为实例变量赋值则改变变量的绑定关系

示例见:

 1 # dog.py
 2 
 3 
 4 class Dog:
 5     """这是一个小狗的类
 6 
 7     此类用来创建小狗的实例
 8     """
 9     pass
10 
11 
12 dog1 = Dog()
13 dog1.kinds = "京巴"  # 为实例添加 kinds 属性
14 dog1.color = "白色"
15 
16 dog2 = Dog()
17 dog2.kinds = "藏獒"
18 dog2.color = "棕色"
19 
20 print("dog1的属性:", dog1.kinds, dog1.color)
21 print("dog2的属性:", dog2.kinds, dog2.color)

 

实例方法:
语法:
  class 类名(继承列表):
      def 实例方法名(self, 参数1, 参数2, ...):
          "实例方法的文档字符串"
          语句块

实例方法说明:
  实例方法的实质就是函数,是定义在类内的函数
  实例方法属于类的属性
  实例方法的第一个参数代表调用这个方法的实例,一般命名为: "self"
  实例方法如果没有return 语句则返回None

调用语法:
  实例.实例方法名(调用参数)
  或
  类名.实例方法名(实例, 调用参数)

示例见:

  

# instance_method.py
class Dog:
    def say(self):
        """这是小狗的沟通方法"""
        print("旺!")
        print("self.kinds=", self.kinds)


dog1 = Dog()

dog1.kinds = "京巴"
# 调用方法1
dog1.say()

dog2 = Dog()
# 下一行出错,因为 第8行 self绑定的
# 对象没有kinds实例变量
dog2.say()

 


  和
  

# instance_method.py
class Dog:
    def say(self):
        """这是小狗的沟通方法"""
        print("旺!")

    def eat(self, that):
        "为狗进食,同时在狗的food属性里记住吃的是什么"
        print("小狗正在吃", that, "旺!...")
        self.food = that

    def food_info(self):
        "显示狗的进食信息"
        print("小狗刚吃过的是:", self.food)

dog1 = Dog()
# 调用方法1
dog1.say()
# 调用方法2
Dog.say(dog1)


dog2 = Dog()

dog1.eat("骨头")
dog2.eat("窝头")

# print("小狗1吃的是", dog1.food)
# print("小狗2吃的是", dog2.food)

dog1.food_info()
r = dog1.food_info()
print(r)

class MyList:
    def append(obj):
        # 把obj放在某个容器的尾部
        return None

 

 

构造方法(也叫初始化方法)
作用:
  创建对象,初始化实例变量

构造方法的语法格式:
  class 类名(继承列表):
      def __init__(self [, 参数列表]):
          语句块
  [] 代表可省略
说明:
  1. 构造 方法名必须是: __init__ 不可改变
  2. 在一个类内只能有一个__init__构造方法起作用
  3. 构造方法会在实例生成时自动调用,且将实例自身通过第一个参数self传入__init__方法
  4. 构造方法内如果需要return语句返回,则只能返回None

 1 class Car:
 2     def __init__(self, c, b, m):
 3         "这是构造方法"
 4         print("__init__被调用!")
 5         self.color, self.brand, self.model = c, b, m
 6 
 7     def run(self, speed):
 8         print(self.color, "", self.brand,
 9               self.model, "正在以", speed,
10               "公里/小时的速度驶")
11 
12     def change_color(self, c):
13         "此方法用来改变颜色"
14         self.color = c  # 换色
15 
16 
17 a4 = Car("红色", "奥迪", "A4")
18 
19 a4.run(199)
20 a4.change_color("黑色")  # 推荐
21 # a4.color = "银色"  # 不推荐
22 a4.run(233)
23 
24 ts = Car("蓝色", "Tesla", "S")
25 ts.run(300)

 

 


析构方法:
语法格式 :
  class 类名(继承列表):
      def __del__(self):
          语句块
说明:
  析构方法在对象被销毁时被自动调用
注:
  python语言建议不要在对象销毁时做任何事情,因为销毁的时间难以确定


预置实例属性:
  __dict__属性:
    通常每个对象(实例)都有一个__dict__属性
    __dict__属性绑定一个存储此实例自身变量的字典

例:
  class Dog:
       pass
  dog1 = Dog()
  print(dog1.__dict__)

__doc__属性:
  记录文件字符串, 用于help帮助
  此文件字符串与类的文档字符串相同


__class__属性
  用于绑定创建此实例的类对象(类实例)

作用:
  可以借助此属性来创建同类对象
  可以借助此属性来访问类对象(类实例)
示例:
  class Dog:
     pass
  dog1 = Dog()
  dog2 = dog1.__class__()  # 创建dog2

类变量
  1. 是指在类class 内定义的变量,此变量属于类,不属于此类的实例
  2. 类变量可以通过该类直接访问
  3. 类变量可以通过类的实例直接访问
  4. 类变量可以通过此类的对象的__class__属性间接访问

语法:
  class 类名(继承列表):
      变量名 = 表达式
      ....

示例:
  class Human:  # 人类
      home = "地球"  # 类变量

  print(Human.home)  #  home 属于  Human类变量

 

类的 __slots__ 列表属性
作用:
  限定一个类创建的实例只能有固定的实例属性
  不允许对象添加列表以外的实例属性(变量)
  防止用户因错写属性的名称而发生程序错误!

说明:
   __slots__属性是一个列表,列表的值是字符串
   含有__slots__ 属性的类所创建的实例对象没有
     __dict__属性,即此实例不用字典来存储属性

示例:
  class Student:
     # __slots__ = ["name", "age", "score"]
     def __init__(self, n, a, s):
         self.name = n
         self.age = a
         self.score = s
         self.scros = s  # 错,因为scros不在列表里


  s1 = Student("李四", 21, 100)
  s1.name = "张三"
  s1.abcd = 10000  # 出错


对象的属性管理函数
  1. getattr(obj, name[, default])  从一个对象得到对象的属性; getattr(x, 'y') 等同于x.y,当属性不存在时,如果给出default参数,则返回default,如果没有给出default则生一个AttributeError错误
  2. hasattr(obj, name) 用给定的name返回对象obj是否有此属性,此种做法可以避免在getattr(obj, name)时引发错误
  3. setattr(obj, name, value) 给对象obj的名为name的属性设置相应的值value; set(x, 'y', v)  等同于 x.y = v
  4. delattr(obj, name) 删除 对象的obj中的name属性, delattr(x, 'y') 等同于 del x.y


用于类的函数:
  isinstance(obj, 类或元组) 返回这个对象obj是否是某个(或某些)类的对象,如果是则返回True, 否则返回False
  type(obj)  返回对象的类型


类方法 @classmethod
    类方法是只能访问类变量的方法
    类方法需要使用@classmethod装饰器定义
    类方法的第一个参数是类实例, 约定写为 cls
说明:
  类实例的对象实例都可以调用类方法
  类方法不能访问实例变量

示例:
  class Human:
      home = "地球"

      @classmethod
      def set_home(cls, h):
          cls.home = h
          print("欢迎来到", cls.home)


静态方法 @staticmethod
  静态方法是普通的函数
  静态方法定义在类的内部,只能凭借该类的实例访问
  静态方法需要使用@staticmethod装饰器定义
  静态方法与普通函数定义相同,不需要传入self和cls参数

说明:
  类实例和对象实例都可以调用静态方法
  静态方法不能访问类变量和实例变量

示例:
  

# 静态方法示例
class A:
    @staticmethod
    def myadd(a, b):
        return a + b

print(A.myadd(100, 200))
a = A()
print(a.myadd(3, 4))

 

实例方法、类方法、静态方法、函数 总结
  不想访问类变量和实例变量,可以用静态方法
  只想访问类内变量,不想访问实例变量用类方法
  即想访问类变量,也想访问实例变量用实例方法
  函数与静态方法相同,只是静态方法的作用域定义在类内

 

posted @ 2018-04-12 23:21  韩男神  阅读(14963)  评论(0编辑  收藏  举报