「Python」身份运算符is 与 is not——判断None应该使用is
Python 使用 not is 判断 运算符 应该 身份
2023-06-13 09:12:06 时间
在python中有两个身份运算符,一个是is另外一个是is not。
作用:身份运算符用于比较两个对象的内存地址是否一致——是否对同一个对象的引用。
在python中针对None比较时,建议使用is判断。
运算符 | 描述 | 实例 |
---|---|---|
is | Is是判断两个标识符是不是引用同一个对象 | x is y ,类似id(x) == id(y) |
Is not | Is not 是判断两个标识符是不是引用不同对象 | x is not y ,类似id(a) != id(b) |
一、Is 与 == 的区别:
is 用于判断两个变量引用对象是否为同一个。
== 用于判断引用变量的值是否相等。
代码验证:
a = [1, 2, 3]
print(id(a)) # 变量a地址
b = [1, 2, 3, 4]
print(id(b)) # 变量b地址
a.append(4)
print(a)
print(a is b)
print(a == b)
执行结果:
二、修改士兵突击面向对象封装案例
在之前的面向对象封装士兵突击案例中就用到了None这个关键字,当时是利用==来进行判断的,但是按照编码规范建议应该使用is来进行判断,所以在这里稍微的修改一下代码。
下面是之前的士兵突击案例修改is之前的完整代码:在修改之前代码执行并没有错误。
class Gun():
def __init__(self, model):
# 1. qiang的型号
self.model = model
# 2. 子弹的数量,初始值为0
self.bullet_count = 0
def add_bullet(self, count):
self.bullet_count += count
def shoot(self):
# 1. 判断子弹数量
if self.bullet_count <= 0:
print("[%s] 没有子弹了" % self.model)
return
# 2. 发射子弹, -1
self.bullet_count -= 1
# 提示发射信息
print("[%s] 突突突。。。[%d]" % (self.model, self.bullet_count))
class Soldier():
def __init__(self, name):
# 1. 姓名
self.name = name
# 2. qiang = 新兵没有枪
self.gun = None
def fire(self):
# 1. 判断是否有枪
if self.gun == None:
print("[%s]还没有qiang" % self.name)
return
# 2. 高喊冲锋口号
print("冲啊。。。 [%s]" % self.name)
# 3. 装填子弹
self.gun.add_bullet(50)
# 4. 发射子弹射击
self.gun.shoot()
# 1. 创建qiang对象
ak47 = Gun("Ak47")
# 2. 调用方法
# ak47.add_bullet(50)
# ak47.shoot()
# 3. 创建士兵对象-张小嘎
zhang = Soldier("张小嘎")
# 用赋值语句,把ak47交给张小嘎
zhang.gun = ak47
zhang.fire()
# print(zhang.gun)
在修改之前可以看出PyCharm给这行代码标注了虚线,那么在修改之后虚线就没了。
下面就对于这部分代码进行修改:
备注:如果想详细了解这个士兵突击的面向对象化封装案例,可以看我之前的一篇文章。文章地址为:https://cloud.tencent.com/developer/article/2096651?sharedUid=9226637#2.3
更多关于Python基础教程和进阶知识都可以去Python自学网学习,还有Python学习路线讲解。
相关文章
- python win32api messagebox_如何在Python中使用Win32 API?
- origin安装嵌入python_python爬虫之git的使用(origin说明)
- python hashlib_Python hashlib模块实例使用详解
- python使用opencv如何保存图片_OpenCV Python 保存图片
- python装饰器的使用方法
- python – 文件
- 【使用Python实现算法】02 原生类型与内置函数
- python-Python与SQLite数据库-使用Python执行SQLite查询(二)
- python-Python与MongoDB数据库-使用Python执行MongoDB查询(一)
- Python使用platform库获取系统信息:操作系统信息、硬件信息、python环境信息
- python从文本文件中选出使用频率最多的单词详解编程语言
- 如何使用Python安装MySQL(python安装mysql)
- Python玩转Redis:提升缓存效率(python使用redis)
- 用这个 Python 3.7 的特性来切片无限生成器
- 使用Python连接SQL Server数据库(python连接sqlserver)
- python驱动使用pip安装MySQL Python驱动的简单步骤(pip安装mysql)
- MySQL中NOT操作的使用方法与实例分析(mysql中not)
- 关键字在 Oracle 中使用 NOT 关键字的实践(oracle 中 not)
- 纯Python开发的nosql数据库CodernityDB介绍和使用实例
- Python数组条件过滤filter函数使用示例
- python进程管理工具supervisor使用实例