C++中NULL和nullptr的区别

article/2025/8/28 5:00:23

在编写C程序的时候只看到过NULL,而在C++的编程中,我们可以看到NULL和nullptr两种关键字,其实nullptr是C++11版本中新加入的,它的出现是为了解决NULL表示空指针在C++中具有二义性的问题,为了弄明白这个问题,我查找了一些资料,总结如下。

一、C程序中的NULL

在C语言中,NULL通常被定义为:#define NULL ((void *)0)

所以说NULL实际上是一个空指针,如果在C语言中写入以下代码,编译是没有问题的,因为在C语言中把空指针赋给int和char指针的时候,发生了隐式类型转换,把void指针转换成了相应类型的指针。

int  *pi = NULL;
char *pc = NULL;

二、C++程序中的NULL

但是问题来了,以上代码如果使用C++编译器来编译则是会出错的,因为C++是强类型语言,void*是不能隐式转换成其他类型的指针的,所以实际上编译器提供的头文件做了相应的处理:

#ifdef __cplusplus
#define NULL 0
#else
#define NULL ((void *)0)
#endif

可见,在C++中,NULL实际上是0.因为C++中不能把void*类型的指针隐式转换成其他类型的指针,所以为了结果空指针的表示问题,C++引入了0来表示空指针,这样就有了上述代码中的NULL宏定义。

但是实际上,用NULL代替0表示空指针在函数重载时会出现问题,程序执行的结果会与我们的想法不同,举例如下:

#include <iostream>
using namespace std;void func(void* i)
{cout << "func1" << endl;
}void func(int i)
{cout << "func2" << endl;
}void main(int argc,char* argv[])
{func(NULL);func(nullptr);getchar();
}

 

  

在这段代码中,我们对函数func进行可重载,参数分别是void*类型和int类型,但是运行结果却与我们使用NULL的初衷是相违背的,因为我们本来是想用NULL来代替空指针,但是在将NULL输入到函数中时,它却选择了int形参这个函数版本,所以是有问题的,这就是用NULL代替空指针在C++程序中的二义性。

三、C++中的nullptr

为解决NULL代指空指针存在的二义性问题,在C++11版本(2011年发布)中特意引入了nullptr这一新的关键字来代指空指针,从上面的例子中我们可以看到,使用nullptr作为实参,确实选择了正确的以void*作为形参的函数版本。

总结:

NULL在C++中就是0,这是因为在C++中void* 类型是不允许隐式转换成其他类型的,所以之前C++中用0来代表空指针,但是在重载整形的情况下,会出现上述的问题。所以,C++11加入了nullptr,可以保证在任何情况下都代表空指针,而不会出现上述的情况,因此,建议以后还是都用nullptr替代NULL吧,而NULL就当做0使用。

其他:在没有C++ 11的nullptr的时候,我们怎么解决避免这个问题呢?

const class nullptr_t
{
public:template<class T>inline operator T*() const{ return 0; }template<class C, class T>inline operator T C::*() const{ return 0; }private:
void operator&() const;
} nullptr = {};

 


http://chatgpt.dhexx.cn/article/wrs0tDd5.shtml

相关文章

C++11中的nullptr

一、什么是nullptr&#xff1f; nullptr是c11的空指针&#xff0c;可以理解为 NULL的升级版。 二、解决什么问题&#xff1f; 首先&#xff0c;在C语言中&#xff0c;NULL是被定义成这样的#define NULL ((void *)0)。 而C中&#xff0c;NULL是被定义成这样#define NULL 0。 …

C++基础:指针空值(nullptr)

初始化指针是将其指向一个“空”位置&#xff0c;比如0。由于大多数计算机系统不允许用户程序写地址为0的内存空间&#xff0c;倘若程序无意中对该指针所指地址赋值&#xff0c;通常在运行时就会导致程序退出。虽然程序退出并非什么好事&#xff0c;但这样一来错误也容易被程序…

【Kafka】消息的同步发送和异步发送

文章目录 概述1. sync vs async1.1 java代码同步和异步 2. 可靠性机制(ack属性配置)2.1 oneway 3. 一般配置4. 同步异步和ack的联系和区别参考 概述 kafka有同步&#xff08;sync&#xff09;、异步&#xff08;async&#xff09;以及oneway这三种发送方式&#xff0c;某些概念…

http请求与响应,同步异步请求以及异步请求axios的配置

文章目录 httphttp简介&#xff0c;协议http请求http响应接收请求行请求头数据 同步异步请求异步请求axios的配置配置文件 http http简介&#xff0c;协议 http是超文本传输协议 &#xff08;HyperText Transfer Protocol&#xff09;服务器传输超文本 到本地浏览器的传送协议…

ajax同步和异步的区别

一、同步访问和异步访问的区别&#xff0c;先从概念上区别&#xff1a; 1、同步的概念应该是来自于操作系统中关于同步的概念。 2、不同进程为协同完成某项工作而在先后次序上调整(通过阻塞,唤醒等方式)。同步强调的是顺序性&#xff0c;谁先谁后&#xff1b;异步则不存在这种顺…

C++ LinuxWebServer项目(5)同步异步日志系统

一、前言 对于任何一个服务器而言,日志系统的设计是非常重要的,尝试设计一个简易的同步异步日志系统来完成系统日志的记录。 二、基础知识 日志,由服务器自动创建,并记录运行状态,错误信息,访问数据的文件。 同步日志,日志写入函数与工作线程串行执行,由于涉及到I…

一文搞懂同步异步阻塞非阻塞

