0
点赞
收藏
分享

微信扫一扫

python学习高级篇(part2)--类方法,静态方法,访问控制

学习笔记,仅供参考,有错必纠

学习资源:图解python


文章目录

  • ​​类方法​​
  • ​​举个例子​​
  • ​​静态方法​​
  • ​​举个例子​​
  • ​​访问控制​​
  • ​​举个例子​​
  • ​​举个例子​​
  • ​​举个例子​​

类方法

类方法指的是类对象中使用装饰器​​@classmethod​​​进行装饰的方法。在类对象中定义类方法时,必须使用装饰器​​@classmethod​​进行装饰,此外,第一个形参表示类对象其对应的实参由系统自动传入。第一个形参的名称通常是​​cls​​​,也可以是其它名称。
类方法可以被类对象所调用,语法格式为:​​类对象.方法名([实参])​​​或​​cls.方法名([实参])​​​。
类方法也可以被实例对象所调用,语法格式为:​​实例对象.方法名([实参])​​​或​​self.方法名([实参])​​​。
类对象的所有实例对象都有一个指向类对象的指针,所以,类对象的所有实例对象都可以调用类对象中定义的类方法。

调用类方法时,系统自动将类对象作为实参传递给第一个形参。第一个实参会传递给第二个形参第二个实参会传递给第三个形参,依次类推。

举个例子

代码:

class MyClass(object):
@classmethod
def cm1(cls, p1, p2):
print(p1, p2)

@classmethod
def cm2(cls):
MyClass.cm1(1, 2)
cls.cm1(1, 2)

def im(self):
self.cm1(1, 2)

MyClass.cm1(1, 2)

mc = MyClass()

mc.cm1(1, 2)
mc.cm2()

mc.im()

输出:

1 2
1 2
1 2
1 2
1 2



静态方法



类对象的静态方法只是一个普通函数。把某个普通函数归属于类对象,可能只是为了易于代码管理
在类对象中定义静态方法时,必须使用装饰器​​​@staticmethod​​​进行装饰。静态方法只是一个普通函数因此,第一个形参没有特殊含义和要求。
静态方法可以被类对象所调用,语法格式为:​​​类对象.方法名([实参])​​​或​​cls.方法名([实参])​​。

静态方法也可以被实例对象所调用,语法格式为:​​实例对象.方法名([实参])​​​或​​self.方法名([实参])​​。

调用静态方法时的参数传递与调用普通函数是一样的。



举个例子



代码:

class MyClass(object):
@staticmethod
def sm(p1, p2):
print(p1, p2)

@classmethod
def cm(cls):
MyClass.sm(1, 2)
cls.sm(1, 2)

def im(self):
self.sm(1, 2)

MyClass.sm(1, 2)

mc = MyClass()

mc.sm(1, 2)

MyClass.cm()
mc.im()

输出:

1 2
1 2
1 2
1 2
1 2



访问控制



访问控制指的是:控制类对象的属性和方法在类对象的外部是否可以直接访问
如果在类对象的某个属性或方法前添加两个下划线​​_​​,那么在类对象的外部就不能直接访问该属性或方法了。



举个例子



代码:

class MyClass(object):
def __init__(self):
self.__pia = 18

def __pim(self):
print("__pim()被调用了")


mc = MyClass()
print(mc.__pia)

输出:

Traceback (most recent call last):
File "fangwenkongzhi.py", line 15, in <module>
print(mc.__pia)
AttributeError: 'MyClass' object has no attribute '__pia'



之所以不能在类对象的外部直接访问以双下划线开头的属性或方法,是因为:Python解释器对外把属性或方法​​__xxx​​​改成了另外一个名字:​​_类名__xxx​​​。所以,在类对象的外部仍然可以通过​​_类名__xxx​​​访问属性或方法​​__xxx​​​。但是,强烈建议不要这样访问,因为不同版本的Python解释器可能会把属性或方法​​__xxx​​改成不同的名字。

同时,仍然可以在类对象的外部动态绑定名为​​__XXX​​​的属性或方法,但是,这与类对象内部名为​​__XXX​​​的属性或方法
是不同的。

举个例子

代码:

class MyClass(object):
def __init__(self):
self.__pia = 18

def __pim(self):
print("__pim()被调用了")

def do_sth(self):
print(self.__pia)
self.__pim()

mc = MyClass()

mc.do_sth()

print(mc._MyClass__pia)
mc._MyClass__pim()
print(dir(mc))


mc.__pia = "Hi"
print(mc.__pia)
print(dir(mc))

输出:

18
__pim()被调用了
18
__pim()被调用了
['_MyClass__pia', '_MyClass__pim', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'do_sth']
Hi
['_MyClass__pia', '_MyClass__pim', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__pia', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'do_sth']



除了在类对象的属性或方法前添加两个下划线​​_​​​,还可以在类对象的属性或方法前添加单下划线​​_​​​,
这表示:虽然可以在类对象的外部访问该属性或方法,但是最好不要访问。

举个例子

代码:

class SomeClass(object):
def __init__(self):
self._pia = 18

def _pim(self):
print("_pim()被调用了")

sc = SomeClass()

print(sc._pia)
sc._pim()

输出:

18
_pim()被调用了

举报

相关推荐

0 条评论