Python面向对象进阶之高级编程

简介:

__slots__:定义类时,使用__slots__变量可以限制能添加的实例的属性

形如:__slots__ = ['name','age']

这样实例化的对象只能绑定到name和age属性,其他属性则无法被绑定

1
2
3
4
5
6
7
8
9
class  People:
     __slots__  =  [ 'name' , 'age' ]
     def  __init__( self ,name,age):
         self .name  =  name
         self .age  =  age
=  People( 'laowang' , 18 )
print (p.name)
p.sex  =  'male'
print (p.sex)

执行结果:

1
2
3
4
5
6
7
8
9
laowang
 
Traceback (most recent call last):
 
   File  "C:/" , line  43 in  <module>
 
     p.sex  =  'male'
 
AttributeError:  'People'  object  has no attribute  'sex'

可以看出name属性初始化成功并且可以访问,但是sex属性无法添加

 

 

__call__方法:只要定义类型的时候,实现__call__函数,这个类型就成为可调用的

1
2
3
4
5
6
7
8
9
10
11
class  People:
     def  __init__( self ,name):
         self .name = name
     #
     def  __call__( self * args,  * * kwargs):
         print ( 'call' )
     #
p = People( 'egon' )
print ( callable (People))
print ( callable (p))
p()

执行结果为:

True

True

call

意味着People及其产生的对象均为可调用的,并且:对象()会执行__call__方法

 

__getitem__、__setitem__、__delitem__方法:提供以字典的方式操作对象属性

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class  Foo:
     def  __init__( self ,name):
         self .name = name
     def  __getitem__( self , item):
         # print('getitem',item)
         return  self .__dict__[item]
     def  __setitem__( self , key, value):
         print ( 'setitem-----<' )
         self .__dict__[key] = value
     def  __delitem__( self , key):
         self .__dict__.pop(key)
         # self.__dict__.pop(key)
     # def __delattr__(self, item):
     #     print('del obj.key时,我执行')
     #     self.__dict__.pop(item)
f = Foo( 'egon' )
f[ 'name' ] = 'egon'
print (f.name)
f[ 'age' ] = 18
print (f.__dict__)
del  f[ 'age' ]

 

__iter__、__next__方法:可以实现一个迭代器协议,类定义中加入这两个方法可以将类实例化的对象变为可迭代的对象

需要注意下的就是__next__中必须控制iterator的结束条件,不然就死循环了

下例利用此原理实现了一个简单的range()函数的功能

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
class  Range :
     def  __init__( self ,start,stop):
         self .start  =  start
         self .stop  =  stop
         pass
     def  __iter__( self ):
         return  self
     def  __next__( self ):
         if  self .start > =  self .stop:
             raise  StopIteration
         =  self .start
         self .start  + =  1
         return  n
 
for  in  Range ( 1 , 10 ):
     print (i)

 

__del__方法:析构函数,当对象在内存中被释放时,自动触发执行

注:此方法一般无须定义,因为Python是一门高级语言,程序员在使用时无需关心内存的分配和释放,因为此工作都是交给Python解释器来执行,所以,析构函数的调用是由解释器在进行垃圾回收时自动触发执行的。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
class  Open :
     def  __init__( self ,filepath,mode = 'r' ,encode = 'utf-8' ):
         self .f = open (filepath,mode = mode,encoding = encode)
     def  write( self ):
         pass
     def  __getattr__( self , item):
         return  getattr ( self .f,item)
     def  __del__( self ):
         print ( '----->del' )
         self .f.close()
f = Open ( 'a.txt' , 'w' )
f1 = f
del  f
print ( '=========>' )

 

__enter__、__exit__方法:实现上下文管理协议,即with语句,这个跟文件操作时使用with语句一样:

1
2
with  open ( 'filepath/filename' , 'r' ,encoding = 'utf-8' ) as f:
         '代码块'

在类定义时定义__enter__、__exit__方法可以让类产生的对象使用with语句

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
class  Foo:
     def  __enter__( self ):
         print ( '=====》enter' )
         return  self
     def  __exit__( self , exc_type, exc_val, exc_tb):
         print ( 'exit' )
         print ( 'exc_type' ,exc_type)
         print ( 'exc_val' ,exc_val)
         print ( 'exc_tb' ,exc_tb)
         return  True
 
with Foo() as obj:  #res=Foo().__enter__() #obj=res
     print ( 'with foo的自代码块' ,obj)
     raise  NameError( '名字没有定义' )
     print ( '************************************' )
print ( '------>' )

 __exit__()中的三个参数分别代表异常类型,异常值和追溯信息,with语句中代码块出现异常,则with后的代码都无法执行,但是__exit__如果有返回值,则with语句块之外的代码可以正常执行

 

__str__方法:当类的方法被调用时,会调用此方法返回一个字符串(为了好看与打印相关重要信息)

 

 

元类:

 

关于元类的详细讲解可参阅此文:深刻理解Python中的元类(metaclass)



本文转自 AltBoy 51CTO博客,原文链接:http://blog.51cto.com/altboy/1919295

