Not not x 和 Bool(x) 用哪个比较好?

今天来做一个选择,个比就是较好 not not x 和 bool(x) 用哪个比较好?

他们都可以把 x 变成一个布尔类型的值:

>>> x = 123 >>> not not x True >>> bool(x) True >>> 

那么谁更快呢?我们写段代码,跑个 100 万次,个比来比较下谁更快:

import timeit def bool_convert(x):     return bool(x) def notnot_convert(x):     return not not x def main():     trials = 10_000_000     kwargs = {          "setup": "x=42",较好         "globals": globals(),         "number": trials,     }     notnot_time = timeit.timeit("notnot_convert(x)", **kwargs)     bool_time = timeit.timeit("bool_convert(x)", **kwargs)     print(f"{ bool_time = :.04f}")     print(f"{ notnot_time = :.04f}") if __name__ == "__main__":     main() 

运行结果如下:

其实 bool(x) 慢的原因在于它是一个函数调用,而 not not x 就是个比一条指令,具有更快捷的较好转换为布尔值的路径,云服务器提供商这一点可以从字节码可以看出来:

bool(x) 多了 LOAD_GLOBAL 和 CALL_FUNCTION。个比

这里附一下相关字节码的较好官方说明:

LOAD_GLOBAL(namei) Loads the global named co_names[namei] onto the stack. CALL_FUNCTION(argc) Calls a callable object with positional arguments. argc indicates the number of positional arguments. The top of the stack contains positional arguments, with the right-most argument on top. Below the arguments is a callable object to call. CALL_FUNCTION pops all arguments and the callable object off the stack, calls the callable object with those arguments, and pushes the return value returned by the callable object. UNARY_NOT Implements TOS = not TOS. 

最后

从结果来看,not not x 比 bool(x) 更快,个比主要原因在于 bool(x) 是较好一个函数调用,函数调用需要参数压入栈顶,个比堆栈的较好顶部包含位置参数,最右边的个比参数在顶部,参数下面是云服务器较好要调用的可调用对象。CALL_FUNCTION 从堆栈中弹出所有参数和可调用对象,个比使用这些参数调用可调用对象,并推送可调用对象返回的返回值,这一过程比一个 not 指令要慢得多。 

不过我仍然推荐你使用 bool(x),因为它的可读性更高,而且,你也不太可能调用它 100万次。站群服务器

IT科技类资讯
上一篇:主流搜索引擎显示的相关搜索项越多,越能积极反映该域名的市场价值。同时,被评估域名的搜索引擎显示结果不佳可能是由于以下两个原因:
下一篇:3、不明先知,根据相关征兆预测可能发生的事件,以便提前做好准备,赶紧注册相关域名。;不差钱域名;buchaqian抢先注册,就是这种敏感类型。预言是最敏感的状态。其次,你应该有眼力。所谓眼力,就是善于从社会上时不时出现的各种热点事件中获取与事件相关的域名资源。眼力的前提是对域名领域的熟悉和丰富的知识。