C语言实例_stdlib.h库函数功能及其用法详解

一、前言

C语言作为一种高效、灵活的编程语言,标准库的使用对于开发人员来说是不可或缺的。其中,stdlib.h是C语言中一个重要的标准库头文件,提供了许多常用的函数和工具,以便开发人员能够更加便捷地进行内存管理、字符串处理、随机数生成等操作。本文将对stdlib.h中的各个函数进行全面介绍,包括它们的功能和使用方法,以帮助开发者更好地理解和利用该标准库。

image-20230816112832472

二、stdlib.h函数介绍

C语言的标准库头文件 stdlib.h 提供了一些常用的函数,用于执行各种实用程序和内存管理任务。

以下是 stdlib.h 头文件中包含的主要函数及其功能的详细介绍:

【1】内存管理函数

  • malloc(size_t size):动态分配指定大小的内存块,并返回指向该内存块的指针。

  • calloc(size_t num, size_t size):动态分配 num 个长度为 size 字节的连续内存区域,并将每个字节初始化为零。

  • realloc(void* ptr, size_t size):重新分配先前分配的内存块 ptr 的大小为 size 字节,并返回指向重新分配后内存块的指针。

  • free(void* ptr):释放之前通过动态内存分配函数分配的内存。

【2】字符串转换函数

  • atoi(const char* str):将字符串转换为对应的整数并返回结果。

  • atol(const char* str):将字符串转换为对应的长整数并返回结果。

  • atof(const char* str):将字符串转换为对应的双精度浮点数并返回结果。

  • itoa(int value, char* str, int base):将整数转换为字符串并存储在 str 中。

  • rand(void):生成伪随机数。

  • srand(unsigned int seed):设置随机数发生器的种子。

【3】环境控制函数

  • system(const char* command):执行命令行参数中指定的 shell 命令。
  • exit(int status):终止程序的执行并返回状态码。
  • _Exit(int status):终止程序的执行并返回状态码,不进行清理操作。
  • abort(void):中止程序的执行,并生成一个异常终止信号。

【4】动态分配排序函数

  • qsort(void* base, size_t nmemb, size_t size, int (*compar)(const void*, const void*)):对数组进行快速排序。

【5】字符串处理函数

  • rand_r(unsigned int* seedp):可重入版本的 rand() 函数。
  • system_l(const char* command, locale_t loc):根据指定的本地化环境执行命令。
  • posix_memalign(void** memptr, size_t alignment, size_t size):分配对齐的内存块。
  • aligned_alloc(size_t alignment, size_t size):分配对齐的内存块。

三、代码示例

3.1 内存管理函数

【1】malloc(size_t size):动态分配指定大小的内存块,并返回指向该内存块的指针。

#include <stdio.h>
#include <stdlib.h>int main() {int* ptr;int num = 5;// 动态分配一个 int 数组,数组长度为 numptr = (int*)malloc(num * sizeof(int));// 检查内存是否成功分配if (ptr == NULL) {printf("内存分配失败\n");exit(1);}// 使用分配的内存for (int i = 0; i < num; i++) {ptr[i] = i + 1;}// 输出数组的值for (int i = 0; i < num; i++) {printf("%d ", ptr[i]);}// 释放内存free(ptr);return 0;
}

【2】calloc(size_t num, size_t size):动态分配 num 个长度为 size 字节的连续内存区域,并将每个字节初始化为零。

#include <stdio.h>
#include <stdlib.h>int main() {int* ptr;int num = 5;// 动态分配一个 int 数组,数组长度为 num,并初始化为零ptr = (int*)calloc(num, sizeof(int));// 检查内存是否成功分配if (ptr == NULL) {printf("内存分配失败\n");exit(1);}// 输出数组的值for (int i = 0; i < num; i++) {printf("%d ", ptr[i]);}// 释放内存free(ptr);return 0;
}

【3】realloc(void* ptr, size_t size):重新分配先前分配的内存块 ptr 的大小为 size 字节,并返回指向重新分配后内存块的指针。

#include <stdio.h>
#include <stdlib.h>int main() {int* ptr;int num = 5;// 动态分配一个 int 数组,数组长度为 numptr = (int*)malloc(num * sizeof(int));// 检查内存是否成功分配if (ptr == NULL) {printf("内存分配失败\n");exit(1);}// 输出数组的值for (int i = 0; i < num; i++) {printf("%d ", ptr[i]);}// 重新分配内存为更大的数组num = 10;ptr = (int*)realloc(ptr, num * sizeof(int));// 使用重新分配的内存for (int i = 5; i < num; i++) {ptr[i] = i + 1;}// 输出数组的值for (int i = 0; i < num; i++) {printf("%d ", ptr[i]);}// 释放内存free(ptr);return 0;
}

