C++学习路线(十六)

void类型指针

void -> 空类型

void* -> 空类型指针,只存储地址的值,丢失类型,无法访问,要访问里面的值

我们必须对指针进行正确的类型转换,然后再间接引用指针

所有其它类型的指针都可以隐式自动转换成 void 类型指针,反之需要强制转换。

cpp 复制代码
int arr[] = { 1, 2, 3, 4, 5 };
char ch = 'a';
void* ptr = arr;
printf("0x%p\n", ptr);
printf("%d\n", *(int*)ptr);

而且 **void***指针 不允许算术运算

常见错误总结

1.使用未初始化指针

这里面去描述两种场景说明使用未初始化指针的场景

第一种场景 未初始化就使用

int x, * p;

x = 10;

printf("%p\n", p);

p = &x;

第二种场景 比较常见

void func(int* p) {

static int count = 50;

p = &count;

}

int main() {

int x, * p;

func(p);

cout << "p = " << p << endl;

}

怎么解决上面的问题 之前的笔记有提到过 使用二级指针

cpp 复制代码
#include <iostream>
using namespace std;

void func(int** p) {
	static int count = 50;
	*p = &count;
}

int main() {
	int x, * p;
	func(&p);
	cout << "p = " << p << endl;
}

2.将值当作地址赋值给指针

怎么解决

1)*p = x;

2)p = &x;

3.忘记解引直接访问内存

cpp 复制代码
char input[64] = { 'h', 'e', 'l', 'l', 'o' };
char* p1, * p2;
p1 = &input[0];
p2 = &input[1];
if (p1 > p2) {
	cout << "p1 is greater than p2" << endl;
}
else {
	cout << "p2 is greater than p1" << endl;
}
return 0;

这种情况下 会打印 "p2 is greater than p1"

cpp 复制代码
#include <iostream>
using namespace std;

int main() {
	char input[64] = { 'h', 'e', 'l', 'l', 'o' };
	char* p1, * p2;
	p1 = &input[0];
	p2 = &input[1];
	if (*p1 > *p2) {
		cout << "p1 is greater than p2" << endl;
	}
	else {
		cout << "p2 is greater than p1" << endl;
	}
	return 0;
}

4.常见的错误4:再次使用忽略重新赋初值

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

int main() {
	char input[64];
	char* p1 = input;
	do {
		gets_s(input, 64);
		while (*p1 != '\0') printf("%c", *p1++);
	} while (strcmp(input, "exit") != 0);
	return 0;
}

这种只能打印第一个数字 因为p1没有被重新赋值给input

正确的做法是

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

int main() {
	char input[64];
	char* p1;
	do {
		printf("Enter a string: ");
		gets_s(input, 64);
		p1 = input;
		while (*p1 != '\0') printf("%c", *p1++);
		printf("\n");
	} while (strcmp(input, "exit") != 0);
	return 0;
}

常量引用

在C++中可以声明const引用

语法:const Type&name = var;

const引用让变量拥有只读属性

|---------------|
| 分两种情况: |
| 1.用变量初始化常引用 |
| 2.用字面量初始化常量引用 |

cpp 复制代码
// 使用变量初始化常量引用
int a = 10;
const int& b = a;
// 用字面量初始化常量引用
const int& c = 20;//会给引用分配内存空间

函数指针

我们来探究一下 函数有没有指针

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

int compare_int(const void* a, const void* b) {
	int* pa = (int*)a;
	int* pb = (int*)b;
	cout << "pa地址:" << &pa << endl;
	cout << "pb地址:" << &pb << endl;
	return *pa - *pb;
}

int main() {
	// 函数有没有地址?
	cout << "compare_int: " << &compare_int << endl;
	int x = 10, y = 20;
	compare_int(&x, &y);
	return 0;
}

函数指针的定义

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

int compare_int(const void* a, const void* b) {
	int* pa = (int*)a;
	int* pb = (int*)b;
	cout << "pa地址:" << &pa << endl;
	cout << "pb地址:" << &pb << endl;
	return *pa - *pb;
}

int main() {
	// 函数有没有地址?
	int(*ptr)(const void*, const void*) = &compare_int;
	int x = 10, y = 20;
	//函数指针有两种调用方式
	//1.解引用方式调用
	(*ptr)(&x, &y);
	//2.直接调用
	ptr(&x, &y);
	return 0;
}

上面这个是函数指针和void*指针的应用

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

int compare_int(const void* a, const void* b) {
	int* pa = (int*)a;
	int* pb = (int*)b;
	return *pa - *pb;
}

int main() {
	// 函数有没有地址?
	int arr[12] = { 1, 3, 5, 7, 9, 2, 4, 6, 8, 10, 11, 12 };
	int(*ptr)(const void*, const void*) = &compare_int;
	int x = 10, y = 20;
	qsort(arr, sizeof(arr) / sizeof(arr[0]), sizeof(arr[0]), ptr);
	cout << "After sorting: ";
	for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++) {
		cout << arr[i] << " ";
	}
	return 0;
}

qsort也可以对char数组进行排序

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

int compare_int(const void* a, const void* b) {
	int* pa = (int*)a;
	int* pb = (int*)b;
	return *pa - *pb;
}

int compare_char(const void* a, const void* b) {
	char* pa = (char*)a;
	char* pb = (char*)b;
	return *pa - *pb;
}

int main() {
	// 函数有没有地址?
	char charArray[] = "asodifoadfjdvn";
	int(*pCompare)(const void*, const void*) = &compare_char;
	qsort(charArray, sizeof(charArray) / sizeof(char), sizeof(char), pCompare);
	for (int i = 0; i < sizeof(charArray) / sizeof(char); i++) {
		cout << charArray[i];
	}
	return 0;
}
相关推荐
时光找茬10 分钟前
【瑞萨AI挑战赛-FPB-RA6E2】+ 从零开始:FPB-RA6E2 开箱测评与 e2 studio 环境配置
c++·单片机·边缘计算
qq_5375626710 分钟前
跨语言调用C++接口
开发语言·c++·算法
wjs202420 分钟前
DOM CDATA
开发语言
Tingjct22 分钟前
【初阶数据结构-二叉树】
c语言·开发语言·数据结构·算法
猷咪1 小时前
C++基础
开发语言·c++
IT·小灰灰1 小时前
30行PHP,利用硅基流动API,网页客服瞬间上线
开发语言·人工智能·aigc·php
快点好好学习吧1 小时前
phpize 依赖 php-config 获取 PHP 信息的庖丁解牛
android·开发语言·php
秦老师Q1 小时前
php入门教程(超详细,一篇就够了!!!)
开发语言·mysql·php·db
烟锁池塘柳01 小时前
解决Google Scholar “We‘re sorry... but your computer or network may be sending automated queries.”的问题
开发语言
是誰萆微了承諾1 小时前
php 对接deepseek
android·开发语言·php