入门
认识指针
#include<iostream>
using namespace std;
int main(void)
{
// 1定义指针
int a=10;
//指针定义语法:数据内型*指针变量名;
int*p;
//让指针记录变量a的地址
p = &a;
cout<<"a的地址"<<&a<<endl<<endl;
cout<<"指针p:"<<p<<endl<<endl;
//2使用指针
//可以通过解引用找到指针指向的内存
//指针前加*代表解引用,找到指针指向的内存数据
*p = 1000; //找到a并修改他
cout<<"a ="<<a<<endl;
cout<<"*p ="<<*p<<endl;
return 0;
}
指针的大小
用sizeof计算出指针的大小
#include<iostream>
using namespace std;
int main(void)
{
//指针所占内存空间
int a=10;
//int * p;
//p = &a;
int*p =&a;
//32位(x86)4字节
//64位(x64)8字节
//所有
cout<<"int * = "<<sizeof(int*)<<endl;
cout<<"float * = "<<sizeof(float*)<<endl;
cout<<"double * = "<<sizeof(double*)<<endl;
cout<<"char * = "<<sizeof(char*)<<endl;
return 0;
}
不同的编译方式就会出现不同的大小
注意事项
空指针(错误的)
#include<iostream>
using namespace std;
int main(void)
{
//空指针
//空指针用于给指针变量初始化
int*p =NULL;
//空指针不可访问
//因为0~255是系统占用的不可访问
return 0;
}
野指针(错误的)
#include<iostream>
using namespace std;
int main(void)
{
//野指针
//程序中,避免野指针
int*p =(int *)0x1100;
cout<<*p<<endl;
return 0;
}
进阶
const修饰指针
#include <iostream>
using namespace std;
int a = 10;
int b = 10;
int main(void)
{
// 1 const 修饰指针
// 常量指针
const int *p = &a; // 不可改值
//******错误********
// *p = 20
//******错误********
p = &b; // 可该指向
//************************************************* */
// 2 const修饰常量
// 指针常量
int *const p2 = &a; // 不可该指向
//******错误********
// p2 = &b
//******错误********
*p2 = 100; // 可改值
/******************************************************* */
// 3 const修饰指针和常量
const int* const p3 =&a; //都不可改
return 0;
}
指针和数组结合
#include <iostream>
using namespace std;
int main(void)
{
//****** 指针和数组 ***** */
// 利用指针访问数组的元素
int arr[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
cout << "第一个元素 " << arr[0] << endl;
int *p = arr; // arr就是数组的首地址
cout << "指针访问第一个元素 " << *p << endl;
cout<<endl<<endl<<endl; //全是空行不用理
cout<<"利用指针访问所有"<<endl;
int *p2 = arr;
for(int i;i<10;i++)
{
cout<<"指针访问第"<<i<<"个元素:"<<*p2<<endl;
p2++;
}
return 0;
}
运行结果
第一个元素 1
指针访问第一个元素 1
利用指针访问所有
指针访问第0个元素:1
指针访问第1个元素:2
指针访问第2个元素:3
指针访问第3个元素:4
指针访问第4个元素:5
指针访问第5个元素:6
指针访问第6个元素:7
指针访问第7个元素:8
指针访问第8个元素:9
指针访问第9个元素:10
指针、函数、数组(冒泡排序)
#include <iostream>
using namespace std;
// 冒泡排序函数 参数1:首地址 参数2:函数长度
void maopao(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 sb(int *arr,int len)
{
for (int i = 0; i < len; i++)
{
cout << arr[i] << endl;
}
}
int main(void)
{
// 1、先创建数组
int arr[10] = {4, 3, 6, 9, 1, 2, 10, 8, 7, 5};
// 数组长度
int len = sizeof(arr) / sizeof(arr[0]);
// 2 创建函数 实现冒泡排序
maopao(arr, len);
// 3 打印排序后的数组
sb(arr, len);
return 0;
}
运行结果
1
2
3
4
5
6
7
8
9
10