zoukankan      html  css  js  c++  java
  • python全栈脱产第29天------异常处理、元类

    一、异常处理

      定义:异常是错误发出的信号,一旦程序出错就会抛出一个异常,如果该异常没有被应用程序处理,那么该异常就会被抛出,程序的执行就会终止

      异常的组成:1.traceback异常的追踪信息  2.异常的类型  3.异常的信息

      错误的分类:1.语法上的错误:在程序运行前就应该修正

            2.逻辑上的错误

      用途:避免程序因为异常而崩溃,所以在应用程序中应该对异常进行处理,从而增强程序的健壮性

      用法:

    try:
    代码1
    代码2
    代码3
    ......
    except NameError:
    当抛出的异常是NameError时执行的子代码块
    except ....:
    pass
    except ...:
    pass
    else:
    pass
    finally:
    pass
      万能异常类型Exception:可以匹配任意类型的异常
      else:必须放到最后,else的子代码块会在被检测的代码没有异常的情况下执行
      主动触发异常:用raise
      自定义异常类型:继承BaseException类
      断言:assert
    二、元类
      定义:一切皆对象,而对象都是由类实例化得到的
      关系:1.调用元类---》自定义的类  2.调用自定义的类---》自定义的对象
      步骤:1.先拿到类名
         2.在拿到类的基类们
         3.然后拿到类的名称空间:
         4.调用实例化得到自定义类
      自定义类的三个关键组成部分:1.类名  2.类的基类们  3.类的名称空间
      不依靠class关键字创建一个自定义类:1.拿到类名  2.拿到类的基类们  3.拿到类的名称空间  4.调用type得到自定义的类
      控制类的产生:1.类名必须使用驼峰体  2.类体必须要有文档注释,且文档注释不能为空
      
    class Mymeta(type): #但凡继承了type的类才能称之为自定义的元类,否则就是只是一个普通的类
    pass

    class OldboyTeacher(object): #OldboyTeacher=Mymeta('OldboyTeacher',(object,),{...})
    school = 'Oldboy'

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

    def score(self):
    print('%s is scoring' %self.name)

    def __call__(self, *args, **kwargs):
    print(self)
    print(args)
    print(kwargs)
    tea1=OldboyTeacher('egon',18,'male')

    tea1(1,2,a=1,b=2) #__call__(tea1,(1,2).{'a':1,'b':2})
      总结:对象之所以可以调用,是因为对象的类中有一个函数__call__
      推导:如果一切皆对象,那么OldboyTeacher也是一个对象,该对象之所可以调用,肯定是这个对象的类中也定义了一个函数__call__
      实例化类:
        1. 先产生一个空对象
        2. 执行__init__方法,完成对象的初始属性操作
        3. 返回初始化好的那个对象
        推导:调用OldboyTeacher(...)就是在调用OldboyTeacher的类中的__call__,那么在该__call__中就需要做上述三件事
      属性查找:先是按子类到父类到object类,再是Mymeta,最后才是type类3
  • 相关阅读:
    docker部署mysql
    docker安装nginx
    Linux查看日志-grep
    linux系统常用命令
    python爬虫
    unittest中常用的assert语句
    Linux 监控tcp连接数及状态
    linux top命令查看内存及多核CPU的使用讲述
    jmeter的时间戳函数使用
    influxdb基本SQL操作2
  • 原文地址:https://www.cnblogs.com/zhouyi0316/p/9545043.html
Copyright © 2011-2022 走看看