【4】free(void* ptr):释放之前通过动态内存分配函数分配的内存。

#include <stdio.h>
#include <stdlib.h>int main() {int* ptr;// 动态分配一个 int 数组ptr = (int*)malloc(5 * sizeof(int));// 检查内存是否成功分配if (ptr == NULL) {printf("内存分配失败\n");exit(1);}// 使用分配的内存for (int i = 0; i < 5; i++) {ptr[i] = i + 1;}// 输出数组的值for (int i = 0; i < 5; i++) {printf("%d ", ptr[i]);}// 释放内存free(ptr);return 0;
}

以上是这些内存管理函数的基本用法。动态内存管理函数允许在程序运行时根据需要分配或释放内存,提供了更灵活和高效地使用内存的方式。重要的是记得在使用完毕后及时释放内存,以避免内存泄漏问题。

3.2 字符串转换与随机数函数

这里是给这些字符串转换函数和随机数函数的例子和用法介绍:

【1】atoi(const char* str):将字符串转换为对应的整数并返回结果。

#include <stdio.h>
#include <stdlib.h>int main() {const char* str = "12345";int num = atoi(str);printf("字符串转换为整数:%d\n", num);return 0;
}

【2】atol(const char* str):将字符串转换为对应的长整数并返回结果。

#include <stdio.h>
#include <stdlib.h>int main() {const char* str = "1234567890";long num = atol(str);printf("字符串转换为长整数:%ld\n", num);return 0;
}

【3】atof(const char* str):将字符串转换为对应的双精度浮点数并返回结果。

#include <stdio.h>
#include <stdlib.h>int main() {const char* str = "3.14159";double num = atof(str);printf("字符串转换为双精度浮点数:%f\n", num);return 0;
}

【4】itoa(int value, char* str, int base):将整数转换为字符串并存储在 str 中。

#include <stdio.h>
#include <stdlib.h>int main() {int num = 12345;char str[20];itoa(num, str, 10);printf("整数转换为字符串:%s\n", str);return 0;
}

【5】rand(void):生成伪随机数。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>int main() {srand(time(NULL)); // 设置随机数发生器的种子为当前时间for (int i = 0; i < 5; i++) {int randomNum = rand();printf("随机数:%d\n", randomNum);}return 0;
}

【6】srand(unsigned int seed):设置随机数发生器的种子。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>int main() {srand(123); // 设置随机数发生器的种子为 123for (int i = 0; i < 5; i++) {int randomNum = rand();printf("随机数:%d\n", randomNum);}return 0;
}

3.3 环境控制函数

【1】system(const char* command):执行命令行参数中指定的 shell 命令。

#include <stdio.h>
#include <stdlib.h>int main() {const char* command = "ls -l"; // 列出当前目录下的文件和文件夹int status = system(command);if (status == -1) {printf("命令执行失败。\n");} else {printf("命令执行成功。\n");}return 0;
}

【2】exit(int status):终止程序的执行并返回状态码。

#include <stdio.h>
#include <stdlib.h>int main() {printf("程序开始执行。\n");// 退出程序,并返回状态码 0exit(0);printf("此行不会被执行。\n");return 0;
}

【2】_Exit(int status):终止程序的执行并返回状态码,不进行清理操作。

#include <stdio.h>
#include <stdlib.h>int main() {printf("程序开始执行。\n");// 退出程序,并返回状态码 0,不进行清理操作_Exit(0);printf("此行不会被执行。\n");return 0;
}

【3】abort(void):中止程序的执行,并生成一个异常终止信号。

#include <stdio.h>
#include <stdlib.h>int main() {printf("程序开始执行。\n");printf("触发异常终止信号。\n");abort();printf("此行不会被执行。\n");return 0;
}

3.4 动态分配排序函数

这里是关于动态分配排序函数的例子和用法介绍:

