C++入门基础Chapeter05指针

1、定义指针

int a = 10;
//指针定义的语法:数据类型 * 指针变量名;
int* p;
//让指针记录变量a的地址
p = &a;

//输出的为16进制的地址
cout << "a的地址为:" << &a << endl;
cout << "指针p为:" << p << endl;

//输出结果为:

a的地址为:0079FBB0
指针p为:0079FBB0

2、使用指针
作用:可以通过解引用的方式来找到指针指向的内存
解引用:*p(在指针的前面加 ’ *’ ),找到指针指向的内存的数据

*p = 1000;
cout << "a = " << a << endl;
cout << "*p = " << *p << endl;

输出结果为:

a = 1000
*p = 1000

3、指针所占用空间
占用空间:
1)在32位操作系统下:占用4个字节空间
2)在64位操作系统下:占用8个字节空间
3)编译时的操作系统更改方式:解决方案平台上将x86改为x64

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

//以下两个输出结果相同
//原理:变量p的类型就是int*,sizeof()所输出的就是此指针所占用空间

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

输出结果为:sizeof(int*) = 4

4、空指针:指针指向内存中编号为0的空间
1)用途:空指针用于给指针变量进行初始化
int* p = NULL;//当前p的地址为0

2)注意:空指针是不可以进行访问的
//0~255之间的内存编号是系统占用的,因此不可以访问
//此时若是输入:*p = 100; 便会发生编译错误

5、野指针:指针变量指向非法的内存空间

int* p = (int*)0x1100;
cout << *p << endl;

PS:这段代码报错原因:为p指针开辟空间之后,指向的却是另一块地址,但是你没有权限对另一块地址进行修改

扫描二维码关注公众号,回复: 16810721 查看本文章

注意:空指针和野指针都不是我们申请的空间,因此不要访问

6、const修饰指针

int a = 10;
int b = 10;

有三种情况:
1)const修饰指针—常量指针
//特点:指针的指向可以修改,但是指针指向的值不可更改

const int* p = &a;

2)const修饰常量—指针常量
//特点:指针的指向不可以修改,但是指针的值可以改

int* const p = &a;

3)const既修饰指针,又修饰常量
//特点:指针的指向、指针的值都不可修改

const int* const p = &a;

7、指针和数组

int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
	cout << "第一个元素:" << arr[0] << endl;

//利用指针访问数组中的元素

int* p = arr;//数组名就是数组的首地址
cout << "利用指针访问第一个元素:" << *p << endl;
p++;//指针向后偏移4个字节
cout << "利用指针访问第二个元素:" << *p << endl;
cout << "利用指针遍历数组:" << endl;
int* p2 = arr;
for (int i = 0; i < 10; i++)
{
	cout << arr[i] << endl;
	cout << *p2 << endl;
	p2++;
}

8、指针和函数
1)值传递(传入的参数,实参不变)
2)地址传递(传入的引用参数/指针的地址,实参改变)

void swap02(int *p1, int *p2) 
 {
    int temp = *p1;
    *p1 = *p2;
    *p2 = temp;
}
void main()
{
    int a = 10;
    int b = 20;
        
    swap02(&a, &b);
    cout << "a = " << a << endl;
   	cout << "b = " << b << endl;
}

9、指针、数组、函数结合实例
问题描述:封装一个函数,利用冒泡排序,实现对整型数组的升序排序
例如数组:

//冒泡排序函数
void bubbleSort(int* arr, int len)
{
	for (int i = 0; i < len; i++)
	{
		for (int j = 0; j < len - 1; 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 len)
{
   	for (int i = 0; i < len; i++)
   	{
   		cout << arr[i] << " ";
   	}
}
void main()
{
    int arr[10] = { 4,3,6,9,1,2,10,8,7,5 };
    //数组长度
    int len = sizeof(arr) / sizeof(arr[0]);
            
    bubbleSort(arr, len);
    printArray(arr, len);
            
    //卡住程序(一般不使用,内存开销大,可移植性差)
    system("pause");
}

猜你喜欢

转载自blog.csdn.net/qq_43036676/article/details/100140713