c++学习笔记7指针

7指针

7.1基本概念

作用:可以通过指针间接访问内存
内存编号是从0开始记录的,一般用十六进制数字表示
可以利用指针变量保存地址;
指针为地址

7.2指针变量的定义和使用

指针变量定义语法:数据类型 * 变量名;

/*定义指针*/
int a = 10;//定义整型变量a
int*p;
p= &a;//让指针p记录a的地址,&为取址符
/*使用指针*/
//可以通过解引用的方式来找到指针指向的内存
//指针前加*代表解引用,找到指针指向的内存中的数据
1,直接输入cout<<"*p="<<"*p"<<endl;此时访问并输出输出变量a的值,即*p=10
2*p=1000;//访问并修改a的内存
//此时,输出a=1000,*p=1000

指针前加*代表解引用,找到指针指向的内存中的数据
p= &a;指针p记录a的地址,&为取址符

7.3指针所占内存空间

intp=&a;相当于intp;p=&a;

int a = 10;
int * p = &a;
cout<<"sizeof(int *)="<<sizeof(int *)<<endl;//或sizeof(p)

7.4空指针和野指针

1、空指针:指针变量指向内存中编号为0的空间
用途:初始化指针变量
注意:空指针指向的内存是不可以访问的

//空指针
//1、空指针用于给指针变量进行初始化
int*p=NULL;
//2、空指针不可以进行访问
//0~255之间的内存编号是系统占用的,因此不可以访问
*p=100;//错误
cout<<*p<<endl;//错误

2、野指针:指针变量指向非法的内存空间
即指向未申请的内存空间
在程序中避免出现野指针

7.5const修饰指针

const修饰指针有三种情况:
1,const修饰指针—常量指针

int a=10;
int b=10;
const int*p=&a;//该指针为常量指针

特点:指针指向可以修改,但指针指向的值不可以修改
即*p=20,错误,指针指向的值不可以改;
p=*b,正确,指针的指向可以修改

2,const修饰常量—指针常量

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

特点:指针的指向不可以改,指针指向的值可以改
即*p=20,正确,指针指向的值可以改;
p=*b,错误,指针的指向不可以修改

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

int a=10;
int b=10;
const int *const p = &a;

特点:指针的指向和指针指向的值都不可以改

记忆法:
const代表常量;*代表指针
const *代表常量指针;*const代表指针常量
const修饰谁,谁就可以改:

7.6指针和数组

作用:利用指针访问数组中元素

int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int* p = arr;//arr即为数组首地址
	cout << "利用指针访问第一个元素:" << *p << endl;
	p++;
	cout << "利用指针访问第二个元素:" << *p << endl;
	
	cout << "利用指针遍历数组中的每个元素:" << endl;
	int* p2 = arr;
	for (int i = 0; i < 10; i++)
	{
		cout << * p2<< "  ";
		p2++;
	}
	cout << endl;

7.7指针和函数

作用:利用指针作函数参数,可以修改实参的值
地址传递:对比于值传递,不能改变实参,地址传递可以

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

int main()
{
	int a = 10;
	int b = 20;
	swap(&a, &b);
	cout << "a=" << a << endl;
	cout << "b=" << b << endl;
		system("pause");
		return 0;
}

在这里插入图片描述

7.8指针、数组、函数

案例描述:封装一个函数,利用冒泡排序,实现对整型数组的升序排序
例如数组:int arr[10]={4,3,6,9,1,2,10,8,7,5}
步骤:
1、先创建数组:
2、创建函数,实现冒泡排序
3、打印排序后的数组

void paixu(int *arr,int changdu)
{
	for (int i = 0; i < changdu - 1; i++)
	{
		for (int j = 0; j < changdu - 1 - i; j++)
		{
			if(arr[j]>arr[j+1])
				{
					int temp = arr[j];
					arr[j]=arr[j+1];
				   arr[j+1]=temp;
				}
		}
	}
}

void printArray(int* arr, int changdu)
{
	for (int i = 0; i < changdu; i++)
	{
		cout << arr[i] << endl;
	}
}

int main()
{
	int arr[10] = { 4,3,6,9,1,2,10,8,7,5 };
	int changdu = sizeof(arr) / sizeof(arr[0]);
	paixu(arr, changdu);
	printArray(arr, changdu);
		system("pause");
		return 0;
}

int x = 3;
const int* p1 = &x;
*p1 = 3;
故常量指针所指向的值不变

int * const p2 = &x;
p2 = &x;
故指针常量所指向的地址不变;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值