iis服务器助手广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >Python的None和C++的NULL用法解读
  • 541
分享到

Python的None和C++的NULL用法解读

Python的NoneC++的NULLNone和NULL 2023-05-19 08:05:08 541人浏览 薄情痞子
摘要

目录python的None和c++的NULLPython的NoneC++的NULLNone、Null与空字符‘‘什么区别NoneNull空字符’&

Python的None和C++的NULL

Python的None

该值表示一个空对象,是Python的一个特殊的值。None不能理解为0,因为0是有意义的。对值为None的对象进行逻辑判断,会返回False。

可以将None赋值给任何变量,也可以将任何变量赋值给一个None值的对象。

 而在Python中,NULL表示空字符,即""。(直接使用NULL会被提示无定义)

C++的NULL

NULL是一个标准规定的宏定义,用来表示空指针常量,使用NULL必须包含相应的标准头文件【其定义在stddef.h文件中,作为最基本的语言依赖宏存在。但是几乎任意的C++标准头文件都会把这个宏引入。】

经验证NULL==0。

None、Null与空字符‘‘什么区别

None

表示空无一物,啥也没有存储。

编程语言里采用None

比如在python中None不是一个保留关键字,只是NoneType对象的一个实例。

空就是空,它不是整型,不是浮点型,也不是字符串,就是一个NoneType。所以在使用len(None)时候会报错,因为NoneType没有字符串才有的方法。

In [71]: type(None)                                                             
Out[71]: NoneType
In [72]: len(None)                                                              
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-72-96b07938784c> in <module>
----> 1 len(None)
TypeError: object of type 'NoneType' has no len()

数据库查询中用Null,表示的含义相同

Null

表示空无一物,啥也没有存储。

数据库中才使用Null

数据库查询时Null就等同于python中的None,表示什么也没有,是个空值,不是空字符串。常见的就是:

--筛选name字段不为空的记录
select * 
from table_A
where name is not Null

Python中没有Null这个东西

在直接使用Null时,会报错提示Null is not defined。 

In [68]: type(Null) 
---------------------------------------------------------------------------
NameError                                 Traceback (most recent call last)
<ipython-input-68-fe48179a953c> in <module>
----> 1 type(Null)
NameError: name 'Null' is not defined
In [69]: type('Null')                                                           
Out[69]: str
In [70]: len('Null')                                                            
Out[70]: 4

空字符’’

有存储个东西,是空字符串,空字符串有哪些特征呢?

  • 长度为0
  • 类型为string

以下是在python中验证了空字符串的特点。

In [66]: len('')                                                                
Out[66]: 0
In [67]: type('')                                                               
Out[67]: str

值得注意的是:

在数据库表中如果存在空字符串,进行表关联操作时可能会出现空值放大的效果,导致表关联后出现了记录数超多。所以在数据库表或dataframe关联时,需要特别处理空字符串这种情形。

总结

现在是不是头脑清醒了许多~

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: Python的None和C++的NULL用法解读

本文链接: https://www.lsjlt.com/news/212686.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作