c2-C语言--指针

2023-12-11 15:04
文章标签 语言 指针 c2

本文主要是介绍c2-C语言--指针,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.用一级指针遍历一维数组
结论
buf[i]<===>*(buf + i) <===> *(p + i)<===> p[i]
 

#include <stdio.h>int main(){int buf[5] = {10,20 ,30 ,40,50};
//buf[0]  --- int
// buf  --&buf[0]  =----int *int *p =buf;//&buf[0]  --- &*(buf+0)printf("%p\n",p);printf("%p\n",&buf[0]);printf("%p\n",p+1);//0x7ffc2eb07e74  偏4printf("%p\n",(&buf+1));//0x7ffc2eb07e84 偏20return 0;}

一维数组 &a[O]和&a之间的关系
 

a[O]为int类型,故&a[O]+1一次偏移一个int类型的大小,4 bytes。
a为int [5]类型,故&a +1一次偏移一个int [5]类型的大小,20 bytes。
 

内存模型

1.定义数组是在栈区申请空间,栈区的空间有读写的权限,可以修改数据。
 

2定义指针保存字符串,指针变量是在栈区申请的空间,字符串是在常量区分配。

指针保存的是内存中常量区空间的地址,常量区空间只有读权限,没有写权限,不能更改数据。
 

内核空间和用户空间
对于32位环境,理论上程序可以拥有4GB的虚拟地址空间,我们在C语言中使用到的变量、函数、字符串等都会对应内存中的一块区域。但是,在这4GB的地址空间中,要拿出一部分给操作系统内核使用,应用程序无法直接访问这一段内存,这一部分内存地址被称为内核空间(Kernel Space) 。
而Linux默认情况下会将高地址的1GB空间分配给内核。也就是说,应用程序只能使用剩下的3GB的地址空间,称为用户空间(User Space)。下图是Linux下32位环境的一种经典内存模型:

一级指针的特点

1.在32bit的操作系统中,所有的指针类型都是占4bytes .
2.大端模式:低地址存高位
小端模式:低地址存低位
3.不同类型的指针的,同对一块内存对齐的时候,读取的位它保存对象的大小的.
char *p;
short *q;

int*m;

*p ;//1

*q; //2

*m;//4
 

我的总结;

对齐的时候

移动的时候

应该是说指针偏移:

当不同类型的指针指向同一块内存,并且对齐要求得到满足时,读取指针所指向对象的大小是由指针的类型决定的。指针的类型决定了指针的步长,即指针在内存中移动的字节数。

例如,假设有一个`int`类型的指针`int* p`和一个`char`类型的指针`char* q`,它们都指向相同的内存块,且内存对齐要求得到满足。那么,使用`*p`来读取该内存块中所保存的对象时,将会按照`int`类型的大小来读取,即读取4个字节;而使用`*q`来读取同一块内存时,则按照`char`类型的大小来读取,即读取1个字节。

这是由于指针在进行间接访问时会根据自身的类型确定要读取的字节数。指针类型与所指向对象的大小息息相关,不同类型的指针具有不同的步长,因此读取的字节数目也会不同。

不同类型的指针,在移动的时候,每次移动的大小也是它保存对象的大小
 

指针数组

不要只看答案:  思考 ,  为什么 这么巧妙:   可以处理的额:刚好 是在哎 指针 数组里面,  刚好 成员 移动一个 就是 对方的地址;

二级指针 来保存  指针数组的首地址

二级指针可以用来保存指针数组的首地址。指针数组是一个数组,其中每个元素都是一个指针。而二级指针是一个指针,它可以指向其他指针的地址。

假设有一个指针数组`int* arr[]`,它存储了一组`int`类型的指针。如果我们要保存指针数组的首地址,可以使用一个二级指针进行存储。

示例代码如下所示:

```c++
int* arr[5]; // 假设有一个指针数组
int** ptr = arr; // 使用二级指针保存指针数组的首地址
```

在上述代码中,`arr`是一个指针数组,每个元素都是`int*`类型的指针。`ptr`是一个二级指针,它被赋值为`arr`,即保存了指针数组的首地址。

通过使用二级指针,我们可以在需要的时候获取到指针数组的首地址,并通过间接操作来访问或修改指针数组中的元素。

扩展小知识:

3 写出int 、bool、 float 、指针变量与 “零值”比较的if 语句

