c++:指针和引用的区别

article/2025/10/3 0:56:50

目录

前言:

1、引用概念上是定义一个变量的别名,而指针是存储一个变量的地址。

2、引用在定义时必须要初始化,但是指针没有要求。

3、引用在初始化时引用一个实体后,就不能再引用其他实体,因为其本质是一个指针常量,无法改变指向。而指针可以在任何时候指向任何一个同类型实体。

4、没有NULL引用,但有NULL指针。

5、在sizeof中含义不同:引用结果为引用类型的大小,但指针始终是空地址空间所占字节个数(32位平台下占用4个字节,64位占用8字节)。

6、引用自加即引用的实体增加1,指针自加即指针向后偏移一个类型的大小。

7、有多级指针,但是没有多级引用。

8、访问实体方式不同,指针需要显示解引用,引用则由编译器自己处理。

9、引用比指针使用起来相对安全。


前言:

指针和引用区别经常在面试中出现, 下面总结出以下区别

1、引用概念上是定义一个变量的别名,而指针是存储一个变量的地址。

 

2、引用在定义时必须要初始化,但是指针没有要求。

 

3、引用在初始化时引用一个实体后,就不能再引用其他实体,因为其本质是一个指针常量,无法改变指向。而指针可以在任何时候指向任何一个同类型实体。

 

4、没有NULL引用,但有NULL指针。

 

5、在sizeof中含义不同:引用结果为引用类型的大小,但指针始终是空地址空间所占字节个数(32位平台下占用4个字节,64位占用8字节)。

 

6、引用自加即引用的实体增加1,指针自加即指针向后偏移一个类型的大小。

 

7、有多级指针,但是没有多级引用。

 

8、访问实体方式不同,指针需要显示解引用,引用则由编译器自己处理。

 

9、引用比指针使用起来相对安全。


http://chatgpt.dhexx.cn/article/5i8Y8mLR.shtml

相关文章

C++中指针和引用的区别

1.指针和引用的定义和性质区别: (1)指针:指针是一个变量,只不过这个变量存储的是一个地址,指向内存的一个存储单元;而引用跟原来 的变量实质上是同一个东西,只不过是原变量的一个别…

C++中的指针与引用

写在前面 指针和引用形式上很好区别,但是他们似乎有相同的功能,都能够直接引用对象,对其进行直接的操作。但是什么时候使用指针?什么时候使用引用呢?这两者很容易混淆,在此我详细介绍一下指针和引用,力争将最真实的一…

引用和指针概念及区别

一、引用和指针 指针:指针是一个特殊的变量,它里面存储的的数值为内存里的一个地址,通过*访问内存地址所指向的值 引用:引用不是新定义一个变量,而是给已存在变量取了一个别名,编译器不会为引用变量开辟内…

01背包.动态规划.c语言实现

二维dp数组01背包 确定dp数组以及下标的含义 使用二维数组,即dp[i][j] 表示从下标为[0-i]的物品里任意取,放进容量为j的背包,价值总和最大是多少 2.递推公式:dp[i][j]dp[i-1][j-weight]value[i] dp[i][j]dp[i-1][j] 3.数组初始…

【动态规划】背包问题

注意:for j in range(1,m1):是枚举所有的情况,不用一一判断放入物品后背包容量减少后j的变化。为什么从1开始,因为0已经写出来了,即dp[i-1][j]dp[i-1][j-0*a[i-1]]0*v[i-1]。 01背包无价值 dp定义:前i项物…

动态规划——背包问题(01背包问题)

动态规划——背包问题(01背包问题)01背包问题(求最大价值):问题优化01背包问题(求方案数): 动态规划——背包问题(01背包问题) 01背包问题(求最大价值): 有N件物品和一个最多能背重量为W的背包…

动态规划:关于01背包问题 I

动态规划:关于01背包问题,你该了解这些! 对于面试的话,其实掌握01背包,和完全背包,就够用了,最多可以再来一个多重背包。 如果这几种背包,分不清,我这里画了一个图&…

c++ 动态规划-01背包

