指针的作用:可以通过指针间接访问内存。
指针所占内存空间:
空指针:指针变量指向内存编号为0的空间;
作用:初始化指针变量;
注意:空指针指向的内存不可以访问。
0~255之间的内存编号是系统占用的,因此不可以访问。
野指针:指针变量指向非法的内存空间;
空指针和野指针都不是我们申请的空间,因此不要访问,访问会报错。
const修饰指针
先出现const,后出现*,则是常量指针;
先出现* ,后出现const,则是指针常量;
const后紧跟指针*,则const不能进行解引用*p对指针指向的值进行修改; // *p = 100;
const后紧跟常量p,则不能对p进行指向的操作; // p = &b;
指针和数组
作用:利用指针访问数组中的元素。
指针和函数
作用:利用指针作函数参数,可以修改实参的值。
封装一个函数,利用冒泡排序,实现对整型数组的升序排序
传入数组首地址,在定义函数接收数组时,使用指针来接收
#include <iostream>
using namespace std;
// 冒泡排序函数 参数1 数组的首地址 参数2 数组的长度
void BubbleSort(int *arr, int len)
{
for (int i = 0; i < len - 1; i++)
{
for (int j = 0; j < len - i - 1; j++)
{
// 如果j>j+1的值,交换数字
if(arr[j] > arr[j+1])
{
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
// 打印数组元素
void PrintArr(int *arr, int len)
{
for(int i = 0; i < len; i++)
{
cout << arr[i] << " ";
}
}
int main()
{
int arr[10] = {4,3,6,9,1,2,10,8,7,5};
int len = sizeof(arr) / sizeof(arr[0]);
// 调用BubbleSort函数
BubbleSort(arr, len);
// 调用PrintArr函数
PrintArr(arr, len);
cout << endl;
system("pause");
return 0;
}