//int与零值比较
if ( n == 0 )
if ( n != 0 )//bool与零值比较
if (flag) // 表示flag为真
if (!flag) // 表示flag为假//float与零值比较
const float EPSINON = 0.00001;
if ((x >= - EPSINON) && (x <= EPSINON) //其中EPSINON是允许的误差(即精度)。//指针变量与零值比较
if (p == NULL)
if (p != NULL)

再扩充:

4 结构体可以直接赋值吗

  • 声明时可以直接初始化,
  • 同一结构体的不同对象之间也可以直接赋值,但是当结构体中含有指针“成员”时一定要小心。
    注意:当有多个指针指向同一段内存时,某个指针释放这段内存可能会导致其他指针的非法操作。因此在释放前一定要确保其他指针不再使用这段内存空间

这篇关于c2-C语言--指针的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/481109

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

人工和AI大语言模型成本对比 ai语音模型

这里既有AI,又有生活大道理,无数渺小的思考填满了一生。 上一专题搭建了一套GMM-HMM系统,来识别连续0123456789的英文语音。 但若不是仅针对数字,而是所有普通词汇,可能达到十几万个词,解码过程将非常复杂,识别结果组合太多,识别结果不会理想。因此只有声学模型是完全不够的,需要引入语言模型来约束识别结果。让“今天天气很好”的概率高于“今天天汽很好”的概率,得到声学模型概率高,又符合表达

C语言 将“China”译成密码

将“China”译成密码,密码规律是:用原来的字母后面的第4个字母代替原来的字母。例如,字母“A”后面的第4个字母是“E”,用“E”代替“A”。因此,“China”应译为“Glmre”。编译程序用付赋初值的方法使c1,c2,c3,c4,c5这五个变量的值分别为“C”,“h”,“i”,“n”,“a”,经过运算,使c1,c2,c3,c4,c5分别变成“G”,“l”,“m”,“r”,“e”。分别用put

C语言入门系列:探秘二级指针与多级指针的奇妙世界

文章目录 一,指针的回忆杀1,指针的概念2,指针的声明和赋值3,指针的使用3.1 直接给指针变量赋值3.2 通过*运算符读写指针指向的内存3.2.1 读3.2.2 写 二,二级指针详解1,定义2,示例说明3,二级指针与一级指针、普通变量的关系3.1,与一级指针的关系3.2,与普通变量的关系,示例说明 4,二级指针的常见用途5,二级指针扩展到多级指针 小结 C语言的学习之旅中,二级

利用结构体作为函数参数时结构体指针的定义

在利用结构体作为函数的参数进行传递时,容易犯的一个错误是将一个野指针传给函数导致错误。 #include <stdio.h>#include <math.h>#include <malloc.h>#define MAXSIZE 10typedef struct {int r[MAXSIZE]; //用于存储要排序的数组,r[0]作为哨兵或者临时变量int length;

【LinuxC语言】select轮询

文章目录 前言select函数详解selectfd_set类型一个小问题select函数使用步骤改进服务器代码select服务器示例代码 总结 前言 在Linux C语言编程中,我们经常需要处理多个I/O操作。然而,如果我们为每个I/O操作创建一个线程,那么当I/O操作数量增加时,线程管理将变得复杂且效率低下。这就是我们需要select轮询的地方。select是一种高效的I/

拓扑排序——C语言

拓扑排序(Topological Sorting)是一种用于有向无环图(DAG)的排序算法,其输出是图中所有顶点的线性排序,使得对于每条有向边 (u, v),顶点 u 在 v 之前出现。拓扑排序确定了项目网络图中的起始事件和终止事件,也就是顶点的执行顺序。         因为是有向无环图,所以拓扑排序的作用其实就是把先发生的排序在前面,后发生的排序到后面。 例如现在我们有一个

OC和 C语言中的const

const与宏对比 1.都是在其他的地方不可以改变 2.一个地方改了其他的地方都会改变。 而且宏定义的缺陷是, 是它会不断的开辟临时变量的存储空间 使用const的话 是都去使用同一的一份空间,使用同一个对象。 加const 之后变量还是全局的,只不过变为全局常量。 如果此时改变量不想被被类外面访问的话,可以加上static关键字, 3.下次想要定义一些宏的时候分

isa指针的理解

D3实例isa指向D3类对象。D3类的话isa指向D3元类对象。D3元类保存类中的方法调度列表,包括类方法和对象方法