动态规划 - 01背包问题 1.使用递归遍历(穷举)求解: 01背包问题:给定 n 种物品和一个重量(容量)(限定条件)为 w 的背包,物品 i 的重量是 wi,其价值为 vi。(每种物品只有一个)问:如何选择装入背包的物品,使得装入背包中的物品的价值最大。 //VC6.0------…

动态规划——01背包问题(C++实现)

题目描述: 解题思路: 整体思路: 利用动态规划,其目的就是将原问题分解成几个子问题,通过求解简单的子问题,把原问题给解决,就比如斐波那契数列方程: f[i]f[i-1]f[i-2]; 动态规划的…

动态规划总结三01背包问题

01背包问题一般是利用动态规划进行解题的,这里通过leetcode1049来讲解01背包的解题思路以及如何对01背包应用题目转换和理清思路 01背包问题: 这里借用学习公众号代码随想录的一张图来说明背包问题的种类 对于面试的话,其实掌握01背包&…

dp 动态规划 01背包问题 Python

参考学习网址: https://www.bilibili.com/video/av33930433?fromsearch&seid10637513335818789097 https://www.cnblogs.com/anzhengyu/p/11408466.html 问题描述: 给定 n 件物品,物品的重量为 w[i],物品的价值为 v[i]。现…

Python3使用动态规划处理01背包问题

文章目录 视频教程讲解题目介绍题解1:二维列表题解2:一维列表(滚动数组)延伸阅读 视频教程讲解 【Python算法系列】动态规划2-01背包问题&完全背包问题【Python算法实战】背包问题 题目介绍 原题链接:NC145 01背…

算法 动态规划 01背包问题

01背包 问题分析代码实现从前往后拿,递归实现非递归实现非递归实现,自上向下填充 允接上一文章内容: 算法 动态规划: link. 问题分析 按照普通思维,首先想到应该为贪心算法,也就是计算每个物品重量价值比,…

【动态规划】01背包问题

👨‍🎓作者简介:一位喜欢写作,计科专业大二菜鸟 🏡个人主页:starry陆离 🕒首发日期:2022年5月16日星期一 🌌上期文章:【动态规划】最长上升子序列 &#x1f4…

01背包问题:图表法带你快速理解动态规划解决01背包问题 附C++源码

0-1背包问题 所谓0-1背包问题,也就是给你一个重量为M的背包和n种物品,每种物品有一定的重量和价值,在每种物品均可装入背包1次或不装入(不能仅装入物品的一部分)且不超过背包载重量的前提下,问你怎样选择物…

动态规划——0/1背包问题(全网最细+图文解析)

✨动态规划——0/1背包问题(全网最细图文解析) 作者介绍: 🎓作者:青花瓷✨ 👀作者的Gitee:代码仓库 📌系列文章推荐: ✨1.数据结构与算法—算法篇之动态规划(一) ✨2.【Java刷题特辑第一章】——【点进来花两把游戏的时间学习晚上睡觉都踏实了…

【动态规划】01背包问题(通俗易懂,超基础讲解)

问题描述 有n个物品,它们有各自的体积和价值,现有给定容量的背包,如何让背包里装入的物品具有最大的价值总和? 为方便讲解和理解,下面讲述的例子均先用具体的数字代入,即:eg:numbe…

java事务和分布式事务详解

目录 事务问题 1 Java事务的类型 2 spring事务实现源码分析 事务问题 面试经常会问到分布式锁、分布式事务、SOA 服务化、分布式系统等业务、架构的问题和解决方案,工作中接触的业务方面事关金融,也需要解决一些类似的业务问题,所以总结…

JAVA事务配置总结

JAVA事务配置总结 使用hibernate:1.本地事务动态数据源单sessionFactory 这种情况属于大部分项目配置,在这里不多谈 2.全局事务动态数据源单sessionFactory 数据库分库分表时使用,已解决了不同库中相同名字的表相同ID的数据同时出现在同一…

Java事务回滚问题:抛出异常事务,并返回给前端异常信息

1、背景 修改bug。 之前的开发写的只能单选,所以逻辑都是按照只需要传递一个id值的逻辑写的 现在改为多选时,传递过来的是id数组,所以直接原逻辑的外层加了一个循环,这样原逻辑包括sql就不需要大变动, 但是这样会有个…