https://www.yuque.com/docs/share/0b3bac66-aa8c-4143-aaa9-0955f609dcb9?# 《Python学习笔记2》https://www.yuque.com/docs/share/0b3bac66-aa8c-4143-aaa9-0955f609dcb9?#%20%E3%80%8APython%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B02%E3%80%8B里面链接是我假期的Python学习笔记,想了解的伙伴可以点进去查看,下面的知识点是其中的一小部分,编程思想
8.1两大编程思想
面向过程 | 面向对象 | |
区别 | 事物比较简单,可以用线性 的思维去解决 | 事物比较复杂,使用简单的线性思维无法解决 |
共同点 | 面向过程和面向对象都是解决实际问题的一种思维方式 | |
两者相辅相成,并不是对立的 解决复杂问题,通过面向对象方式便于我们从宏观上把握事物之间复杂的关系,方便我们分析 整个系统,具体到微观操作,仍然使用面向过程方式来处理 |
8.2类与对象的创建
类别,分门别类,物以类聚,人类,鸟类,动物类,植物类....
类是多个类似事物组成的群体的统称。能够帮助我们快速理解和判断事物
1.数据类型
不同的数据类型属于不同的类
使用内置函数查看数据类型
2.对象
100,99,520都是int类之下包含的相似的不同个例,这个个例专业数语称之为实例或对象
1.类的创建
- 创建类的语法
lass Student:
pass
- 类的组成
类属性 实例方法 静态方法 类方法
class Student:
passprint(type(Student),id(Student))print(Student)
Student为类的名称(类名)由一个或多个单词组成,每个单词的首字母大写,其余小写
直接写在类里的变量,称之为类属性
实例方法
def eat(self):
print("学生在吃饭")
静态方法
@staticmethoddef method():
print("staticmethod进行修饰为静态方法,不能使用self")
在类之外定义的称之为函数,在类之内定义的称之为方法
静态方法进行修饰,不能使用self
类方法
@classmethoddef cm(cls):
print("classmethod进行修饰为类方法,使用cls")
Init初始化方法
def __init__(self,name,age):
self.name=name
self.age=age
Self.name称之为实体属性,进行了一个赋值操作,将局部变量的name的值赋给实体变量
2.对象的创建
对象的创建又称为类的实例化
语法:
实例名=类名()
举例:Stu=Student()
意义:有了实例,就可以调用类中的内容
class Student:
native_pace='吉林'
def __init__(self,name,age):
self.name=name
self.age=age
stu1=Student("张三",20)print("实例对象",id(stu1))print(type(stu1))print(stu1)print("--------")print("类对象",id(Student))print(type(Student))print(Student)
8.3动态绑定属性和方法
Python是动态语言,在创建对象之后,可以动态地绑定属性和方法
一个Student类可以创建多个Student类的实例对象,每个实体对象的属性值不同
class Student:
native_pace='吉林'
def __init__(self,name,age):
self.name= name
self.age=age
def eat(self):
print(self.name+"在吃饭")
stu1=Student("张三",20)
stu2=Student("李四",30)print(id(stu1))print(id(stu2))print("只为为stu2动态绑定性别")
stu2.gender="女"print(stu2.name,stu2.age,stu2.gender)print(stu1.name,stu1.age)
stu1.eat()
stu2.eat()def show():
print("定义在类之外,称函数")
stu1.show=showprint("绑定在对象之后就成为show方法")
stu1.show()
8.4类属性、类方法、静态方法
类属性:类中方法外的变量称之为类属性,被该类的所有对象所共享
类方法:使用@classmethod修饰的方法,使用类名直接访问的方法
静态方法:使用@staticmethod修饰的主法,使用类名直接访问的方法
Print(Student.native_place) #访问类属性
Student.cm() #调用类方法
Student.sm() #调用静态方法
class Student:
native_pace='吉林'
def __init__(self, name, age):
self.name = name
self.age = age
stu1=Student("张三",20)
stu2=Student("李四",30)print(stu1.native_pace)print(stu2.native_pace)
Student.native_pace="天津"print(stu1.native_pace)print(stu2.native_pace)
class Student:
native_pace='吉林'
@classmethod
def cm(cls):
print("classmethod进行修饰为类方法,使用cls")
@staticmethod
def method():
print("staticmethod进行修饰为静态方法,不能使用self")
Student.cm()
Student.method()
8.5面向对象的三大属性
8.5.1封装
封装:提高程序的安全性
将数据(属性)和行为(方法)包装到类对象中。在方法内部对属性进行操作,在类对象的外部调用方法。这样,无需关心方法内部的具体实现细节,从而隔离了复杂度
在python中没有专门的修饰符用于属性的私有,如果改属性不希望在类对象外部被访问,前面使用两个“_”
继承:提高代码的复用性
多态:提高代码的可扩展性和可维护性
class Car:
def __init__(self,brand):
self.brand=brand
def start(self):
print("汽车已启动")
car=Car("宝马X5")
car.start()print(car.brand)
年龄不希望在类的外部被调用,所有使用两个“_”
在类的外部可以通过_Student__age进行访问
class Student:
def __init__(self,name,age):
self.name=name
self.__age=age
def show(self):
print(self.name,self.__age)
stu=Student("张三",20)
stu.show()print(stu.name)#print(dir())
#print(stu._Student__age)
8.5.2继承
语法格式:
class 字典类名(父级1,父级2):
pass
如果一个类都没有继承任何类,则默认继承object
Python支持多继承
定义子集时,必须在其构造函数中调用父类的构造函数
class Person(object):
def __init__(self,name,age):
self.name=name
self.age=age
def info(self):
print(self.name,self.age)class Student(Person):
def __init__(self,name,age,stu_no):
super().__init__(name,age)
self.stu_no=stu_noclass Teacher(Person):
def __init__(self,name,age,teachofyear):
super().__init__(name,age)
self.teachofyear=teachofyear
stu=Student("张三",20,"1001")
teacher=Teacher("李四",34,10)
stu.info()
teacher.info()
多继承
class A(object):
pass
class B(object):
pass
class C(A,B):
pass
8.5.3方法重写
如果子类对继承自父类的某个属性或方法不满意,可以在子类中对其(方法体)进行重新编写
子类重写后的方法中可以通过super().XXX()调用父类中被重写的方法
class Person(object):
def __init__(self,name,age):
self.name=name
self.age=age
def info(self):
print(self.name,self.age)class Student(Person): #继承
def __init__(self,name,age,stu_no):
super().__init__(name,age)
self.stu_no=stu_no
def info(self):
super().info()
print("学号",self.stu_no)class Teacher(Person):
def __init__(self,name,age,teachofyear):
super().__init__(name,age)
self.teachofyear=teachofyear
def info(self):
super().info()
print("教龄:",self.teachofyear)
stu=Student("张三",20,"1001")
teacher=Teacher("李四",34,10)
stu.info()print("-------")
teacher.info()
8.5.4 object类
(1)object类是所有类的父亲,因此所有类都有object类的属性和方法
(2)内置函数dir()可以查看指定对象所有属性
(3)Object有一个__str__()方法,用于返回一个对于“对象的描述”,对应于内置函数str()
经常用于print()方法,帮我们查看对象的信息,所以我们经常会对__str__()进行重写
class Student:
def __init__(self,name,age):
self.name=name
self.age=age
def __str__(self):
return "我的名字是{0},今年{1}岁".format(self.name,self.age)
stu=Student("张三",20)print(dir(stu))print(stu)print(type(stu))
8.5.5多态
简单地说,多态就是“具有多种形态”,它指的是:即便不知道一个变量所引用的对象到底是什么类型,仍然可以通过这个变量调用方法,在运行过程中根据变量所引用对象的类型,动态决定调用哪个对象中的方法
class Animal:
def eat(self):
print("动物会吃")class Dog(Animal):
def eat(self):
print("狗吃骨头")class Cat(Animal):
def eat(self):
print("猫吃鱼")class Peason():
def eat(self):
print("人吃五谷杂粮")#定义一个函数def fun(obj):
obj.eat()#开始调用函数fun(Cat())
fun(Dog())
fun(Animal())print("----------")
fun(Peason())
附:静态语言和动态语言
静态语言和动态语言关于多态的区别
静态语言实现多态的三个必要条件
继承,方法重写,父类引用指向子类对象
8.5.6特殊方法和特殊属性
名称 | 描述 | |
特殊属性 | __dict__ | 获得类对象或实例对象所绑定的所有属性和方法的字典 |
特殊方法 | __len__() | 通过重写__len__()方法,让内置函数len()的参数可以 是自定义类型 |
__add__() | 通过重写__add__()方法,可使自定义对象具有“+”功能 | |
__new__() | 用于创建对象 | |
__init__() | 对创建的对象进行初始化 |
print(dir(object))class A:
pass
class B:
pass
class C(B,A):
def __init__(self,name,age):
self.name=name
self.age=ageclass D(A):
passx=C("jack",20)#x是c类型的实例类型print("实例对象的属性字典",x.__dict__) #print("类对象的属性内容",C.__dict__)print("---------------—-----")print("输出了对象所属的类",x.__class__)print("C类父类类型的元素",C.__bases__)print("定义时C类型最近的父级元素",C.__base__)print("类的层次结构",C.__mro__)print("子类列表",A.__subclasses__())
特殊方法__add__()
a=20b=100c=a+b
d=a.__add__(b)print(c)print(d)
class Student:
def __init__(self,name):
self.name=name
def __add__(self, other):
return self.name+other.name
stu1=Student("张三")
stu2=Student("李四")
s=stu1+stu2print("两个对象相加方法一",s)
s=stu1.__add__(stu2)print("两个对象相加方法二",s)
特殊方法__len__()
class Student:
def __init__(self,name):
self.name=name
def __len__(self):
return len(self.name)
stu1=Student("Python")print("stu1()中Python的长度",len(stu1))
lst=[11,22,33,44]print("列表的长度",len(lst))print("len是内置函数len")print("列表的长度",lst.__len__())
特殊方法__new__()特殊方法__init__()
class Person(object):
def __init__(self,name,age):
self.name=name
self.age=age
def __new__(cls, *args, **kwargs):
print("__new__被调用执行了,cls的id值为:{0}".format(id(cls)))
obj=super().__new__(cls)
print("创建的对象的id为{0}".format(id(obj)))
return obj
def __init__(self,name,age):
print("__init__被调用了,self的id值为:{0}".format(id(self)))
self.name=name
self.age=ageprint("object这个类对象的id值为:{0}".format(id(object)))print("Person这个类对象的id值为:{0}".format(id(Person)))
p1=Person("张三",20)print("p1这个Person类的实例对象的id:".format(id(p1)))