Python【面向对象编程】

#1、python中,类名首字母都大写
#2、在python3中,经典类和新式类没有任何区别
#3、在python2中,经典类和新式类的区别主要体现在多继承上,经典类是深度优先,新式类是广度优先
#4、在python3中,都是广度优先

#定义一个【经典类】
class Japanese:
pass

#定义一个【新式类】
class Chinese(object):
pass


print("=============定义一个类===========")
  1 class Person(object):
  2 
  3     #构造函数:可有可无,不是必须存在的
  4     #在实例化一个类的对象时,自动执行构造函数,不需要我们手动显式的调用构造函数
  5     def __init__(self,skin='white',nose='high',eye='blue'):
  6         self.skin_color = skin
  7         self.nose = nose
  8         self.eye_color = eye
  9         self.__language='english'
 10 
 11     # 析构函数:在实例被销毁的时候自动执行,不需要我们手动调用析构函数
 12     # 析构函数可有可无,不是必须存在的,一般可在该函数中,执行一些关闭数据连接的操作
 13     def __del__(self):
 14         # ..........
 15         # ..........
 16         # ..........     此处省略掉关闭数据库连接的代码行
 17         pass
 18 
 19 
 20     # 类变量:公共的变量,每个实例都可以用
 21     country = 'usa'
 22     #实例变量:比如前面构造函数中的【self.nose】,【self.skin_color】等,可以在所有实例方法中访问,也可以在类外部访问
 23     #私有变量:比如前面构造函数中的【self.__language】,只能在类内部访问,类外部无法访问到,变量名是两个下划线开头命名的
 24 
 25     #实例方法:self代表本类对象
 26     #可以访问类变量和类方法
 27     #可以访问静态方法
 28     #可以访问属性方法
 29     def run(self):
 30         print(self.country)
 31         self.eat_class_1()
 32         self.sleep_static_1()
 33         self.walk_property_1
 34         self.run_1()
 35 
 36 
 37     def run_1(self):
 38         print("实例方法")
 39 
 40     #属性方法:通过实例对象调用,不要通过类进行调用
 41     @property
 42     def walk_property(self):
 43         print(self.country)
 44         self.eat_class_1()
 45         self.sleep_static_1()
 46         self.run_1()
 47         self.walk_property_1
 48 
 49     @property
 50     def walk_property_1(self):
 51         print("属性方法")
 52 
 53     #类方法:
 54     # 1、不用实例化就可以直接调用
 55     # 2、它可以通过cls使用类变量
 56     # 3、它不能调用这个类里面的其他实例方法和实例变量
 57     # 4、可以访问静态方法
 58     # 5、cls代表对的就是Person
 59     @classmethod
 60     def eat_class(cls):
 61         print(cls.country)
 62         cls.sleep_static_1()
 63         cls.walk_property_1
 64         cls.eat_class_1()
 65 
 66 
 67     @classmethod
 68     def eat_class_1(cls):
 69         print('类方法')
 70 
 71     #静态方法
 72     # 1、一个普通函数,只不过是写在类里面而已,它用不了类变量、类方法、实例变量、实例方法、属性方法、静态方法
 73     @staticmethod
 74     def sleep_static():
 75         try:
 76             self.run_1()
 77         except Exception as e:
 78             print(e)
 79         try:
 80             self.walk_property_1
 81         except Exception as e:
 82             print(e)
 83 
 84         try:
 85             self.sleep_static_1()
 86         except Exception as e:
 87             print(e)
 88 
 89         try:
 90             self.eat_class_1()
 91         except Exception as e:
 92             print(e)
 93 
 94     @staticmethod
 95     def sleep_static_1():
 96         print('这个是静态方法,它和一个没写在类里面的函数一样')
 97 
 98     #私有方法:只能在类内部访问,类外部无法访问到,方法名是两个下划线开头命名的
 99     def __speak(self):
100         print ("这是个私有方法")
101 
102     #实例方法:方法名是一个下划线开头命名的
103     def _shopping(self):
104         self._flower = "rose"
105         print("方法名一个下划线开头的实例方法")
106 
107     def tool(self):
108         print(self.__language)
109         return self.__speak()

print("==========修改类变量===========")

 1 #实例化两个美国人
 2 p = Person()
 3 p1 = Person()
 4 
 5 p.country='USA'
 6 #Person.country = 'USA'
 7 print("p.........:",p.country)
 8 print('p1.......',p1.country)
 9 print('Person.......',Person.country)
10 #结论:p.country='USA'和Person.country = 'USA'两种赋值方式有区别:
11 #1、通过Person.country = 'USA'这种方式给【country】类变量赋值,则:Person.country、p.country、p1.country 三个的值都是USA,
12     #说明影响的是类的所有实例以及类本身
13 #2、通过p.country='USA'这种方式给【country】类变量赋值,则:p.country的值是USA,而Person.country和p1.country的值是空,
14     #说明影响的是当前实例,并不会影响其他实例和类本身

print("========通过实例调用四种不同类型的方法=========")
1 print(p.walk_property)          #通过实例调用属性方法:正确
2 print(p.eat_class())            #通过实例调用类方法:正确
3 print(p.sleep_static())         #通过实例调用静态方法:正确
4 print(p.run())                  #通过实例调用实例方法:正确
5 print(p._shopping())            #通过实例调用一个下划线开头的实例方法:正确
6 print(p._flower)                #通过实例调用一个下划线开头的成员变量:正确
7 
8 print(p.tool())                 #通过tool()方法间接调用私有方法和私有变量

print("========通过类调用四种不同类型的方法========")
1 print(Person.walk_property)     #通过类调用属性方法:错误
2 print(Person.eat_class())       #通过类调用类方法:正确
3 print(Person.sleep_static())    #通过类调用静态方法:正确
4 #print(Person.run())            #通过类调用实例方法:错误

print("=======类的继承==========")
 1 #支持多继承,比如class Japanese(Person,XXX,XX)
 2 class Japanese(Person):
 3     def play(self):
 4         print("我是一个子类")
 5 
 6     #重写父类方法
 7     def run(self):
 8         # 调用父类方法
 9         Person().run()
10 
11         #如果继承多个父类,super会根据继承的父类顺序,从左至右依次去找每一个父类,如果在某个父类中找到该方法,则停止寻找,
12         #直接实例化一个第一次找到的那个父类的对象,然后再调用父类的方法
13         super(Japanese, self).run()
14         print("重写父类方法")
15 
16 j1 = Japanese(nose='flat',skin='yellow',eye='black')
17 j2 = Japanese()
18 Japanese.country='Japan'
19 print('Japanese.......',Japanese.country)
20 print('j1........',j1.country)
21 print('j2........',j2.country)

# if __name__ == '__main__':
# 1、判断python文件是在别的地方导入的,还是直接运行的这个python文件
# 2、这句话一般是做调试的时候用的。
# 3、如果是直接运行这个python文件的时候,这句话一点用都没有















原文地址:https://www.cnblogs.com/mtszw/p/9087559.html