mysql if else多层嵌套_多层嵌套的if判断需要优化么?对性能影响大么?

博客探讨了在Python中使用多层if嵌套进行MySQL查询决策的情况,并建议关注代码的可读性和可维护性而非仅仅性能。文章通过一个线程类示例展示了如何处理任务队列,并提出使用第三方工具如Pypy进行优化,同时提醒注意线程方式对性能的影响,提倡使用try-except结构提升代码整洁度。
摘要由CSDN通过智能技术生成

class ThreadUrl(threading.Thread):

def __init__(self, main_queue, source1_queue, source2_queue, source3_queue, source4_queue):

threading.Thread.__init__(self)

self.main_queue = main_queue

self.source1_queue = source1_queue

self.source2_queue = source2_queue

self.source3_queue = source3_queue

self.source4_queue = source4_queue

def run(self):

while True:

# 从任务队列里取出任务

sql_dict = self.main_queue.get()

sql = sql_dict.get('a')

if sql is not None:

self.source1_queue.put(sql)

self.main_queue.task_done()

else:

sql = sql_dict.get('b')

if sql is not None:

self.source2_queue.put(sql)

self.main_queue.task_done()

else:

sql = sql_dict.get('c')

if sql is not None:

self.source3_queue.put(sql)

self.main_queue.task_done()

else:

sql = sql_dict.get('d')

if sql is not None:

self.source4_queue.put(sql)

self.main_queue.task_done()

类似这种形式。

影响不大,清晰的结构比那点性能往往更总要。想做优化的话完全可以通过第三方工具(Pypy等)。

主要是丑呀,如此不优雅的代码。

else 全部可以用它 continue 代替。

至于性能,你确定你要用 threading.Thread 这种线程方式?

有点啰嗦,try里写正常代码,except里处理sql异常

首先考虑可读性可维护性

最后才考虑性能

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值