当前位置: 首页 > article >正文

11.03学习

一、主函数和exit函数

主函数( main 函数)

1. 入口点: main 函数是C程序的入口点,程序执行从这里开始。

2. 返回类型: main 函数可以返回 int 类型,也可以返回 void 类型。但在现代C语言标准(C99及以后)中,推荐使用 int 类型。

3. 参数: main 函数可以接受两个参数,通常定义为 int argc 和 char *argv[] 。 argc 表示命令行参数的数量, argv 是一个字符串数组,包含每个参数的具体值。

4. 返回值: main 函数的返回值通常用来表示程序的退出状态。返回 0 通常表示程序成功执行,非 0 值表示出现了错误或异常。

5. 示例:int main() {

// 程序代码

return 0;

}

 

 

 exit 函数

1. 终止程序: exit 函数用于立即终止程序的执行。

2. 头文件:使用 exit 函数需要包含头文件 <stdlib.h> 。

3. 参数: exit 函数接受一个 int 类型的参数,用来表示程序的退出状态。

4. 返回值: exit 函数不返回任何值。

5. 示例:#include <stdlib.h>

 

int main() {

// 程序代码

exit(0); // 正常退出

}

其他知识点

程序终止:除了 exit 函数外, main 函数执行完毕后也会自动终止程序。

资源清理:在 exit 函数被调用之前,程序应该释放所有已分配的资源,如内存、文件句柄等。

信号处理:在某些情况下,程序可能因为接收到信号(如 SIGINT )而终止。可以通过信号处理函数来控制程序的退出行为。