#include <stdio.h>
#include <stdlib.h>// 比较函数,用于指定排序顺序
int compareFunc(const void* a, const void* b) {// 将输入的指针转换为所需的类型int num1 = *(int*)a;int num2 = *(int*)b;// 按升序进行排序if (num1 < num2) {return -1;} else if (num1 > num2) {return 1;} else {return 0;}
}int main() {int arr[] = {5, 2, 8, 6, 1, 3, 9, 7, 4};int size = sizeof(arr) / sizeof(arr[0]);printf("排序前的数组:");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");// 使用 qsort 对数组进行排序qsort(arr, size, sizeof(int), compareFunc);printf("排序后的数组:");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

在这个例子中,定义了一个整型数组 arr,包含了一些无序的元素。使用 qsort 函数对该数组进行排序。qsort 函数接收四个参数:要排序的数组的起始地址 base,数组中元素的个数 nmemb,每个元素的字节大小 size,以及一个比较函数 compar。比较函数用于指定排序的顺序。

compareFunc中,传入的指针转换为 int 类型,并按照升序排序的规则进行比较。如果第一个元素小于第二个元素,返回 -1;如果第一个元素大于第二个元素,返回 1;如果两个元素相等,返回 0

最后,输出排序前和排序后的数组,可以看到数组已经按升序进行了排序。

qsort 函数是对 C 标准库的一部分,经过高效的优化,可以处理不同类型的数组,而不仅仅是整型数组。

3.5 字符串处理函数

【1】rand_r(unsigned int* seedp):可重入版本的 rand() 函数,用于生成伪随机数。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>int main() {unsigned int seed = time(NULL);for (int i = 0; i < 5; i++) {int randomNum = rand_r(&seed);printf("%d ", randomNum);}printf("\n");return 0;
}

在这个例子中,使用 rand_r 函数生成了5个伪随机数。通过向 rand_r 函数传递一个指向种子的指针,确保每次调用 rand_r 函数时都使用不同的种子,使其成为可重入函数。

【2】system_l(const char* command, locale_t loc):根据指定的本地化环境执行命令。

#include <stdio.h>
#include <stdlib.h>
#include <locale.h>int main() {const char* command = "ls -l"; // 列出当前目录下的文件和文件夹locale_t loc = newlocale(LC_ALL_MASK, "", NULL);int status = system_l(command, loc);if (status == -1) {printf("命令执行失败。\n");} else {printf("命令执行成功。\n");}freelocale(loc);return 0;
}

在这个例子中,使用 system_l 函数执行了一个命令 ls -l,该命令用于列出当前目录下的文件和文件夹。使用 newlocale 函数创建了一个新的本地化环境 loc,并将其作为参数传递给 system_l 函数。最后,使用 freelocale 函数释放本地化环境。

【3】posix_memalign(void memptr, size_t alignment, size_t size):分配对齐的内存块。

#include <stdio.h>
#include <stdlib.h>int main() {void* memPtr;size_t alignment = 16; // 对齐要求为16字节size_t size = 32; // 分配32字节的内存int status = posix_memalign(&memPtr, alignment, size);if (status == 0) {printf("内存分配成功。\n");// 使用分配的内存free(memPtr);} else {printf("内存分配失败。\n");}return 0;
}

在这个例子中,使用 posix_memalign 函数分配了一个对齐的内存块,要求对齐要求为16字节,分配32字节的内存。通过传递指向 memPtr 的指针,可以在函数内部接收分配的内存地址。最后,使用 free 函数释放内存。

【4】aligned_alloc(size_t alignment, size_t size):分配对齐的内存块。

#include <stdio.h>
#include <stdlib.h>int main() {size_t alignment = 16; // 对齐要求为16字节size_t size = 32; // 分配32字节的内存void* memPtr = aligned_alloc(alignment, size);if (memPtr != NULL) {printf("内存分配成功。\n");// 使用分配的内存free(memPtr);} else {printf("内存分配失败。\n");}return 0;
}

在这个例子中,使用 aligned_alloc 函数分配了一个对齐的内存块,要求对齐要求为16字节,分配32字节的内存。通过将返回的内存指针赋值给 memPtr 变量,可以获得分配的内存地址。最后,使用 free 函数释放内存。

这些字符串处理函数提供了在 C 语言中处理字符串和执行相关操作的功能。使用这些函数时需要小心内存管理,避免出现内存泄漏等问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/308356.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WebGL以及wasm的介绍以及简单应用

简介 下面主要介绍了WebGL和wasm,是除了html,css,js以外Web标准所支持的另外两个大件 前者实现复杂的图形处理,后者提供高效的代码迁移以及代码执行效率 WebGL 简介 首先,浏览器里的游戏是怎么做到这种交互又显示不同的画面的? 试想用我们的前端三件套实现一下.好像可以…

【论文解读】Early Skip Mode Decision for HEVC Encoder With Emphasis on Coding Quality

