C语言复习概要(六)
公主请阅
- 1. 深入理解数组与指针在C语言中的应用
- 1.1 数组名的理解
- 2. 使用指针访问数组
- 3. 一维数组传参的本质
- 4. 冒泡排序的实现
- 5. 二级指针
- 6. 指针数组
- 7. 指针数组模拟二维数组
- 8.总结
1. 深入理解数组与指针在C语言中的应用
数组与指针是C语言的核心概念之一,理解它们的本质及其相互关系是成为C语言高手的必经之路。数组为我们提供了一种存储大量相同类型数据的高效方式,而指针则为操作这些数据提供了极大的灵活性。本文将从数组名与指针的基本理解出发,深入探讨指针与数组的结合使用,并通过经典的冒泡排序算法和多级指针操作举例说明。
1.1 数组名的理解
数组是存储相同类型数据的线性结构。一个简单的一维数组的声明如下:
int arr[5] = {1, 2, 3, 4, 5};
在这个例子中,arr
是一个包含5个int
类型元素的数组。但是在更底层的C语言内存模型中,数组名实际上是一个常量指针,它指向数组的第一个元素的地址。也就是说,arr
的值是&arr[0]
。但需要注意的是,数组名本身是一个常量,不能像普通指针一样被重新赋值。
例如,下面的代码将会报错:
arr = &x; // 错误:数组名是常量,不能被赋值
这一点解释了为什么我们可以通过指针的方式来访问数组的元素:
int *p = arr;
在这个例子中,p
指向arr[0]
,也就是数组的第一个元素。通过指针p
,我们可以轻松访问整个数组元素:
for (int i = 0; i < 5; i++) {printf("%d ", *(p + i)); // 输出:1 2 3 4 5
}
这说明数组名其实是一种特殊的指针,它和指针的行为非常相似,但在某些情况下,数组名与普通指针的行为略有不同。
2. 使用指针访问数组
使用指针访问数组是C语言中非常常见的操作,它可以提高程序的效率。我们可以通过指针遍历数组,而不是通过索引。
假设有一个数组:
int arr[5] = {10, 20, 30, 40, 50};
你可以通过指针访问数组的每一个元素:
int *ptr = arr;for (int i = 0; i < 5; i++) {printf("Element %d: %d\n", i, *(ptr + i));
}
这里,ptr + i
表示指向数组中第i
个元素的指针,而*(ptr + i)
则解引用该指针,得到对应的值。通过指针直接访问数组元素,避免了使用数组下标的额外计算,从而提升了访问速度。
3. 一维数组传参的本质
在C语言中,函数传递数组参数实际上是传递指针。让我们来看看一个示例:
void printArray(int *arr, int size) {for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}
}
在这里,arr
实际上是一个指向数组的指针,而不是整个数组。当我们调用这个函数时,传递的实际上是数组的地址:
int arr[5] = {1, 2, 3, 4, 5};
printArray(arr, 5);
这种方式使得数组传参非常高效,因为只需传递数组的首地址即可,而不是整个数组的内容。这样可以节省大量的内存和时间,特别是在处理大型数组时。
4. 冒泡排序的实现
冒泡排序是一种经典的排序算法,借助数组和指针的结合,我们可以用更灵活的方式实现它。让我们看看如何用指针来实现冒泡排序:
void bubbleSort(int *arr, int size) {for (int i = 0; i < size - 1; i++) {for (int j = 0; j < size - i - 1; j++) {if (*(arr + j) > *(arr + j + 1)) {// 交换两个元素int temp = *(arr + j);*(arr + j) = *(arr + j + 1);*(arr + j + 1) = temp;}}}
}
在这个例子中,我们通过指针访问数组中的元素并进行交换。与直接使用数组下标相比,使用指针能更加灵活地操作内存地址。
5. 二级指针
二级指针(即指向指针的指针)是C语言中的另一个重要概念。它常用于动态分配二维数组或在函数中修改指针的值。假设我们需要通过函数来修改一个指针的指向:
void modifyPointer(int **p) {static int x = 10;*p = &x;
}
在这个例子中,p
是一个二级指针,它指向一个指针。通过解引用p
,我们可以改变一级指针的值。在函数调用中:
int *ptr = NULL;
modifyPointer(&ptr);
printf("%d\n", *ptr); // 输出:10
这展示了如何通过二级指针在函数中修改一级指针的值。
6. 指针数组
指针数组是一个存储指针的数组。它通常用于存储一组字符串或指向其他数组的指针。让我们看看一个指针数组的例子:
char *names[] = {"Alice", "Bob", "Charlie", "David"};for (int i = 0; i < 4; i++) {printf("%s\n", names[i]);
}
在这个例子中,names
是一个指针数组,每个元素都是一个指向字符串的指针。通过遍历指针数组,我们可以输出每个字符串。
指针数组在处理动态内存分配和多维数组时非常有用。
7. 指针数组模拟二维数组
二维数组是一种常见的数据结构,但有时候我们需要使用指针数组来模拟二维数组,以获得更大的灵活性。例如,以下代码演示了如何使用指针数组来动态创建一个二维数组:
int rows = 3, cols = 4;
int **arr = (int **)malloc(rows * sizeof(int *));
for (int i = 0; i < rows; i++) {arr[i] = (int *)malloc(cols * sizeof(int));
}// 为数组赋值
for (int i = 0; i < rows; i++) {for (int j = 0; j < cols; j++) {arr[i][j] = i * cols + j;}
}// 打印数组
for (int i = 0; i < rows; i++) {for (int j = 0; j < cols; j++) {printf("%d ", arr[i][j]);}printf("\n");
}// 释放内存
for (int i = 0; i < rows; i++) {free(arr[i]);
}
free(arr);
这里,我们首先分配了一个存储行指针的数组,然后为每一行分配内存。这种方法使得我们可以根据需要动态调整二维数组的大小。
8.总结
数组与指针是C语言中的基础概念,但它们的结合使用可以极大提高程序的灵活性和效率。通过理解数组名的本质、指针访问数组、函数传参中的指针使用、以及指针数组与多级指针的应用,我们可以编写出高效且灵活的C程序。冒泡排序和二维数组的指针模拟为我们展示了指针在实际算法和数据结构中的应用。掌握这些技巧和概念,将帮助你在C语言编程中走得更远。
相关文章:

C语言复习概要(六)
公主请阅 1. 深入理解数组与指针在C语言中的应用1.1 数组名的理解 2. 使用指针访问数组3. 一维数组传参的本质4. 冒泡排序的实现5. 二级指针6. 指针数组7. 指针数组模拟二维数组8.总结 1. 深入理解数组与指针在C语言中的应用 数组与指针是C语言的核心概念之一,理解…...

PyQt 入门教程(2)搭建开发环境
文章目录 一、搭建开发环境1、安装PyQt5与pyqt5-tools2、配置QtDesigner3、配置Pyuic4、配置Pyrcc 一、搭建开发环境 1、安装PyQt5与pyqt5-tools PyQt5: PyQt的开发库。Pyqt5-tools: 它是一个包含多种工具的工具包,旨在帮助开发者更方便地使…...

Flink Kubernetes Operator
Flink Kubernetes Operator是一个用于在Kubernetes集群上管理Apache Flink应用的工具。 一、基本概念 Flink Kubernetes Operator允许用户通过Kubernetes的原生工具(如kubectl)来管理Flink应用程序及其生命周期。它简化了Flink应用在Kubernetes集群上的…...

【最新华为OD机试E卷-支持在线评测】字符统计及重排(100分)多语言题解-(Python/C/JavaScript/Java/Cpp)
🍭 大家好这里是春秋招笔试突围 ,一枚热爱算法的程序员 💻 ACM金牌🏅️团队 | 大厂实习经历 | 多年算法竞赛经历 ✨ 本系列打算持续跟新华为OD-E/D卷的多语言AC题解 🧩 大部分包含 Python / C / Javascript / Java / Cpp 多语言代码 👏 感谢大家的订阅➕ 和 喜欢�…...

springboot使用GDAL获取tif文件的缩略图并转为base64
springboot使用GDAL获取tif文件的缩略图并转为base64 首先需要安装gdal:https://blog.csdn.net/qq_61950936/article/details/142880279?spm1001.2014.3001.5501 然后是配置pom.xml文件: <!--处理缩略图的--><dependency><groupId>o…...

Pytorch——pip下载安装pytorch慢的解决办法
一、找到需要下载的pytorch链接 运行:pip install torch1.11.0cu113 torchvision0.12.0cu113 torchaudio0.11.0 --extra-index-url https://download.pytorch.org/whl/cu113。然后得到: 我这里为:https://download.pytorch.org/whl/cu113/t…...

uniapp微信小程序调用百度OCR
uniapp编写微信小程序调用百度OCR 公司有一个识别行驶证需求,调用百度ocr识别 使用了image-tools这个插件,因为百度ocr接口用图片的base64 这里只是简单演示,accesstoken获取接口还是要放在服务器端,不然就暴露了自己的百度项目k…...
Vue3+TS项目---实用的复杂类型定义总结
namespace 概念 在TypeScript中,namespace是一种用于组织代码得结构,主要用于将相关得功能(例如类、接口、函数等)组合在一起。它可以帮助避免命名冲突,尤其是在大项目中。 用法 1.定义命名空间 使用namespace关键…...
尚硅谷rabbitmq2024 工作模式路由篇 第11节 答疑
String exchangeName "test_direct"; /! 创建交换机 人图全 channel.exchangeDeclare(exchangeName,BuiltinExchangeType.DIREcT, b: true, b1: false, b2: false, map: null); /1 创建队列 String queue1Name "test_direct_queue1"; String queue2Name &q…...

HTTP vs WebSocket
本文将对比介绍HTTP 和 WebSocket ! 相关文章: 1.HTTP 详解 2.WebSocket 详解 一、HTTP:请求/响应的主流协议 HTTP(超文本传输协议)是用于发送和接收网页数据的标准协议。它最早于1991年由Tim Berners-Lee提出来&…...

R语言医学数据分析实践-数据读写
【图书推荐】《R语言医学数据分析实践》-CSDN博客 《R语言医学数据分析实践 李丹 宋立桓 蔡伟祺 清华大学出版社9787302673484》【摘要 书评 试读】- 京东图书 (jd.com) R语言编程_夏天又到了的博客-CSDN博客 R编程环境的搭建-CSDN博客 在分析公共卫生数据时,数…...
JavaWeb环境下Spring Boot在线考试系统的优化策略
摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了基于JavaWeb技术的在线考试系统设计与实现的开发全过程。通过分析基于Java Web技术的在线考试系统设计与实现管理的不足,创建了一个计算机管理基于Ja…...

ETL技术在金蝶云星空与旺店通WMS集成中的应用
金蝶云星空数据集成到旺店通WMS的技术案例分享 在数字化转型的背景下,现代企业对系统间的数据集成需求日益增加。本篇文章将以“组装入库>其他入库单-1”方案为例,详细解析如何通过轻易云数据集成平台,实现金蝶云星空与旺店通WMS之间的数…...
【力扣热题100】3194. 最小元素和最大元素的最小平均值【Java】
题目:3194.最小元素和最大元素的最小平均值 你有一个初始为空的浮点数数组 averages。另给你一个包含 n 个整数的数组 nums,其中 n 为偶数。 你需要重复以下步骤 n / 2 次: 从 nums 中移除 最小 的元素 minElement 和 最大 的元素 maxElement…...

机器学习拟合过程
import numpy as np import matplotlib.pyplot as plt# 步骤1: 生成模拟数据 np.random.seed(0) X 2 * np.random.rand(100, 1) y 4 3 * X 2 * X**2 np.random.randn(100, 1)# 步骤2: 定义线性模型 (我们从随机权重开始) w np.random.randn(2, 1) b np.random.randn(1)#…...

如何快速部署一套智能化openGauss测试环境
一、openGauss介绍 openGauss是一款开源关系型数据库管理系统,采用木兰宽松许可证v2发行,允许用户自由地复制、使用、修改和分发软件。openGauss内核深度融合了华为在数据库领域多年的研发经验,结合企业级场景需求,持续构建竞争力…...
【设计模式】深入理解Python中的原型设计模式
深入理解Python中的原型设计模式 在软件开发中,有时需要创建对象的过程非常复杂或者代价较高,而在同一类对象的实例之间有很多重复的属性。为了避免重复构造对象,提升性能和效率,原型设计模式(Prototype Pattern&…...
Django CORS配置方案
参考 https://pypi.org/project/django-cors-headers/ 在setting.py中设置 INSTALLED_APPS [......corsheaders, #添加此行 ]MIDDLEWARE[......corsheaders.middleware.CorsMiddleware, #添加此行django.middleware.common.CommonMiddleware,#django.middleware.csrf.CsrfVi…...

2024年开放式耳机哪个牌子好?推荐最好的顶级开放式耳机品牌
在当下,开放式耳机逐渐成为众多消费者的新宠。与传统入耳式耳机相比,开放式耳机展现出诸多独特之处。它可以呈现出更清晰的音质效果,让用户有更美妙的听觉体验。在佩戴感上,开放式耳机更为舒适,不会给耳朵带来压迫感。…...

零基础读懂Stable Diffusion!
前言 一文搞懂Stable Diffusion是什么,怎么训练和使用,语义信息影响生成图片的过程。>>[][加入极市CV技术交流群,走在计算机视觉的最前沿] 前几个月AIGC可谓是大热了一把,各种高质量的生成图片层出不穷,而其中…...

css实现圆环展示百分比,根据值动态展示所占比例
代码如下 <view class""><view class"circle-chart"><view v-if"!!num" class"pie-item" :style"{background: conic-gradient(var(--one-color) 0%,#E9E6F1 ${num}%),}"></view><view v-else …...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...

剑指offer20_链表中环的入口节点
链表中环的入口节点 给定一个链表,若其中包含环,则输出环的入口节点。 若其中不包含环,则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...
OkHttp 中实现断点续传 demo
在 OkHttp 中实现断点续传主要通过以下步骤完成,核心是利用 HTTP 协议的 Range 请求头指定下载范围: 实现原理 Range 请求头:向服务器请求文件的特定字节范围(如 Range: bytes1024-) 本地文件记录:保存已…...

React19源码系列之 事件插件系统
事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...

Mac软件卸载指南,简单易懂!
刚和Adobe分手,它却总在Library里给你写"回忆录"?卸载的Final Cut Pro像电子幽灵般阴魂不散?总是会有残留文件,别慌!这份Mac软件卸载指南,将用最硬核的方式教你"数字分手术"࿰…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

基于Docker Compose部署Java微服务项目
一. 创建根项目 根项目(父项目)主要用于依赖管理 一些需要注意的点: 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件,否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...
Rust 异步编程
Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...
服务器--宝塔命令
一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...