码迷,mamicode.com
首页 > 编程语言 > 详细

python全栈开发day24-__new__、__del__、item系列、异常处理

时间:2018-05-31 19:25:48      阅读:258      评论:0      收藏:0      [点我收藏+]

标签:shuffle   命名   fun   __slots__   acl   使用场景   用户输入   就是   final   

一.昨日内容回顾

  1.反射

    用字符串类型的名字,操作命名空间的变量。

    反射使用场景:明显的简化代码,能拿到的变量名本来就是一个字符串类型的时候,

    用户输入的,文件读入的,网上传输的

  2.__call__

    对象名() 就会调用__call__方法

  3.__len__

  4.__hash__

  5.__eq__

  6.__dict__

    对象名.__dict__:查看对象空间的变量的变量,

    类名.__dict__ 类空间

  7.__slots__

    #__slots__ = (‘name‘,‘age‘)

  8.__module__和__class__

  9.isinstance和issubclass

二.今日内容总结

  1.__new__

    #创建一个对象,是一个构造方法,在初始化方法__init__(self,...)执行之前执行。

      单例模式:

    

技术分享图片
class A:
    __instance = None
    def __init__(self,name):
        self.name = name

    def __new__(cls, *args, **kwargs):
        if not cls.__instance:
            cls.__instance = object.__new__(cls)
        return cls.__instance


a = A(alex)
b = A(jack)

print(a.name)
print(b.name)
单例模式举例

 

  2.__del__

    #在一个对象在内存中删除前,执行__del__方法

    # 对比delattr 使用字符类型的变量从命名空间中删除这个变量

    # 对比@property deleter 伪装成属性的方法,要执行删除属性

  #Python解释器

    #能够主动回收不用的变量

    #在程序结束的时候所有的数据都会被清除

  #如果用户主动删除某个变量

    # 那么这个变量将会主动的被删除

  #无论上述哪种方式

    #在删除一个变量之前都会主动的执行析构方法__del__

        应用:对象删除之前回归操作系统资源

    class B:

      def __init__(self,path):

        self.f = open(path)

      def __del__(self):

        self.f.close()

    b = B(‘userinfl‘)

  3.__getitem__、__setitem__、__delitem__

    # 有一些内置模块中的内置方法

      #是依赖__getitem__方法的

      #或者说是依赖item[‘a‘]这种调用方式的

             #  洗牌,抽牌例子:

      random.choice方法依赖(__len__,__getitem__)

      random.shuffle方法依赖作用对象还有内置方(__len__,__getitem__,__setitem__)

  

技术分享图片
import random
from collections import namedtuple
Card = namedtuple(card, [rank, suit])


class FranchDeck:
    ranks = [i for i in range(2, 11)] + list(JQKA)
    suits = [红心, 方块, 黑桃, 梅花]

    def __init__(self):
        self.__cards = [Card(rank, suit) for rank in FranchDeck.ranks for suit in FranchDeck.suits]

    def __len__(self):
        return len(self.__cards)

    def __getitem__(self, item):
        return self.__cards[item]

    def __setitem__(self, key, value):
        self.__cards[key] = value

    def __delitem__(self, key):
        del self.__cards[key]


deck = FranchDeck()
print(deck.__dict__)
print(deck[0])
random.shuffle(deck)
print(deck.__dict__)
print(random.choice(deck))
洗牌和抽牌的例子

 

  4.异常处理

    #try  except

    #try  except  else

    #try  except  else  finally

    #try   finally

    # assert 1=2

    # raise 主动抛出异常

    # 自定义异常类型

  

技术分享图片
class WuException(BaseException):
    def __init__(self, name):
        self.__name = name

    def __str__(self):
        return self.__name


try:
    raise WuException(有东西错了试试吧)
except WuException as e:
    print(e)
    
自定义异常类型例子

 

 

 

三.预习与扩展

  1.对元类metaclass的理解:

   1)、我们用class关键字创建的类,都是通过基类type类创建:

      class Foo(object):

        a = 1

                             def func():

          print(6666)

      等同于:type(‘Foo‘,(object,),{‘a‘:1,‘func’:func})

                      def func():

        print(6666)

    2) 、 创建类的时候有优先找__metaclass__,自己没有找父类,父类没有找模块,一直找不到就会利用内置type进行类的创建

     class A:

        __metaclass__ = mm

    3)、我们自己定制元类:

     class metaclasstest(type):

        def __new__(cls,name,bases,dict):

          ..........

          return super().__new__(cls,name,bases,dict(可变化))

python全栈开发day24-__new__、__del__、item系列、异常处理

标签:shuffle   命名   fun   __slots__   acl   使用场景   用户输入   就是   final   

原文地址:https://www.cnblogs.com/wuchenggong/p/9116442.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!