-
面向对象和面向过程
面向过程:以吃饭为例,即为 煮饭、洗菜、洗碗、切菜、炒菜、出锅、吃饭
面向对象:目标对象做完,直接吃
疑问点:1、面向对象就是把过程用函数封装起来,随时调用?;2、面向过程就是每次都把逻辑程序再走一遍?【初次接触,仅了解,上述疑问有待考证】
-
类
如果定义一个类
class 类名(首字母大写):
代码块(类属性定义)
举个栗子:
class MyFruit :
name = '疏楼龙宿'
age = 31
这就是一个类 -
调用类
第一种方法是:类名.属性,即MyFruit.name,需要print;
第二种方法是:
实例化
f = MyFruit()
f.name
f.age 同样需要print
-
属性概念和私有属性
类中的定义变量即为属性,该例子中的name、age即为属性
私有属性是在变量名前面有下划线的(分一个下划线和两个下划线)
class Person:
name = '疏楼龙宿'
_age = 31
__money = 10000区别:
print(Person.name) #普通属性
print(Person._age) #前面有一个下划线,可以直接调用,和普通属性区别不大
print(Person._Person__money) #私有属性加强版,前面两个下划线,需要单下划线加类名加私有属性来使用 -
方法
即封装在类中的函数
举个栗子:
class Student:
name = 'xxxx'
def study(self):
print('%s真帅'%(self.name))该类中的函数即是称作方法,最后是print还是return没有区别
-
方法的调用
通过实例化来调用
a = Student()
a.study() -
关于方法中的self参数
谁调用了该方法,这个self就是哪个值self.name即这个值就是name的值,如果全局变量没有,就去类中寻找默认值(局部变量)【与函数的相反】
举个栗子:
longshou = Student()
longshou.name = '疏楼龙宿'
longshou.study()self所在的study函数被longshou调用,那么'self'就是'longshou',可见上述方法中的‘self.name’即为 ‘longshou.name’,全局变量中又有定义longshou.name = '疏楼龙宿',所以,按照格式化的规则传入该值
-
魔法方法__init__(双下划线)
意思是初始化,其作用其实是赋值,即在类下面定义一个魔法方法,然后如果在实例化的同时,类的()被传入了值,就会自动运行__init__方法处理,然后运行其他方法得出结果
举个栗子:
class Student:
name = 'xxxx'
def __init__(self,name,age):
self.name = name
self.age = age
def study(self):
print('%s已经%d岁了,但仍然是人间至帅'%(self.name,self.age))
#=============假装自己是封装线?=================
s = Student('疏楼龙宿',31)
s.study()解释该代码块:
在实例化该类的同时,传入“疏楼龙宿”和31两个值,符合触发__init__方法的条件,__init__方法开始运行,处理这两个参数,分别赋值,然后运行下一步的study方法,并提供刚刚赋值的结果。可以视作__init__的作用就是定义class的属性
-
析构
li = [1,2,3,4,5]
del li
print(li) #报错
pop、clear remove等是删除元素,del是删除列表指向,即内存中列表本身,或者说是取消列表定义
del其实就是调取的‘ __del__’魔法方法
class MyFriend:
pass
longshou = MyFriend()
print(longshou) #输出是个内存地址
del longshou
print(longshou) #报错
class MyFriend:
def __del__(self):
print("人间至帅-疏楼龙宿")
longshou = MyFriend() #实例化
print(111111)
del longshou #删除该实例化的时候,会触发__del__方法,输出“人间至帅-疏楼龙宿”
print(22222)
当某个类中有__del__方法的时候,在py文件执行结束后,会自动触发。
del是将该内存解放掉