5.【Python】Python3 运算符
第一步分析与整理 运算符1. 什么是运算符运算符用于执行算术、比较、逻辑等操作。操作数是参与运算的值。例如4 5 9中4和5是操作数是运算符。Python 支持以下运算符类型算术运算符比较关系运算符赋值运算符逻辑运算符位运算符成员运算符身份运算符运算符优先级2. 算术运算符假设a10b21运算符描述实例加a b→ 31-减a - b→ -11*乘a * b→ 210/除浮点数b / a→ 2.1%取模余数b % a→ 1**幂a ** b→ 10^21//整除向下取整9//2→ 4-9//2→ -5示例代码a21b10c0cabprint(1 - c 的值为,c)# 31ca-bprint(2 - c 的值为,c)# 11ca*bprint(3 - c 的值为,c)# 210ca/bprint(4 - c 的值为,c)# 2.1ca%bprint(5 - c 的值为,c)# 1a2b3ca**bprint(6 - c 的值为,c)# 8a10b5ca//bprint(7 - c 的值为,c)# 23. 比较运算符假设a10b20运算符描述实例等于(a b)→ False!不等于(a ! b)→ True大于(a b)→ False小于(a b)→ True大于等于(a b)→ False小于等于(a b)→ True示例代码a21b10ifab:print(1 - a 等于 b)else:print(1 - a 不等于 b)# 输出ifa!b:print(2 - a 不等于 b)# 输出# ... 其余类似4. 赋值运算符运算符描述实例简单赋值c a b加法赋值c a→c c a-减法赋值c - a*乘法赋值c * a/除法赋值c / a%取模赋值c % a**幂赋值c ** a//整除赋值c // a:海象运算符3.8在表达式中赋值并返回值海象运算符示例# 传统写法n10ifn5:print(n)# 海象运算符if(n:10)5:print(n)# 10优点减少重复计算提高可读性。例如避免调用len()两次if(n:len(a))10:print(fList is too long ({n}elements, expected 10))5. 位运算符将数字视为二进制进行运算。假设a 600011 1100b 130000 1101运算符描述实例按位与a b→ 12 (0000 1100)|按位或a | b→ 61 (0011 1101)^按位异或a ^ b→ 49 (0011 0001)~按位取反~a→ -61补码表示左移a 2→ 240 (1111 0000)右移a 2→ 15 (0000 1111)示例代码a60b13cabprint(1 - c 的值为,c)# 12ca|bprint(2 - c 的值为,c)# 61ca^bprint(3 - c 的值为,c)# 49c~aprint(4 - c 的值为,c)# -61ca2print(5 - c 的值为,c)# 240ca2print(6 - c 的值为,c)# 156. 逻辑运算符假设a10b20运算符描述实例and布尔“与”(a and b)→ 20or布尔“或”(a or b)→ 10not布尔“非”not(a and b)→ False注意and和or返回的是操作数的值而不是简单的True/False。短路求值。a10b20ifaandb:print(a 和 b 都为 true)# 输出7. 成员运算符运算符描述实例in在序列中找到值返回 Truea in listnot in在序列中未找到值返回 Trueb not in listlist[1,2,3,4,5]a10ifainlist:print(a 在列表中)else:print(a 不在列表中)# 输出8. 身份运算符比较两个对象的内存地址是否为同一个对象。运算符描述实例is引用同一对象返回 Truea is bis not引用不同对象返回 Truea is not bis与区别is判断对象身份id 是否相同判断值是否相等a[1,2,3]baprint(bisa)# Trueba[:]print(bisa)# Falseprint(ba)# True9. 运算符优先级从高到低相同单元格内从左至右幂运算从右至左优先级运算符最高(expressions...),[expressions...],{key:value...}x[index],x[index:index],x(arguments...),x.attributeawait x**x,-x,~x*,,/,//,%,-,^|in,not in,is,is not,,,,,!,not xandorif -- elselambda最低:示例a20b10c15d5e(ab)*c/d# (30*15)/5 90.0print(e)and 优先级高于 orxTrueyFalsezFalseifxoryandz:# 等同于 x or (y and z)print(yes)# 会输出if(xory)andz:print(yes)# 不会输出注Python 3 已不支持运算符应使用!。如需使用可from __future__ import barry_as_FLUFL。第二步费曼学习法教学核心思想运算符就是让电脑帮你做各种“计算动作”编程中我们经常需要对数据进行处理加减乘除、比较大小、判断真假、移动二进制位等等。运算符就是告诉电脑“请执行这个动作”的符号。1. 算术运算符最基础的数学计算,-,*,/和数学课上学的一样。%是“取余数”10 % 3 1常用于判断奇偶、循环索引。//是“整除向下取整”9//24-9//2-5注意是向负无穷取整不是截断。**是幂运算2**101024比pow(2,10)更简洁。容易忽略的点/总是返回浮点数即使两个整数都能整除。如果需要整数结果用//。2. 比较运算符得到 True/False用于条件判断。常见陷阱赋值与相等混淆。!表示不等于。3. 赋值运算符把计算结果存起来是赋值。这类“增强赋值”让代码更紧凑x 1比x x 1更清晰。海象运算符:在表达式中同时赋值并返回值。典型用途是避免重复计算# 不用海象需要计算两次 len(a)iflen(a)10:print(f长度{len(a)}大于10)# 用海象只计算一次if(n:len(a))10:print(f长度{n}大于10)4. 位运算符直接操作二进制位虽然平时用得少但在芯片验证、网络协议、嵌入式等领域非常重要。例如用于掩码提取某些位|用于设置位^用于翻转位,用于快速乘以/除以 2 的幂。例子判断一个整数是否为 2 的幂(n (n-1)) 05. 逻辑运算符组合条件and两边都为真才真。or至少一边为真即真。not取反。注意短路False and anything不计算 anythingTrue or anything不计算 anything。利用短路可以写出简洁的代码例如x and print(x)。6. 成员运算符检查是否在集合中in和not in对字符串、列表、元组、字典检查键都有效。非常常用。7. 身份运算符判断是不是同一个对象is用于比较None、单例对象。不要用is来比较数字或字符串可能因小整数缓存而偶然相等但不可靠。比较值is比较身份。aNoneifaisNone:# 正确写法8. 运算符优先级不用死记硬背用括号优先级决定了哪个运算符先计算。例如*先于。当你记不清时加括号( )明确意图还能提高可读性。常见优先级错误ifab0:# 实际是 a (b 0)可能不是你想要的if(ab)0:# 正确如何学习与应用多动手在交互式环境里测试每个运算符。结合现实问题写一个计算器、判断闰年、位图操作。工作中验证工程师常用位运算处理寄存器掩码、用成员运算符检查仿真日志中的关键词、用海象运算符优化循环。综合示例简单的位掩码工具defset_bit(value,pos):将 value 的第 pos 位设为 1pos 从 0 开始returnvalue|(1pos)defclear_bit(value,pos):将 value 的第 pos 位设为 0returnvalue~(1pos)deftest_bit(value,pos):测试第 pos 位是否为 1return(valuepos)1# 使用示例reg0b1010regset_bit(reg,1)# 现在 1010 - 1010? 实际第1位已是1不变regclear_bit(reg,3)# 清除第3位: 1010 - 0010 (二进制)print(bin(reg))# 0b10print(test_bit(reg,1))# 1第三步芯片验证工程师视角的应用示例在芯片验证中我们经常需要解析硬件寄存器描述、生成随机测试向量、检查状态位等。位运算符和逻辑运算符是必备工具。下面给出一个模拟寄存器读写与位域操作的示例。场景描述你有一个 32 位控制寄存器CTRL_REG其位域定义如下bit[0]: 使能位 (EN)bit[3:1]: 模式字段 (MODE)3位bit[7:4]: 分频系数 (DIV)4位bit[31:8]: 保留需要编写函数来读取/修改这些位域并验证随机生成的配置是否符合预期。# filename: reg_operations.py# 功能模拟硬件寄存器位域操作用于验证环境classRegister:简单的寄存器抽象支持位域读写def__init__(self,name,width32,value0):self.namename self.widthwidth self._valuevalue((1width)-1)# 截断到指定位宽defread(self):returnself._valuedefwrite(self,value):self._valuevalue((1self.width)-1)returnself._valuedefget_field(self,high,low):提取 [high:low] 位域的值包含 high 和 lowmask((1(high-low1))-1)lowreturn(self._valuemask)lowdefset_field(self,high,low,field_value):设置 [high:low] 位域为 field_value保留其他位mask((1(high-low1))-1)low# 清空原字段再或上新的值self._value(self._value~mask)|((field_valuelow)mask)returnself._valuedef__repr__(self):returnf{self.name}0x{self._value:0{self.width//4}X}# 定义 CTRL_REG 的位域CTRL_EN_POS0CTRL_EN_MASK1CTRL_EN_POS CTRL_MODE_LOW1CTRL_MODE_HIGH3CTRL_MODE_MASK((1(CTRL_MODE_HIGH-CTRL_MODE_LOW1))-1)CTRL_MODE_LOW CTRL_DIV_LOW4CTRL_DIV_HIGH7CTRL_DIV_MASK((1(CTRL_DIV_HIGH-CTRL_DIV_LOW1))-1)CTRL_DIV_LOWdeftest_reg_operations():测试寄存器位域操作ctrlRegister(CTRL_REG,32,0x0000_0000)# 1. 使能位设置ctrl.set_field(CTRL_EN_POS,CTRL_EN_POS,1)print(ctrl)# CTRL_REG0x00000001enctrl.get_field(CTRL_EN_POS,CTRL_EN_POS)print(fEN {en})# 1# 2. 设置模式为 5 (二进制 101)ctrl.set_field(CTRL_MODE_HIGH,CTRL_MODE_LOW,5)print(ctrl)# 应该是 bit3-1 101整体 0x...0A? 计算bit11,bit20,bit31 - 0b1010 1? 实际值 (51)10 (0xA) 1 11 (0xB)print(fMode {ctrl.get_field(CTRL_MODE_HIGH,CTRL_MODE_LOW)})# 5# 3. 设置分频系数为 8 (4位最大15)ctrl.set_field(CTRL_DIV_HIGH,CTRL_DIV_LOW,8)print(ctrl)# 现在 bit7-4 1000 (8)divctrl.get_field(CTRL_DIV_HIGH,CTRL_DIV_LOW)print(fDIV {div})# 8# 4. 验证总体寄存器值是否符合预期使用位运算直接比较expected(1CTRL_EN_POS)|(5CTRL_MODE_LOW)|(8CTRL_DIV_LOW)ifctrl.read()expected:print(寄存器值正确)else:print(f错误: 寄存器0x{ctrl.read():X}, 期望0x{expected:X})defgenerate_random_config():随机生成有效的寄存器配置用于仿真激励importrandom enrandom.choice([0,1])moderandom.randint(0,7)# 3位0-7divrandom.randint(0,15)# 4位0-15reg_val(enCTRL_EN_POS)|(modeCTRL_MODE_LOW)|(divCTRL_DIV_LOW)returnreg_valdefcheck_config_valid(reg_val):检查随机配置是否符合约束例如分频系数不能为0div(reg_valCTRL_DIV_LOW)((1(CTRL_DIV_HIGH-CTRL_DIV_LOW1))-1)ifdiv0:returnFalse,分频系数不能为0# 模式不能为保留值 7假设mode(reg_valCTRL_MODE_LOW)0x7ifmode7:returnFalse,模式7是保留值returnTrue,有效if__name____main__:test_reg_operations()print(\n--- 随机配置测试 ---)for_inrange(10):cfggenerate_random_config()valid,msgcheck_config_valid(cfg)print(f配置: 0x{cfg:08X}-{msg})详解验证工程师角度位运算符在寄存器操作中的核心作用左移将位域值移到正确的位置。|按位或合并多个位域。按位与提取或清零特定位。~按位取反构造清零掩码。复合使用(reg ~mask) | (value low)是标准位域赋值模式。为什么要抽象成类提高代码复用性避免在每个地方重复编写掩码计算。便于维护修改位域定义只需改一处。可以扩展为带读写回调的模型用于仿真环境中的寄存器模型RAL。实际工作中的应用验证环境中的寄存器抽象层RAL使用类似方法模拟 DUT 寄存器行为。生成随机测试序列generate_random_config用于覆盖率驱动的随机测试。检查约束条件check_config_valid确保随机值不会产生非法配置。学习建议先手动计算小位宽如 8 位的掩码理解((1 n) - 1)为什么能得到 n 个 1。在 Python 交互环境中测试每个位运算表达式观察结果。尝试为自己的项目例如一个简单的 CPU 或外设模型编写寄存器位域操作。通过这个实战示例你将深刻理解位运算符、赋值运算符、逻辑运算符和成员运算符在芯片验证中的价值。运算符虽小却是构建复杂自动化工具的基础砖石。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2622920.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!