相关文章
|
2天前
|
数据采集 机器学习/深度学习 数据挖掘
探索Python编程之美:从基础到进阶
【9月更文挑战第4天】在数字时代的浪潮中,编程已成为一种新兴的“超能力”。Python,作为一门易于上手且功能强大的编程语言,正吸引着越来越多的学习者。本文将带领读者走进Python的世界,从零基础出发,逐步深入,探索这门语言的独特魅力和广泛应用。通过具体代码示例,我们将一起解锁编程的乐趣,并理解如何利用Python解决实际问题。无论你是编程新手还是希望提升技能的开发者,这篇文章都将为你打开一扇通往高效编程的大门。
|
3天前
|
数据采集 机器学习/深度学习 数据挖掘
探索Python编程之美:从基础到实战
【9月更文挑战第3天】本文旨在通过深入浅出的方式,带领读者领略Python编程语言的魅力。我们将从基本语法入手,逐步深入至高级特性,最终通过实战案例将理论知识与实践操作相结合。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供有价值的见解和技巧。
|
1天前
|
存储 开发者 Python
探索Python编程之美
【9月更文挑战第5天】在这篇文章中,我们将一起踏上一场Python编程的奇妙之旅。从基础语法到高级特性,我们将一步步揭开Python语言的神秘面纱。你将学习如何编写清晰、高效的代码,掌握函数、类和模块的使用,以及理解面向对象编程的核心概念。此外,我们还将探讨异常处理、文件操作等实用技能。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供宝贵的知识和技巧,让你在编程的道路上更加从容自信。
|
2天前
|
API C语言 开发者
Python如何成为跨平台编程的超级巨星:系统调用深度探索
【9月更文挑战第5天】Python 作为一种高级编程语言,凭借简洁的语法、丰富的库支持和强大的社区,迅速在编程界崭露头角。尤其在跨平台编程方面表现卓越,这得益于其解释器设计和对系统调用的深度整合。CPython 采用 C 语言编写,可为不同操作系统编译,使 Python 程序无需修改即可运行。Python 标准库提供了操作系统功能的抽象,如文件操作、进程控制等,隐藏了底层差异,实现了代码的统一。
18 7
|
3天前
|
存储 人工智能 数据挖掘
探索Python编程:从基础到进阶的旅程
【9月更文挑战第3天】在编程的世界里,Python以其简洁明了的语法和强大的功能库赢得了无数开发者的青睐。本文将带你走进Python的世界,从基础的数据类型和控制结构开始,逐步深入到面向对象编程(OOP)和异常处理等高级主题。无论你是初学者还是有一定经验的开发者,这篇文章都能为你提供新的视角和思考。
13 8
|
1天前
|
存储 数据采集 人工智能
Python编程入门:从零基础到精通
【9月更文挑战第5天】本文将带你进入Python编程的世界,无论你是编程新手还是有一定基础的开发者,都可以通过本文快速掌握Python编程的基础知识和技能。我们将从Python的基本语法开始,逐步深入到面向对象编程、文件操作、网络编程等高级主题,最后还将介绍一些实用的Python库和框架,帮助你在实际项目中应用Python编程。通过阅读本文,你将能够编写出高效、简洁的Python代码,解决实际问题。
|
2天前
|
算法 程序员 Linux
Python编程入门:构建你的第一个程序
【9月更文挑战第4天】编程是现代技术发展的基石,而Python作为一门简洁、易学且功能强大的编程语言,已成为众多初学者的首选。本文将引导你通过一个简单的Python程序,探索编程世界的奥秘,并了解如何利用Python实现基本的算法逻辑。无论你是完全的新手还是希望巩固基础的开发者,这篇文章都将为你提供一个清晰的学习路径。从安装Python环境开始,到编写第一个程序,我们将一步步揭开编程的神秘面纱。
|
5天前
|
存储 人工智能 开发者
探索Python编程:从基础到高级
【8月更文挑战第33天】本文将带你进入Python的世界,从基础语法开始,逐步深入到高级特性。我们将通过实际代码示例,展示Python的强大功能和灵活性。无论你是初学者还是有经验的开发者,这篇文章都将帮助你提升Python编程技能。
|
2天前
|
Linux iOS开发 MacOS
Python系统编程高手进阶:跨平台兼容性?小菜一碟💪
【9月更文挑战第6天】当我们探讨Python系统编程时,跨平台兼容性至关重要。Python凭借其解释型语言特性和多平台解释器,确保了代码能够在Windows、Linux、macOS等多种环境中顺畅运行。本文将介绍Python跨平台运行的基本原理,以及如何处理文件路径差异和系统调用等问题,助你轻松应对跨平台挑战。
8 1
|
2天前
|
存储 Python
Python编程入门:从零开始的代码之旅
【9月更文挑战第4天】本文将带领初学者步入Python的世界,通过简明的语言和直观的例子,逐步揭示编程的乐趣。我们将一起构建基础的数据结构,探索控制语句的奥秘,并实现简单的函数。无论你是编程新手还是希望巩固基础,这篇文章都是你理想的起点。让我们开始吧,一步步将代码块搭建成思维的宫殿!
14 2
下一篇
DDNS