1
Livid MOD 没有必要一定写 return。
|
2
ayanamist 2011-09-28 09:12:51 +08:00
看团队的风格,有些团队是从C转过来的,要求显式返回的代码风格。
一般是不主张在没有返回的情况下最后加一个return的。在Scala中甚至不主张显式使用return,而是把要返回的值放在最后一行 |
3
reorx OP 我是遇到了这样的情况,和同伴一起工作,预定义一些函数来统一接口:
class FooHdr: ... def func_a(self): """Description & Usage""" return def func_b(self): """Description & Usage""" return 为了保证程序能正常运行,这些函数肯定是不能留空的,那么就是加return和加pass的选择了。 我想的是,对于需要返回数据的函数,完成之后,直接在return后面加上变量就可以了,对于不需要返回的,也省去了用pass时要删掉的麻烦。总而言之是出于协作规范的考虑,不过根据Google的Python规范来看,这样做确有画蛇填足之嫌了。 |
4
levey 2011-09-28 13:56:46 +08:00
void的我不写return。
|
5
istef 2011-09-28 13:58:18 +08:00
感觉是个人风格问题,我貌似就是比较喜欢写 return 那种类型的。。。。
|
6
chuangbo 2011-09-28 14:03:12 +08:00
Pythonic 的话就不写,会自动返回 None
|
8
huangz 2011-09-28 14:14:37 +08:00
处理这样的空函数,比起pass或者return,更好的选择是显式地抛出一个异常:
def fun(): ____raise NotImplementedError 这样一来起到了占位符的作用,二来可以防止你在程序中误用这个未完成的函数——一些单纯依靠副作用的函数因为返回None而“骗过”测试,这样的错误并不少见。 |
9
reorx OP @huangz fantastic solution! 抛出异常确实是处理空函数的最佳方法。
看了一下NotImplementedError的定义: “In user defined base classes, abstract methods should raise this exception when they require derived classes to override the method.” 虽然是用于父类需要重写的方法,不过在意义上和“没有部署的函数”是相近的,很合适,毕竟我们需要的就是异常而已。 |
10
huangz 2011-09-28 15:36:04 +08:00
@reorx
是的,反正只要抛出异常就行了,Python的异常里面,NotImplementedError算是比较符合占位符目的的一个了(望文见义嘛)。 我自己一般用Exception,因为可以少打点字,哈哈。 |
11
ccp0101 2011-09-28 20:20:50 +08:00
C中我全加return。Python一般都只是一次性用用看心情。
|
12
Numbcoder 2011-09-28 20:29:51 +08:00
Ruby 里不需要return,最后一行就是返回值。
|