Python基础 | 类相关

Python作为一种动态语言,有自己的特性。学习了部分关于Python中类相关的内容之后,总结几点小知识,更好的温习。

一、创建大量实例节省内存

  • Python支持实例动态增加属性,大量实例占据大量内存空间,优化方式是使用slots属性,禁止其动态绑定参数行为,有效优化内存空间
class Player1(object):
    def __init__(self,uid,name,status=0,level=1):
        self.uid = uid
        self.name = name
        self.status = status
        self.level = level
    
class Player2(object):
    # 声明出仅有的四个属性,不能在运行中动态绑定属性
    __slots__=['uid','name','status','level']
    def __init__(self,uid,name,status=0,level=1):
        self.uid = uid
        self.name = name
        self.status = status
        self.level = level

二、创建可管理的对象属性

  • Java中使用get和set方法访问和设置属性,Python支持动态绑定属性,这种方式不能保证参数类型的有效性,可以在set方法中进行类型验证
  • 对于Python中的get和set方法,是否可以像访问属性一样简单呢?可以使用其内置函数property,实现函数像属性一样简单访问
from math import pi
class Circle(object):
    def __init__(self,radius):
        self.radius = radius
    def getRadius(self):
        # 可以对输入的数据进行四舍五入
        return round(self.radius,2)
    # 使用方法设置后,属性类型可以确定
    def setRadius(self,value):
        if not isinstance(value,(int,float)):
            raise ValueError('错误类型')
        self.radius = value
    def getAreas(self):
        return self.radius ** 2 * pi
    # 用于快速访问方法属性
    R = property(getRadius,setRadius)

c = Circle()
c.R
c.R = 13

三、描述符对实例属性做类型检查

  • Python动态绑定属性时,是否可以对其要添加的类型进行检查呢?可以基于描述符对动态绑定的属性进行类型检查
class Attr(object):
    def __init__(self,name,type_):
        self.name = name
        self.type_ = type_
           
    def __get__(self,instance,cls):
        return instance.__dict__[self.name]
    
    def __set__(self,instance,value):
        if not isinstance(value,self.type_):
            raise TypeError("required type: %s " % self.type_)
        instance.__dict__[self.name] = value
        
    def __delete__(self,instance):
        del instance.__dict__[self.name]
        
class Person(object):
    name = Attr('name',str)
    age = Attr('age',int)
    email = Attr('email',str)

四、环形引用的对象销毁

  • Python中对象的销毁基于引用计数,如果存在环形引用情况,往往难以销毁对象,可以使用weakref包中的弱引用来实现
import weakref
class Data(object):
    def __init__(self,value,own):
         self.value = value
         self.own = weakref.ref(own)
    def __str__(self):
        return "%s's data,value is %s" %(self.own(),self.value)
    def __del__(self):
        print ('in Data del')

class Node(object):
    def __init__(self,value):
        self.value = Data(value,self)
    def __del__(self):
        print ('in Node del')

今年的六月,相对还是很温和的,相比于之前年份的六月,只能说以前太残忍。趁着机会,伴着微风,开心向前。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Python 面向对象Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对...
    顺毛阅读 4,238评论 4 16
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,973评论 19 139
  • 我曾待过几年的地方 如今我在家乡还过着深秋 那儿已下起了雪 每年春来都到了五月里 我没去以前的那些年不常下雨 下雨...
    无问色空阅读 174评论 7 7
  • 到底是哪两字呢?这话还要从高中时说起。 高中的时候,我一直是班里的宣传委员,主要负责黑板报的设计、编辑和撰写工作,...
    默墨舞文阅读 668评论 2 2
  • 互联网接入中国已经整整20年。从发出第一封电子邮件,到ICQ、OICQ等即时聊天工具的风靡;从使用搜索引擎...
    Fiona喬天阅读 117评论 0 0