LINUX下的安装声卡等操作和技巧介绍

源代码在线查看: 第八章 错误与例外 suzhe (转).txt

软件大小: 735 K
上传用户: my99ab1
关键词: LINUX 声卡 操作
下载地址: 免注册下载 普通下载 VIP

相关代码

				作者:softrain
				email: softrain@edu.21cn.com
				日期:2001-7-21 9:59:02
				第八章 错误与例外 
				到现在为止我们只是提到了错误信息而没有详细讨论,如果你运行了前面的例子可能已 
				经看到了一些错误信息。至少有两种不同错误:句法错和例外错(exceptions)。 
				8.1 句法错 
				 句法错也称为语法分析错,是你在学习Python的时候最可能犯的错误。 
				>>> while 1 print 'Hello world' 
				  File "", line 1 
				    while 1 print 'Hello world' 
				                ^ 
				SyntaxError: invalid syntax 
				语法分析器重复出错行,并用一个小‘箭头’指向行内最早发现错误的位置。错误是由 
				箭头前面的记号引起的(至少是在这里检测到的)。在本例中,错误在关键字print处检 
				测到,因为它前面应该有一个冒号(“:”)。错误信息中显示了文件名和行号这样如果 
				错误发生在一个脚本文件中你就知道到哪里去找。 
				8.2 例外 
				即使语句或表达式句法没有问题,在试图运行的时候也可能发生错误。运行时检测到的 
				错误叫做例外,这种错误不一定必然是致命的:你很快就会学到如何在Python程序中处 
				理例外。然而,多数例外不能被程序处理,这是会产生错误信息,如: 
				>>> 10 * (1/0) 
				Traceback (innermost last): 
				  File "", line 1 
				ZeroDivisionError: integer division or modulo 
				>>> 4 + spam*3 
				Traceback (innermost last): 
				  File "", line 1 
				NameError: spam 
				>>> '2' + 2 
				Traceback (innermost last): 
				  File "", line 1 
				TypeError: illegal argument type for built-in operation 
				错误信息的最后一行显示发生的情况。例外有不同的类型,类型作为错误信息的一部分 
				显示:上例中错误的类型有ZeroDivisionError、NameError和TypeError。作为例外类型 
				显示的字符串是发生的例外的内置名。这对于所有内置例外成立,但对用户自定义例外 
				不一定成立(用户最好能遵守这样的约定)。标准例外名是内置的标识符(不是保留关 
				键字)。 
				此行的其余部分是错误的细节,其解释依赖于例外类型。错误信息前面的部分以堆栈反 
				跟踪的形式显示了发生错误的上下文环境。一般这包含了列出源代码行的一个列出源程 
				序行的堆栈反跟踪;然而,它不会显示从标准输入读进的行。 
				 库参考手册列出了内置例外和其含义。  
				8.3 例外处理 
				 可以编程序来处理选定的例外。请看下面的例子,显示一些浮点数的倒数: 
				>>> numbers = [0.3333, 2.5, 0, 10] 
				>>> for x in numbers: 
				...     print x, 
				...     try: 
				...         print 1.0 / x 
				...     except ZeroDivisionError: 
				...         print '*** has no inverse ***' 
				... 
				0.3333 3.00030003 
				2.5 0.4 
				0 *** has no inverse *** 
				10 0.1 
				try语句是这样工作的: 
				首先,运行try子句(在try和except之间的语句)。 
				如果没有发生例外,跳过except子句,try语句运行完毕。 
				如果在try子句中发生了例外错误而且例外错误匹配except后指定的例外名,则跳过try 
				 子句剩下的部分,执行except子句,然后继续执行try语句后面的程序。 
				如果在try子句中发生了例外错误但是例外错误不匹配except后指定的例外名,则此例外 
				被传给外层的try语句。如果没有找到匹配的处理程序则此例外称作是未处理例外,程序 
				停止运行,显示错误信息。 
				try语句可以有多个except子句,为不同的例外指定不同处理。至多只执行一个错误处理 
				程序。错误处理程序只处理相应的try子句中发生的例外,如果同try语句中其它的错误 
				处理程序中发生例外错误处理程序不会反应。一个except子句可以列出多个例外,写在 
				括号里用逗号分开,例如: 
				... except (RuntimeError, TypeError, NameError): 
				...     pass 
				最后一个except子句可以省略例外名,作为一个通配项。这种方法要谨慎使用,因为这 
				可能会导致程序实际已出错却发现不了。 
				try ... except语句有一个可选的else子句,如有的话要放在所有except子句之后。el 
				se 的意思是没有发生例外,我们可以把try子句中没有发生例外时要做的事情放在这个 
				子句里。例如: 
				for arg in sys.argv[1:]: 
				    try: 
				        f = open(arg, 'r') 
				    except IOError: 
				        print '不能打开', arg 
				    else: 
				        print arg, '有', len(f.readlines()), '行' 
				        f.close() 
				例外发生时可能伴有一个值,叫做例外的参数。参数是否存在及其类型依赖于例外的类 
				型。对于有参数的例外,except在自居可以在例外名(或表)后指定一个变量用来接受 
				例外的参数值,如: 
				>>> try: 
				...     spam() 
				... except NameError, x: 
				...     print 'name', x, 'undefined' 
				... 
				name spam undefined 
				有参数的例外未处理时会在错误信息的最后细节部分列出其参数值。  
				例外处理程序不仅处理直接产生于try子句中的例外,也可以处理try子句中调用的函数 
				(甚至是间接调用的函数)中的例外。如: 
				>>> def this_fails(): 
				...     x = 1/0 
				... 
				>>> try: 
				...     this_fails() 
				... except ZeroDivisionError, detail: 
				...     print 'Handling run-time error:', detail 
				... 
				Handling run-time error: integer division or modulo 
				8.4 产生例外 
				raise语句允许程序员强行产生指定的例外。例如: 
				>>> raise NameError, 'HiThere' 
				Traceback (innermost last): 
				  File "", line 1 
				NameError: HiThere 
				raise语句的第一个参数指定要产生的例外的名字。可选的第二参数指定例外的参数。  
				 
				8.5 用户自定义例外 
				程序中可以定义自己的例外,只要把一个字符串赋给一个变量即可。例如: 
				>>> my_exc = 'my_exc' 
				>>> try: 
				...     raise my_exc, 2*2 
				... except my_exc, val: 
				...     print 'My exception occurred, value:', val 
				... 
				My exception occurred, value: 4 
				>>> raise my_exc, 1 
				Traceback (innermost last): 
				  File "", line 1 
				my_exc: 1 
				许多标准模块用这种方法报告自己定义的函数中发生的错误。  
				8.6 定义清理动作 
				  try语句还有另一个finally可选子句,可以用来规定不论出错与否都要执行的动作。 
				例如: 
				>>> try: 
				...     raise KeyboardInterrupt 
				... finally: 
				...     print 'Goodbye, world!' 
				... 
				Goodbye, world! 
				Traceback (innermost last): 
				  File "", line 2 
				KeyboardInterrupt 
				finally子句不论try子句中是否发生例外都会执行。例外发生时,先执行finally子句然 
				后重新提出该例外。当try语句用break或return语句退出时也将执行finally子句。 
				要注意的是,try语句有了except子句就不能有finally子句,有了finally子句就不能有 
				except 子句,不能同时使用except子句和finally子句。需要的话可以嵌套。 
				 
							

相关资源