时间&#xff1a;2015 级别&#xff1a;IEEE 机构&#xff1a;IEEE 学生会员 摘要 高效视频编码(High Efficiency Video Coding, HEVC)以其较高的压缩效率和良好的编码图像质量适用于高清和超高清视频业务&#xff0c;但其较高的编码复杂度阻碍了其广泛的实际应用。许多快速编…

最新GPT4教程,GPT语音对话使用,Midjourney绘画,ChatFile文档对话总结+DALL-E3文生图教程工具

一、前言 ChatGPT3.5、GPT4.0、GPT语音对话、Midjourney绘画&#xff0c;文档对话总结DALL-E3文生图&#xff0c;相信对大家应该不感到陌生吧&#xff1f;简单来说&#xff0c;GPT-4技术比之前的GPT-3.5相对来说更加智能&#xff0c;会根据用户的要求生成多种内容甚至也可以和…

前后端分离nodejs+vue+ElementUi网上订餐系统69b9

课题主要分为两大模块&#xff1a;即管理员模块和用户模块&#xff0c;主要功能包括个人中心、用户管理、菜品类型管理、菜品信息管理、留言反馈、在线交流、系统管理、订单管理等&#xff1b; 运行软件:vscode 前端nodejsvueElementUi 语言 node.js 框架&#xff1a;Express/k…

计算机视觉技术-锚框

目标检测算法通常会在输入图像中采样大量的区域&#xff0c;然后判断这些区域中是否包含我们感兴趣的目标&#xff0c;并调整区域边界从而更准确地预测目标的真实边界框&#xff08;ground-truth bounding box&#xff09;。 不同的模型使用的区域采样方法可能不同。 这里我们介…

Elasticsearch:使用 ELSER v2 文本扩展进行语义搜索

Elastic 提供了一个强大的 ELSER 供我们进行语义搜索。ELSER 是一种稀疏向量的搜索方法。我们无需对它做任何的微调及训练。它是一种 out-of-domain 的模型。目前它仅对英文进行支持。希望将来它能对其它的语言支持的更好。更多关于 ELSER 的知识&#xff0c;请参阅文章 “Elas…

根据文法求对应的语言

技巧&#xff1a;最后得到的是终结符组成的闭包 例题&#xff1a; 文法G[S]: S-->AB A-->aAb|ab B-->Bc|&#xff0c;求对应的语言 ①S-->(aAb|ab)(Bc|) ②我们可以观察到&#xff0c;无论A-->aAb还是A-->ab&#xff0c;都一定会同时出现ab,…

66biolinks v42.0.0 已注册 – 生物短链接、URL 缩短器、QR 码和 Web 工具 (SAAS) 源码

66biolinks v42.0.0&#xff1a;全能生物短链接与网络工具平台 一、开篇介绍 66biolinks v42.0.0是一款集生物链接、URL缩短器、二维码和网络工具于一体的综合性软件解决方案。作为社交生物链接平台的佼佼者&#xff0c;66biolinks提供了全方位的功能&#xff0c;旨在满足用户…

【并发设计模式】聊聊线程本地存储模式如何实现的线程安全

前面两篇文章&#xff0c;通过两阶段终止的模式进行优雅关闭线程&#xff0c;利用数据不变性的方式保证数据安全&#xff0c;以及基于COW的模式&#xff0c;保证读数据的安全。本篇我们来简述下如果利用线程本地存储的方式保证线程安全。 首先一个大前提就是并发问题&#xff…

Python武器库开发-武器库篇之上传本地仓库到Git(三十八)

武器库篇之上传本地仓库到Git(三十八) 当我们在Git中创建远程仓库和进行了SSH key免密登陆之后&#xff0c;我们点击 Your respositories 可以查看我们所创建的远程仓库&#xff0c;如图所示&#xff1a; 如果我们需要将本地的仓库上传到Git&#xff0c;首先我们需要建立一个本…

Python 实现 PDF 到 Word 文档的高效转换(DOC、DOCX)

PDF&#xff08;Portable Document Format&#xff09;已成为一种广泛使用的电子文档格式。PDF的主要优势是跨平台&#xff0c;可以在不同设备上呈现一致的外观。然而&#xff0c;当我们需要对文件内容进行编辑或修改&#xff0c;直接编辑PDF文件会非常困难&#xff0c;而且效果…

鸿蒙系列--组件介绍之容器组件

一、Badge 描述&#xff1a;给其他组件添加标记 子组件&#xff1a;支持单个子组件 1.创建数字标记 Badge(value: {count: number, position?: BadgePosition, maxCount?: number, style: BadgeStyle}) 2.创建字符串标记 Badge(value: {value: string, position?: Badge…