C++复习day01

这篇博客主要复习C语言的数组和指针

1.指针数组和数组指针

问:指针数组和数组指针,哪一个是指针,哪一个是数组?
我们来类比一下,整型数组是存放整型的数组,那么指针数组就是一个存放指针的数组,自然而然,数组指针就是一个指向数组的指针

#include <iostream>

int main()
{
	int a = 1, b = 2, c = 3;
	int* p1 = &a, * p2 = &b, * p3 = &c;
	int* arr[] = { p1,p2,p3 }; //指针数组
	int** ptr = arr; //数组指针
	return 0;
}
2.函数指针

这个有点特殊,所以单独拿出来做一下介绍
首先,函数指针变量应该是⽤来存放函数地址的,未来通过地址能够调⽤函数的。这个函数一定是有地址的

#include <iostream>
void solve()
{
	std::cout << "今天是复习C++的第一天" << std::endl;
}
int main()
{
	std::cout << solve << std::endl; //00C3137A
	std::cout << &solve << std::endl; //00C3137A
	return 0;
}

可以发现,对函数名取地址和原来的函数名效果相同------也就是说函数名就是地址,同样取函数的地址也可以使用"&函数名"的方法,二者是等效的
提出问题:那么什么叫做函数指针?
回答:顾名思义,就是一个指向函数的指针,请看"VCR"

int (*pf) (int x, int y)
 | | ------------
 | | |
 | | pf指向函数的参数类型和个数的交代
 | 函数指针变量名
 pf指向函数的返回类型
int (*) (int x, int y) //pf函数指针变量的类型

下面来举一个例子

#include <iostream>

int add(int x, int y)
{
	return x + y;
}
int main()
{
	//以add()函数为例
	int (*p)(int, int) = add;
	std::cout << p(1, 2) << std::endl; //3
	std::cout << (*p)(1, 2) << std::endl; //3
	return 0;
}

下面来看,两个比较难的例子,尽量去分析一下

(*(void (*)())0)();

void (*signal(int , void(*)(int)))(int);

来分析一下,首先是第一个式子
(void (*)())很明显是一个函数指针类型,意思就是把**int**类型的0强制转化为一个函数指针类型,然后对它解引用,并且调用它

第二个例子
signal的第一个参数的int类型,第二个参数是"void(*)int的函数指针类型",signnal的返回值也是"void(*)int的函数指针类型",如果typedef void(*func)(int),之后就相当于func signal(int,func)
3.const和指针

const和*的位置不同,会有不一样的效果,他们被称作是指针常量,常量指针

#include <iostream>

int main()
{
	int a = 1, b = 2;
	const int* p1 = &a;
	int const* p2 = &a;
	int* const p3 = &a;
	p1 = &b;
	p2 = &b;
	//p3 = &b; 这个会报错,因为p3是指针常量,指针的指向不能修改,但是指针指向的值可以修改

	//*p1 = 100;
	//*p2 = 100; 这两个会报错,因为p1,p2都是常量指针,指针的指向可以改变,但是指针指向的值不能改变
	*p3 = 100;
	return 0;
}
4.sizeof,数组,指针

数组名的意义

  1. sizeof(数组名),这⾥的数组名表⽰整个数组,计算的是整个数组的⼤⼩。

  2. &数组名,这⾥的数组名表⽰整个数组,取出的是整个数组的地址。

  3. 除此之外所有的数组名都表⽰⾸元素的地址。

    #include <iostream>

    int main()
    {
    int arr[] = { 1,2,3,4,5 };
    int* ptr = arr;
    std::cout << "sizeof(arr) = " << sizeof(arr) << std::endl;
    std::cout << "sizeof(ptr) = " << sizeof(ptr) << std::endl;
    return 0;
    }

5.sizeof和strlen的区别

sizeof :在学习操作符的时候,我们学习了 sizeof , sizeof 计算变量所占内存内存空间⼤⼩的,单位是

字节,如果操作数是类型的话,计算的是使⽤类型创建的变量所占内存空间的⼤⼩。sizeof 只关注占⽤内存空间的⼤⼩,不在乎内存中存放什么数据
strlen :strlen 是C语⾔库函数,功能是求字符串⻓度。
sizeof 和 strlen的对⽐

sizeof strlen
sizeof是操作符 strlen是库函数
sizeof计算操作数所占内存的⼤⼩,单位是字节 srtlen是求字符串⻓度的,统计的是 \0 之前字符的隔个数
不关注内存中存放什么数据 关注内存中是否有 \0 ,如果没有 \0 ,就会持续往后找,可能会越界
相关推荐
工业3D_大熊14 分钟前
3D可视化引擎HOOPS Luminate场景图详解:形状的创建、销毁与管理
java·c++·3d·docker·c#·制造·数据可视化
暮色_年华28 分钟前
Modern Effective C++ Item 11:优先考虑使用deleted函数而非使用未定义的私有声明
c++
流星白龙31 分钟前
【C++习题】10.反转字符串中的单词 lll
开发语言·c++
Smile丶凉轩1 小时前
微服务即时通讯系统的实现(服务端)----(1)
c++·git·微服务·github
肥猪猪爸1 小时前
使用卡尔曼滤波器估计pybullet中的机器人位置
数据结构·人工智能·python·算法·机器人·卡尔曼滤波·pybullet
linux_carlos1 小时前
环形缓冲区
数据结构
readmancynn1 小时前
二分基本实现
数据结构·算法
萝卜兽编程1 小时前
优先级队列
c++·算法
Bucai_不才1 小时前
【数据结构】树——链式存储二叉树的基础
数据结构·二叉树
盼海1 小时前
排序算法(四)--快速排序
数据结构·算法·排序算法