很多前端工程师看到这个标题可能会产生质问:html
我js用得好好的,能后端能APP,为何还要学习Python?前端
至少有下面两个理由:python
这篇文章咱们经过对比两种语言之间的“异常”来学习Python。web
异常是编写代码时必须考虑的问题,但却并非一个热门话题,少有文章提到。
尤为在web前端这一块,浏览器的强大容错能力帮工程师解决(隐藏)了大量的异常。
但若是忽视异常轻则影响功能运行,重则致使系统崩溃,形成经济损失。后端
JavaScript 异常捕获关键字与 Python 一致,都是使用try
。浏览器
// JavaScript try { ... } # Python try: ...
可是二者都具备局限性:只能用来捕获同步执行代码的异常。前端工程师
对于异步代码的异常捕获的状况 JavaScript 处理起来相对复杂,按运行环境就能够分为 Node.js 和 浏览器,按捕获范围又能够分为所有捕获和局部捕获。机器学习
// 浏览器全局异常捕获 window.onError = e => {} window.addEventListener('', e => {}) 捕获请求错误 // 浏览器Ajax异常捕获 var xhr = new XMLHttpRequest(); xhr.onload = function(e) { if(this.status > 400){ ... } }; // Node.js 全局异常捕获 process.on('uncaughtException', e => {}) // Node.js 回调方式异常捕获 fs.readFile('/etc/passwd', (err, data) => { if (err) { ... } });
Python 的状况要简单不少,即便使用异步线程或进程,也能够在函数内部进行捕获,而后其它方式上报。异步
def _parse_speed(key_name, speed_list): try: ... t = threading.Thread(target=_parse_speed, args=(v, speed_list)) t.start()
因为异常捕获状况比较复杂,如无特殊说明,后文讨论仅指使用try关键字的同步异常捕获。函数
再看看JavaScript几种处理异常方式。
很多读者可能会觉得在catch语句块后执行的代码和finally语句块做用同样,但实际上是有区别的!
下面举个例子
fn = () => { try { throw Error() } catch(e) { throw Error() return 1 } finally { return 2 } return 3 } fn() // 是2不是3
也就是说 finally 语句块中的代码,不论 try 仍是 catch 执行出错都会执行。
Python的异常处理:
下面列举使用 except 的几个例子:
# 捕获异常实例 except Exception as e: # 批量异常捕获 except (IOError, TypeError): # 异常分类捕获: except OSError as err: ... except ValueError: ... except: ...
JavaScript 中能够经过关键字 throw 来抛出一个 Error 对象。
Python中与之对应的是 raise ,用来抛出一个 Exception 实例。
虽然关键字不同可是写法基本类似:
// JavaScript throw Error(...) # Python raise Exception(...)
对于 JavaScript 而言,谈异常类的意义不大,处理不一样的异常须要手动判断,因此异常类型也比较简单。
Python的异常类型则丰富得多
参考: