首页 > 编程语言 >C++学习笔记(8):指针

C++学习笔记(8):指针

时间:2024-06-05 15:59:25浏览次数:21  
标签:const 常量 指向 int 笔记 C++ 修饰 指针

  指针的作用:指针保存数据的地址,可以通过指针间接访问内存。

1.指针的定义和使用

指针的定义语法:数据类型 * 指针变量名
使用:*指针变量名,通过*操作指针指向内存,可以对内存中的数据进行访问和读写。

示例:

#include <iostream>
using namespace std;

int main()
{
	int a = 1;

	int * p; //定义指针p

	p = &a;//让指针p记录a的地址

	cout << "a的地址:" << &a << endl;
	cout << "指针p为:" << p << endl;

	*p = 2;//指针前加*代表解引用,可以找到指针指向的内存的数据
	cout << "a=" << a << endl;
	cout << "*p=" << *p << endl;

	system("pause");
	return 0;
}

运行结果

a的地址:000000CE68F7FAF4
指针p为:000000CE68F7FAF4
a=2
*p=2

2.指针的内存空间

  指针的内存空间在32位操作系统下都是4字节,在64位操作系统下都是8字节。

示例

#include <iostream>
using namespace std;

int main()
{
	int a = 1;

	int* p; //定义指针p

	p = &a;//让指针p记录a的地址

	cout << "sizeof(int *)=" << sizeof(p) << endl;
	cout << "sizeof(int *)=" << sizeof(int*) << endl;
	cout << "sizeof(float *)=" << sizeof(float*) << endl;
	cout << "sizeof(double *)=" << sizeof(double*) << endl;
	cout << "sizeof(char *)=" << sizeof(char*) << endl;

	system("pause");
	return 0;
}

运行结果

sizeof(int *)=8
sizeof(int *)=8
sizeof(float *)=8
sizeof(double *)=8
sizeof(char *)=8

3.空指针

  空指针指针变量指向内存中编号为0的空间。可以用来初始化指针变量

注:内存编号为0~255是系统占用内存,不允许客户访问。因此空指针指向的内存是不可以访问的

int* p = NULL;//空指针

4.const修饰指针

const修饰指针的三种情况:
(1)const修饰指针 ---- 常量指针
(2)const修饰常量 ---- 指针常量
(3)const即修饰指针,又修饰常量

4.1 const修饰指针

  const修饰指针,指针的指向可以修改,但指针指向的值不可以改。

int a=1;
int b=2;
const int* p=&a;//常量指针

*p=10;(×)  指针指向的值不可以改
p=&b;(√)   指针的指向可以修改

4.2 const修饰常量

  const修饰常量,指针的指向不可以修改,但指针指向的值可以改。

int a=1;
int b=2;
int* const p=&a;//指针常量,const后边跟着变量p

*p=10;(√)   指针指向的值可以改
p=&b; (×)  指针的指向不可以修改

4.3 const即修饰指针,又修饰常量

  const即修饰指针,又修饰常量时,指针的指向和指针指向的值都不可以修改。

int a=1;
int b=2;
const int* const p=&a;//即修饰指针,又修饰常量

*p=10;(×)  指针指向的值不可以改
p=&b; (×)  指针的指向不可以修改

5.指针指向数组

int arr[10] = { 1,2,3,4,5 };
int* p = arr;//利用指针指向数组首地址
cout << "利用指针访问第一个元素:" << *p << endl;//1
p++;//让指针向后偏移4个字节
cout << "利用指针访问第二个元素:" << *p << endl;//2

6.指针在函数中的地址传递

  函数调用时通过值传递可以将实参传给形参,但形参发生的改变不会影响实参。而通过指针可以实现地址传递,可以改变实参的数据。

示例

#include <iostream>
using namespace std;

void swap(int* p1, int* p2)
{
	int temp = *p1;
	*p1 = *p2;
	*p2 = temp;
}

int main()
{
	int a = 3;
	int b = 8;
	cout << "交换后a,b的值:" << endl;
	cout << "a=" << a << endl;
	cout << "b=" << b << endl;
	swap(&a, &b);
	cout << "交换后a,b的值:" << endl;
	cout << "a=" << a << endl;
	cout << "b=" << b << endl;

	system("pause");
	return 0;
}

运行结果

交换后a,b的值:
a=3
b=8
交换后a,b的值:
a=8
b=3

在这里插入图片描述

标签:const,常量,指向,int,笔记,C++,修饰,指针
From: https://blog.csdn.net/m0_53462217/article/details/139462046

相关文章

  • QT笔记:重定向qDebug到控件
    QT笔记:重定向qDebug到控件作为log输出的qDebug可以将调试信息打印到调试终端中,但是有时候实际使用将其输出到UI界面也是很有用的,这里记录下如何将qDebug进行控件重定向。测试版本为QT6.6.2代码mainwindow.h//只要能正常编译过qDebug的就行#include<QMainWindow>QT_BEGIN_......
  • 【C++小知识】为什么C语言不支持函数重载,而C++支持
    为什么C语言不支持函数重载,而C++支持编译链接过程函数名修饰过程总结在了解C++函数重载前,如果对文件的编译与链接不太了解。可以看看我之前的一篇文章,链接:文件的编译链接想要清楚为什么C语言不支持函数重载而C++支持,有俩个过程:1.编译链接。2.函数名修饰过程。编译......
  • c++ 运算符重载、线程安全实现单例
    一、运算符重载namespaceCalcRect{ structRect { Rect(intposX=0,intposY=0,intw=0,inth=0) { x=posX; y=posY; width=w; height=h; } voidoperator=(constRect&other) { x=other.x; y=other.y; width=ot......
  • 算法训练营第九天|28. 实现 strStr()459.重复的子字符串 字符串总结 双指针回顾
    28.实现strStr()1.暴力解法:对主串的每一个字符都作为开头,尝试是否匹配字串,时间复杂度O(m*n)2.确保所有的变量在使用前都被明确地初始化了3.kmp算法之后慢慢理解!!!要记得!!!459.重复的子字符串1.暴力解法:列出所有的子字符串,看是否合法(子字符串开头固定),时间复杂度O(n*n)2.用模......
  • 8086 汇编笔记(十):标志寄存器
    前言一、ZF标志ZeroFlag,零标记位。用于记录相关指令执行后,其结果是否为0。如果结果为0,则ZF=1,如果结果非0,则ZF=0 movax,1subax,1;ZF=1movax,2subax,1;ZF=0二、PF标志ParityFlag,奇偶标记位。它用于记录相关指令执行后,其结果的所有bit位中1的个......
  • 构建之法阅读笔记01
    第一章概论软件=程序+软件工程  软件企业=软件+商业模式  一个复杂的软件不但要有合理的软件架构、软件设计与实现,还要有各种文件和数据来描述各个程序文件之间的依赖关系、编译参数等等,这些都是软件构建的过程。软件开发的不同阶段:1.玩具阶段 2.业余爱好阶段 3.探索......
  • 构建之法阅读笔记02
    第四章两人合作在代码规范方面,可以分为两个部分:代码风格规范和代码设计规范。代码风格规范主要是缩进、行宽、括号、断行与空白的{}行、分行、命名、下划线、大小写、注释等;建民老师上课主要强调的是缩进、命名和注释。在代码设计规范方面,主要是函数、goto错误处理、类处理等。......
  • 构建之法阅读笔记03
    第六章敏捷流程敏捷开发的原则是:1.尽早并持续地交付有价值的软件以满足顾客需求  2.敏捷流程欢迎需求的变化  3.经常发布可用的软件,发布间隔可以从几周到几个月,能短则短 4.业务人员和开发人员在项目开发过程中应该每天共同工作 5.以有进取心的人为项目核心,充分支持信......
  • 【第三节】C/C++数据结构之栈与队列
    目录一、数据结构-栈1.1栈的定义1.2栈的ADT(AbstractDataType)1.3栈的顺序存储结构及实现二、数据结构-队列2.1队列的定义2.2队列的ADT2.3队列的顺序存储结构与实现2.4优先队列一、数据结构-栈1.1栈的定义栈(Stack)可以看成是一种特殊的线性表。限......
  • 计算机毕业设计项目推荐,28259校园信息交流平台的设计与实现(开题答辩+程序定制+全套文
    摘 要随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,校园信息交流平台被用户普遍使用,为方便用户能够可以随时进行校园信息交流平台的数据信息管理,特开发了基于校园信息交流......