环境清理:在程序退出之前,C运行时库会执行一些清理工作,如关闭所有打开的文件、调用注册的`ate

 

 

二、多文件编程相关知识点

C语言中的多文件编程是一种常见的编程实践,它允许将程序分解成多个源文件和头文件,以提高代码的可读性、可维护性和可重用性。

1. 源文件(.c文件):

包含实际的C代码和函数实现。

每个源文件可以包含多个函数的定义。

2. 头文件(.h文件):

包含函数声明、宏定义、类型定义和全局变量声明。

用于在不同的源文件之间共享接口和公共定义。

通常使用 #ifndef 、 #define 和 #endif 预处理指令来防止头文件内容被多次包含(头文件保护)。

3. 编译单元:

每个源文件及其对应的头文件构成一个编译单元。

编译器独立编译每个编译单元,然后链接器将它们链接成一个可执行文件。

4. 函数声明:

在头文件中声明函数,以便在其他源文件中调用这些函数。

函数声明告诉编译器函数的名称、返回类型和参数类型。

5. 外部链接:

使用 extern 关键字声明全局变量或函数,使其可以在其他文件中访问。

一个文件中声明为 extern 的变量或函数,必须在另一个文件中定义。

6. 静态链接:

链接器将不同的编译单元链接成一个单一的可执行文件。

静态链接发生在程序编译时,所有需要的库和代码都被包含在最终的可执行文件中。

7. 静态库和动态库:

静态库(.a文件):在编译时将库的内容复制到可执行文件中。

动态库(.so文件在Linux,.dll文件在Windows):在程序运行时动态加载库。

8. 编译和链接命令:

使用编译器(如gcc或clang)编译源文件。

使用链接器(如ld)链接目标文件生成可执行文件。

示例命令:gcc -c file1.c file2.c # 编译源文件生成目标文件

gcc file1.o file2.o -o program # 链接目标文件生成可执行文件

9. 模块化:

将程序分解成模块,每个模块负责特定的功能。

模块化有助于代码的组织和重用。

10. 依赖管理:

确保头文件和源文件之间的依赖关系正确,避免循环依赖。

使用 #include 指令包含所需的头文件。

11. 代码组织:

将相关的函数和数据组织在同一个文件中,以便于理解和维护。

12. 代码风格和规范:

遵循一致的代码风格和命名规范,以提高代码的可读性。

13. 错误处理:

在多文件编程中,确保每个模块都能正确处理错误,并在必要时向上层模块传递错误信息。

 

 

三、数组逆转相关知识点

在C语言中,数组逆转(也称为数组反转)是指将数组中的元素顺序颠倒,使得第一个元素变成最后一个,第二个元素变成倒数第二个,以此类推。

1. 理解数组:

数组是相同数据类型元素的集合,存储在连续的内存位置。

数组可以是一维或多维。

2. 数组长度:

逆转数组前,需要知道数组的长度,这可以通过传递数组大小参数或使用 sizeof 运算符计算得出。

3. 指针操作:

通过指针可以访问和修改数组元素。

可以使用指针来遍历数组并交换元素。

4. 交换元素:

要逆转数组,需要交换数组的首尾元素,然后向中心移动,继续交换相邻的元素,直到到达数组的中心。

5. 循环控制:

使用循环结构(如 for 循环)来控制元素的交换过程。

循环终止条件通常是到达数组的中间位置。

6. 临时变量:

在交换两个元素时,通常需要一个临时变量来保存其中一个元素的值。

7. 原地逆转:

数组逆转可以在原数组上进行,不需要额外的存储空间。

8. 函数封装:

将逆转逻辑封装在一个函数中,以提高代码的可重用性和模块化。

9. 边界条件:

考虑空数组或只有一个元素的数组的情况,这些情况下不需要进行任何操作。

10. 代码示例:

void reverseArray(int arr[], int n) {

int temp;

for (int i = 0; i < n / 2; i++) {

temp = arr[i];

arr[i] = arr[n - i - 1];

arr[n - i - 1] = temp;

}

}

11. 递归方法:

除了迭代方法,也可以使用递归来实现数组的逆转。

12. 多维数组:

对于多维数组,逆转操作可能需要更复杂的逻辑,可能需要逐行或逐列进行逆转。

13. 性能考虑:

原地逆转算法的时间复杂度为O(n/2),即O(n),其中n是数组的长度。

14. 稳定性:

逆转操作不涉及比较,因此它是稳定的,不会改变相同元素的相对顺序。

15. 测试:

对逆转函数进行充分的测试,包括边界条件和典型案例。


http://www.kler.cn/a/379581.html

相关文章:

  • 借助 Aspose.Words,使用 C# 从 Word 文档中删除页面
  • OpenEuler 使用ffmpeg x11grab捕获屏幕流,rtsp推流,并用vlc播放
  • 【PGCCC】在 Postgres 中创建日期箱的 4 种方法:interval、date_trunc、extract 和 to_char
  • mac-泛洪
  • 力扣排序350题 两个元组的交集2
  • Elasticsearch 实战应用详解!
  • 智慧汇聚:十款企业培训工具打造学习型企业
  • PostgreSQL核心揭秘(二)-进程和内存架构
  • 深入解析缓存模式下的数据一致性问题
  • 论文学习笔记(一)
  • leetcode hot100【LeetCode 3. 无重复字符的最长子串】java实现
  • 发现一个宝藏AI解梦工具
  • 零基础Java第十三期:继承与多态(一)
  • 【算法赌场】SPFA算法
  • Android音频进阶之PCM设备创建(九十三)
  • 【WPF】MatrixTransform类
  • 【Kotlin】 基础语法笔记
  • SQL基础—2
  • 后台管理系统的通用权限解决方案(九)SpringBoot整合jjwt实现登录认证鉴权
  • iOS中OC对象的本质
  • HTTP的初步了解
  • 代码随想录第十五天| 110.平衡二叉树 、 257. 二叉树的所有路径 、404.左叶子之和、222.完全二叉树的节点个数
  • 基于深度学习的数据安全与可追溯性增强
  • qt QPixmap详解
  • 深入了解 Kotlin 高阶函数
  • SpringBoot实现:高效在线试题库系统