zoukankan      html  css  js  c++  java
  • 异常处理

    异常处理

    什么是异常?
    异常发生之后
    异常之后的代码就不执行了

    什么是异常处理
    python解释器检测到错误,触发异常(也允许程序员自己触发异常)
    程序员编写特定的代码,专门用来捕捉这个异常(这段代码与程序逻辑无关,与异常处理有关)
    如果捕捉成功则进入另外一个处理分支,执行你为其定制的逻辑,使程序不会崩溃,这就是异常处理

    为什么要进行异常处理?

    python解析器去执行程序,检测到了一个错误时,触发异常,异常触发后且没被处理的情况下,
    程序就在当前异常处终止,后面的代码不会运行,谁会去用一个运行着突然就崩溃的软件。

    所以你必须提供一种异常处理机制来增强你程序的健壮性与容错性

    如何进行异常处理?
    首先须知,异常是由程序的错误引起的,语法上的错误跟异常处理无关,必须在程序运行前就修正

    # try, except 单支
    
    try:
        l1 = [1, 2, 3]
        l1[100]  # 代码运行到这里就结束了
        print(111)
        dic = {"key1": "v1"}
        dic["key2"]  # 这里不会报错
    
    except IndexError:
        print("索引错误")
    
    # 索引错误
    
    
    
    try:
        print(111)
        dic = {"key1": "v1"}
        dic["key2"]
    
    except IndexError:
        print("索引错误")
    
    # 可以这样写:
    except IndexError as i:
        print(i)
    
    # 不会显示 IndexError,因为这不是 IndexError, 而是 KeyError
    # 多支
    
    try:
        l1 = [1, 2, 3]
        l1[100]
        print(111)
        dic = {"key1": "v1"}
        dic["key2"]
        num = int(input("请输入数字:"))
    
    except IndexError as i:
        print("i")
    
    except KeyError as k:
        print("k")
    
    except ValueError as v:
        print("v")
    # 万能处理
    
    try:
        l1 = [1, 2, 3]
        l1[100]
        print(111)
        dic = {"key1": "v1"}
        dic["key2"]
        num = int(input("请输入数字:"))
    
    except Exception as e:
        print(e)
    
    # 检测到第一个错误即停止运行
    # list index out of range
    # 以上的异常处理方法分情况使用,不是说哪一种就绝对好
    # 1.如果对报错信息不关心,只是像直接跳过报错而不分流执行代码,使用万能异常
    
    s1 = 'hello'
    try:
        int(s1)
    except Exception as e:
        print(e)
    
    # 如果你统一用Exception,没错,是可以捕捉所有异常
    # 但意味着你在处理所有异常时都使用同一个逻辑去处理(这里说的逻辑即当前expect下面跟的代码块)
    # 2.如果想要捕捉具体的错误信息,根据不同的错误执行不同的分支,则使用多分支比较好
    
    s1 = 'hello'
    try:
        int(s1)
    except IndexError as i:
        print(i)
    except KeyError as k:
        print(k)
    except ValueError as v:
        print(v)
    # 3.使用多分支的时候,最后加上一个 Exception,打印类似"出现未知错误"的提示,逻辑更完整
    
    s1 = 'hello'
    try:
        int(s1)
    except IndexError as i:
        print(i)
    except KeyError as k:
        print(k)
    except ValueError as v:
        print(v)
    except Exception as e:
        print(e)
    
    # try...except...不要乱用, 一般可以用在需要用 if..elif..else 判断的时候
    # 异常的其他机构
    
    s1 = 'hello'
    try:
        int(s1)
    except IndexError as i:
        print(i)
    except KeyError as k:
        print(k)
    except ValueError as v:
        print(v)
    #except Exception as e:
    #    print(e)
    else:
        print('try内代码块没有异常则执行我')
    finally:
        print('无论异常与否,都会执行该模块,通常是进行清理工作')
    
    # finally的用法——程序有没有异常它都会执行,它的作用很大
    # 1. 关闭文件句柄,数据库链接等
    # with open("test", encoding="utf-8") as f:
    #     try:
    #         pass
    #         # 这里有很多内容
    #     finally:
    #         f.close()  # 因为中间内容要是有点问题,文件不会关闭,还会留在内存中
    
    # 2.会在函数运行一开始就运行 def func(): try: return 666 finally: print(111) func() # 111 # 说明 finally 语句会在程序一开始就会运行,很神奇
    # 3.会在while循环一开始就执行
    while 1: try: break finally: print(777) # 777
    # 主动触发异常
    
    try:
        raise TypeError('类型错误')
    except Exception as e:
        print(e)
    
    
    # 自定义异常
    class EvaException(BaseException):
        def __init__(self,msg):
            self.msg=msg
        def __str__(self):
            return self.msg
    
    try:
        raise EvaException('类型错误')
    except EvaException as e:
        print(e)

    # 断言
    assert 1 == 1
    # 不成立就报错
    assert 1 == 2
    try..except的方式比较if的方式的好处

    1.try..except这种异常处理机制就是取代if那种方式
    让程序在不牺牲可读性的前提下增强健壮性和容错性

    2.异常处理中为每一个异常定制了异常类型(python中统一了类与类型,类型即类)
    对于同一种异常,一个except就可以捕捉到,可以同时处理多段代码的异常
    无需‘写多个if判断式’,减少了代码,增强了可读性

    使用try..except的方式

    1:把错误处理和真正的工作分开来
    2:代码更易组织,更清晰,复杂的工作任务更容易实现;
    3:毫无疑问,更安全了,不至于由于一些小的疏忽而使程序意外崩溃了;

    try...except应该尽量少用,因为它本身就是附加给程序的一种异常处理的逻辑
    与主要的工作是没有关系的

    这种东西加的多了,会导致你的代码可读性变差
    只有在有些异常无法预知的情况下,才应该加上try...except,其他的逻辑错误应该尽量修正
  • 相关阅读:
    #Leetcode# 21. Merge Two Sorted Lists
    #Leetcode# 118. Pascal's Triangle
    #LeetCode# 136. Single Number
    #Leetcode# 26. Remove Duplicates from Sorted Array
    #LeetCode# 167. Two Sum II
    #Leetcode# 58. Length of Last Word
    #LeetCode# 35. Search Insert Position
    POJ 2492 J-A Bug's Life
    #Leetcode# 27. Remove Element
    【前端】.easyUI.c#
  • 原文地址:https://www.cnblogs.com/shawnhuang/p/10283281.html
Copyright © 2011-2022 走看看