相信很多人在面试的过程中&#xff0c;都被问到过同步和异步的区别、阻塞和非阻塞的区别&#xff0c;以及这两对关系又有什么联系&#xff1f;本文尽可能从专业的角度&#xff0c;用易懂的语言&#xff0c;帮助大家理解 01 前置知识 用户空间和内核空间 操作系统可以支持多个…

同步异步半同步分离式通信

同步通信&#xff1a;采用统一的时钟信号 读数据 T1上升沿主设备给出从设备地址 T2上升沿给出读命令 T3上升沿读数据 T4上升沿撤销 写数据 T1上升沿主设备给出从设备地址 T1下降沿给出数据 T2上升沿给写命令 T4上升沿撤销 异步通信分为三类&#xff1a; 不互锁&#…

一篇文章理解 同步异步、阻塞非阻塞

前述 同步异步&#xff0c;阻塞非阻塞是一些非常常见的概念&#xff0c;但是对于开发者来说往往是用到了很难说清楚。 笔者专门整理了下这方面的概念&#xff0c;作此文以记之。 这部分内容可能存在一些争议&#xff0c;如有不同意见欢迎评论交流。 概念 个人理解同步异步与阻…

ES6同步异步处理

同步和异步 1.同步就是代码从上而下依次执行&#xff0c;除了函数或则回调函数 2.异步也有先后之分但是不明显&#xff0c;等js代码先执行同步后再去执行异步的代码. 如何处理同步异步的问题&#xff08;ES6的Promise&#xff09; 接上面&#xff0c;看下面的代码 var arr[…

前端学习-同步异步问题

在做实作课作品时&#xff0c;出现过对象中变量访问不到的情况&#xff0c;查阅相关资料发现时同步异步的问题&#xff0c;这篇文章帮助我理清思路&#xff0c;希望也能帮助你们更好地理解同步异步。 一、什么是同步/异步任务&#xff1f; 同步任务&#xff1a;指的是在主线程…

dubbo同步异步调用

通常我们通过dubbo调用服务接口&#xff0c;等待提供方处理完响应结果&#xff0c;这是同步调用&#xff1b;也是默认的调用方式。通过查看原吗DubboInvoker可以看到&#xff1a; 整体来说有三种方式&#xff1a; 1、是否关注结果&#xff0c;returntrue关注&#xff0c;默认也…

理解:什么是同步和异步?什么是阻塞和非阻塞?

一、同步和异步 同步与异步是指访问数据的机制&#xff0c;同步一般指主动请求并等待IO操作完成的方式。 异步则指主动请求数据后便可以继续处理其它任务&#xff0c;随后等待IO操作完毕的通知。 同步和异步最大的区别就在于&#xff1a;同步需要等待&#xff0c;异步不需要等…

CPUGPU加速计算

1、CPU(Centrol Processing Unit) CPU上的大部分面积做了cache 和控制逻辑&#xff0c;天然适合做复杂串行程序&#xff1b; 2、GPU(Graphic Processing Unit): GPU有更多的晶体管用于数据处理&#xff0c;特别适用于解决并行计算的问题。可以使程序执行速度加快。为处理图形…

tensorflow使用GPU加速

测试faster-rcnn时&#xff0c;cpu计算速度较慢&#xff0c;调整代码改为gpu加速运算 将 with tf.Session() as sess: 替换为 1 gpu_options tf.GPUOptions(per_process_gpu_memory_fraction0.9) 2 with tf.Session(configtf.ConfigProto(gpu_optionsgpu_options,log_device_…

GPU 及其加速库简介

文章目录 一、GPU 与 CPU 简介1、GPU 与 CPU 的区别2、GPU 分类3、GPU&#xff08;NVIDIA A100 &#xff09; 介绍 二、CUDA 简介1、多版本 CUDA 切换2、为各种 NVIDIA 架构匹配 CUDA arch 和 gencode 三、OpenCL 简介1、OpenCL 平台模型2、OpenCL 执行模型 四、参考资料 一、G…

Pytorch使用GPU加速的步骤

CUDA&#xff08;Compute Unified Device Architecture&#xff09;&#xff0c;是显卡厂商NVIDIA推出的运算平台。 CUDA是一种由NVIDIA推出的通用并行计算架构&#xff0c;该架构使GPU能够解决复杂的计算问题。近些年来&#xff0c;显卡的计算能力越来越强大&#xff0c;如果只…

Python程序如何用GPU加速:Tesla、CUDA、Numba

概念解析 首先要明白&#xff0c;普通的Python代码是无法使用GPU加速的&#xff0c;只能在GPU上跑针对GPU设计的程序。 硬件加速必须要用硬件语言实现。 查询PythonGPU关键字&#xff0c;除了TensorFlow&#xff0c;另外出镜率比较高的几个概念是&#xff1a;Numba、CUDA、PyCU…

什么是 GPU 加速的计算?

什么是 GPU 加速的计算? GPU 加速计算是指同时采用图形处理单元 (GPU) 和 CPU&#xff0c;以加快科学、分析、设计、消费者和企业应用程序的速度。GPU 加速器于 2007 年由 NVIDIA 率先推出&#xff0c;现已在世界各地为政府实验室、大学、公司以及中小型企业的高能效数据中心提…

MATLAB上的GPU加速计算

概述 怎样在MATLAB上做GPU计算呢?主要分为三个步骤&#xff1a;数据的初始化、对GPU数据进行操作、把GPU上的数据回传给CPU 一、数据的初始化 首先要进行数据的初始化。有两种方法可以进行初始化&#xff1a;一是先在CPU上设置好数据然后拷贝到GPU&#xff1b;二是直接在GPU…