python------面向对象进阶

Posted bltstop

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python------面向对象进阶相关的知识,希望对你有一定的参考价值。

*面向对象高级语法部分   (不常用,了解)
静态方法、类方法、属性方法
类的特殊方法
反射
*异常处理
*Socket开发基础

一.面向对象高级语法部分
1.静态方法
@staticmethod
只是名义上归类管理,实际上在静态方法里访问不了类或者实例中的任何属性。
class Dog(object):
def __init__(self,name):
self.name = name

@staticmethod #实际上跟类没有什么关系了,也不用self.的属性。非要用的话,
#就不传d.eat = ("包子"),而是传对象d.eat = (d),既然人家称为静态了,
#就不要用self的方式。 不常用
def eat(self,food):
print("%s is eating %s" %(self.name,food))

d = Dog("xaiznlaizi")
d.eat = (d)

2.类方法
@classmethod
类方法只能访问类变量,不能访问实例变量。(不常用)3.属性方法


@property


把一个方法变成一个静态属性。

class Dog(object):

def __init__(self, name):
self.name = name

@property # 属性方法不能传参数
def eat(self):
print("%s is eating %s" % (self.name, "包子"))

@eat.setter # 只能通过给属性赋值。
def eat(self, food):
print("set to food:", food)

@eat.setter # 删除属性

def eat(self):
del self.__food
print("删完了")


d = Dog("xiaolaizi")
d.eat

4.
类的特殊方法(成员)

1)__doc__: 查看描述文档
2)__module__: 查看当前操作的对象在哪个模块
__class__: 查看当前操作的对象的类是什么
3)__init__: 构造方法,通过类创建对象时,自动触发执行
4)__del__: 析构方法,当对象在内存中被释放时,自动触发执行。
注: 此方法一般无须定义,python是一门高级语言,程序员在使用时无须关心内存的分配和释放
因为此工作都是交给python解释器来执行的,所以,析构函数的调用是由解释器在进行垃圾回收时
自动触发执行的。
5)__call__: 对象后面加括号,触发执行
注:构造方法的执行时由创建对象触发的,即:对象 = 类名();
而对于__call__方法的执行
是由对象后面加括号触发的,即:对象()
或者
类()()
6)__dict__: 查看类或对象中的所有成员。

类.__dict__: 打印类里的所有属性,不包括实例属性
对象.__dict__: 打印实例属性,不包括类的属性。
7)__str__: 如果一个类中定义了__str__方法,那么在打印对象时,默认输出该方法的返回值。
8)__getitem__ / __setitem__ / __delitem__: 用于索引操作,如字典。以上分别表示获取、设置、删除数据。
9)__new__ / __metaclass__:


class Foo(object):
def __init__(self, name):
self.name = name


f = Foo("xiaolaizi")
上述代码中,f是通过Foo实例化的对象,其实,不仅f是一个对象,Foo类本身也是一个对象,因为在Python中
一切事物都是对象, 那么问题来了:Foo对象后的类又是谁呢???(生命的本源)

class Foo(object):
def __init__(self,name):
self.name = name

f = Foo("xiaolaizi")
print(type(f))
print(type(Foo))

运行结果:

<class ‘__main__.Foo‘>    #ojb对象由Foo类创建
<class ‘type‘>            #Foo类由type类创建

那么,创建类就有两种方式:

1)普通方式:(我们经常用的就是)

1 class Foo(object):
2     def __init__(self,name):
3         self.name = name
4         print("name : %s" ,%self.name)
5 
6 f = Foo("xiaolaizi")

2)特殊方式:

 

1 def func(self):
2     print("Hello xiaolaizi")
3 
4 Foo = type(Foo,(),{talk: func})   
5 f = Foo()
6 f.talk()
7 
8 print(type(Foo))

技术分享图片

所以:类是由type类实例化产生。

def func(self):
    print("Hello xiaolaizi")
def __init__(self,name,age):
    self.name  = name
    self.age = age

Foo = type(‘Foo‘,(object,),{‘talk‘: func,‘__init__‘:__init__})  #(object,)加个逗号,认为是元组。
f = Foo("zahngsan",23)
f.talk()

print(type(Foo))         #注:这种我们基本不会用到(了解)。

  那么,type类中如何实现的创建类?类又是如何创建对象?

     __mataclass__

详见:www.cnblogs.com/alex3714/articles/5213184.html

 

 

 

 



































































































以上是关于python------面向对象进阶的主要内容,如果未能解决你的问题,请参考以下文章

Python基础-第七天-面向对象编程进阶和Socket编程简介

Python 进阶 — 面向对象编程

python 面向对象(进阶篇)

python(24)- 面向对象进阶

python进阶之面向对象初识

python面向对象进阶版