一.对象独有的名称空间
在产生对象时就赋初值
class Student:
def __init__(self,name,sex):
self.name = name
self.sex = sex # 通常建议参数名与新增属性同名
stu = Student('Bob','male') # 实例化对象
print(stu。name,stu.sex)
1.__init__方法会在实例化对象时被调用
2.会将实例化的对象形成空的名称空间
3.方法可以被传参,在 类名(实参)方式下调用并传参__init__(self,形参)
4.第一个self就是要产生的当前对象
重点:在方法内部,形参拿到了实参值,利用self.属性名 = 形参 =实参值,对对象的名称空间添加属性
二.类中方法的第一个默认参数(对象方法)
class A:
#对象方法
def test(self,num):
pass
a = A()
实现原理
A.__dict__['test'](a,10)
一级优化
A.test(a,10)
二级优化
a.test(10)
总结:对象a传递给self,数字10传递给num
重点:方法的第一个参数一定是调用该方法的对象
三.类中@classmethod修饰的方法:类方法
class Tool:
@classmethod
def add(cls,n1,n2): # 统一类与对象都可以调用类方法,一定有默认传入的第一个参数
return n1 + n2
Tool.add(10,20) # 默认第一个传入自身 -TOOL 建议使用
tool = Tool()
tool.add(100,200) # 默认第一个传入自身所属类-toll.__class__ 不建议使用
总结:
class OldBoy:
# 属于类的属性
name = '老男孩' # 属于对象的属性
def __init__(self, name):
self.name = name # 属于类的方法
# 需求:获取机构的名字
@classmethod
def get_class_name(cls):
return cls.name # 属于对象的方法
# 需求:获取校区的名字
def get_school_name(self):
return self.name # 先创建校区
shanghai = OldBoy('上海校区')
shenzhen = OldBoy('深圳校区') # 类方法的使用
# 建议使用类调用
print(OldBoy.get_class_name())
# 类方法拿对象调用并没有多少新增的意义,不建议拿对象调用
print(shanghai.get_class_name())
print(shenzhen.get_class_name()) # 对象方法的使用
# 类调用对象方法,必须把要操作的对象手动传入,不建议使用
print(OldBoy.get_school_name(shanghai))
print(OldBoy.get_school_name(shenzhen))
# 对象调用对象方法,默认将自身传入,建议使用
print(shanghai.get_school_name())
print(shenzhen.get_school_name())
四.封装
封装:对外隐藏类中一些属性和方法的实现细节
优点:外界不能直接访问,让内部的属性与方法具有安全保障
语法:
class A:
# 类的属性:__开头的属性,在外界不能通过cord|__cord直接访问,对外隐藏
__cord = '123456'
# 类的方法:__开头的方法,在外界不能通过get_money|__get_money直接访问,对外隐藏
@classmethod
def __get_money(cls):
print('输入密码,取出钱')
#对象的方法:一般的实现需求都是,这些方法只在内部使用
def __test(self):
pass
对象的属性:封装目的
1.对象的属性值一般都来源于外界,外界是有权利再次访问的
2.封装的目的不是让外界无法访问,而是不能直接访问,可以在完成安全处理后访问
3.如何做到外界还是通过变量名来对属性进行取值赋值,但是是走的方法间接拿到的值
# __money被封装,外界还是可以通过 对象.money直接取值
def __init__(self,money):
self.__money = money
#取值
@property # 在外界可以通过 对象.money进行取值
def money(self):
return self.__money
#赋值
@money.setter # 在外界可以通过 对象.money = 新值 进行赋值
def money(self,money):
self.__money = money
#删除
@money.deleter
def money(self):
del self.__money