博客
关于我
python实现switch
阅读量:162 次
发布时间:2019-02-28

本文共 736 字,大约阅读时间需要 2 分钟。

我们来看一个经典的例子:计算器实现。假设我们要实现一个简单的计算器,那么是否需要判断运算符是加减乘除?大家可能会说,用if语句判断不就可以了?但这种方法会导致代码冗余,占用大量空间。我们以计算器为例,来看看如何实现更高效的解决方案。

传统的方法是使用if语句来判断运算符类型。比如:

def jia(x, y):    return x + ydef jian(x, y):    return x - ydef cheng(x, y):    return x * ydef chu(x, y):    return x / yopr = {    "+": jia,    "-": jian,    "*": cheng,    "/": chu}print(opr["+"](2, 3))

这种方法虽然简单,但代码重复率较高,难以维护和扩展。

相比之下,我们可以通过字典映射的方式实现运算符的多态性。这种方法既简洁又高效,代码量大幅减少,易于扩展。

def jia(x, y):    return x + ydef jian(x, y):    return x - ydef cheng(x, y):    return x * ydef chu(x, y):    return x / yopr = {    "+": jia,    "-": jian,    "*": cheng,    "/": chu}print(opr["+"](2, 3))

这种方法的核心思想是将运算符与相应的函数绑定,通过字典查找快速执行相应的操作。这种方式代码简洁,功能模块化,且易于维护和扩展。如果需要增加新的运算符,只需在字典中添加对应的函数即可,无需修改现有代码。

转载地址:http://dlzj.baihongyu.com/

你可能感兴趣的文章
Oracle 表
查看>>
oracle 课堂笔记
查看>>
Oracle 返回结果集的 存储过程
查看>>
Oracle 递归
查看>>
Oracle 递归函数与拼接
查看>>
oracle 逻辑优化,提升高度,综合SQL上下文进行逻辑优化
查看>>
oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
查看>>
oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
查看>>
oracle--用户,权限,角色的管理
查看>>
Oracle-定时任务-JOB
查看>>
oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
查看>>
oracle00205报错,Oracle控制文件损坏报错场景
查看>>
Oracle10g EM乱码之快速解决
查看>>
Oracle10g下载地址--多平台下的32位和64位
查看>>
Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
查看>>
oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
查看>>
Oracle11G基本操作
查看>>
Oracle11g服务详细介绍及哪些服务是必须开启的?
查看>>
Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
查看>>
oracle12安装软件后安装数据库,然后需要自己配置监听
查看>>