C 标准库 - <stdlib.h>

C 标准库 - <stdlib.h>

概述

C 标准库中的 <stdlib.h> 头文件提供了许多用于内存分配、转换、排序和搜索的标准函数。这些函数在 C 程序开发中非常常见,尤其是在处理数据结构和动态内存分配时。本文将详细介绍 <stdlib.h> 头文件中的主要函数及其应用。

主要函数

1. 动态内存分配

malloc()

malloc(size_t size) 函数用于分配指定大小的内存块,并返回指向内存块的指针。如果分配成功,返回的指针不为 NULL

c 复制代码
void *malloc(size_t size);
free()

free(void *ptr) 函数用于释放由 malloc()calloc()realloc() 分配的内存。如果传入的指针为 NULL,则函数不执行任何操作。

c 复制代码
void free(void *ptr);
calloc()

calloc(size_t num_elements, size_t size) 函数用于分配指定大小的内存块,并将所有内容初始化为 0。它等价于调用 malloc()memset() 的组合。

c 复制代码
void *calloc(size_t num_elements, size_t size);
realloc()

realloc(void *ptr, size_t new_size) 函数用于重新分配内存块的大小。如果传入的指针为 NULL,则与 malloc() 类似;如果传入的指针不为 NULL,则 realloc() 会尝试扩展或缩小内存块的大小。

c 复制代码
void *realloc(void *ptr, size_t new_size);

2. 数据转换

atoi()

atoi(const char *str) 函数用于将字符串转换为整数。如果字符串中的字符不是数字,则返回 0。

c 复制代码
int atoi(const char *str);
atof()

atof(const char *str) 函数用于将字符串转换为浮点数。如果字符串中的字符不是数字,则返回 0.0。

c 复制代码
double atof(const char *str);
atol()

atol(const char *str) 函数用于将字符串转换为长整数。如果字符串中的字符不是数字,则返回 0。

c 复制代码
long atol(const char *str);

3. 排序和搜索

qsort()

qsort(void *base, size_t num_elements, size_t size, int (*comparator)(const void *, const void *)) 函数用于对元素数组进行排序。comparator 是一个比较函数,用于比较两个元素。

c 复制代码
void qsort(void *base, size_t num_elements, size_t size, int (*comparator)(const void *, const void *));
bsearch()

bsearch(const void *key, const void *base, size_t num_elements, size_t size, int (*comparator)(const void *, const void *)) 函数用于在已排序的元素数组中搜索指定元素。如果找到,返回指向该元素的指针;否则返回 NULL

c 复制代码
void *bsearch(const void *key, const void *base, size_t num_elements, size_t size, int (*comparator)(const void *, const void *));

应用实例

以下是一个使用 <stdlib.h> 中函数的简单示例:

c 复制代码
#include <stdio.h>
#include <stdlib.h>

int compare_int(const void *a, const void *b) {
    return (*(int *)a - *(int *)b);
}

int main() {
    int numbers[] = {5, 2, 9, 1, 5, 6};
    int num_elements = sizeof(numbers) / sizeof(numbers[0]);
    int i;

    // 使用 qsort 对数组进行排序
    qsort(numbers, num_elements, sizeof(int), compare_int);

    // 输出排序后的数组
    for (i = 0; i < num_elements; i++) {
        printf("%d ", numbers[i]);
    }
    printf("\n");

    return 0;
}

在这个例子中,我们首先定义了一个比较函数 compare_int,用于比较两个整数。然后使用 qsort() 函数对 numbers 数组进行排序,并输出排序后的结果。

总结

C 标准库中的 <stdlib.h> 头文件提供了许多实用的函数,可以帮助我们更高效地开发 C 程序。通过了解并熟练使用这些函数,我们可以更好地处理内存分配、数据转换、排序和搜索等任务。

相关推荐
少控科技2 小时前
QT新手日记035
开发语言·qt
青川学长2 小时前
Cursor + Qt Creator 混合开发指南
开发语言·qt
嫂子开门我是_我哥2 小时前
第十五节:文件操作与数据持久化:让程序拥有“记忆”
开发语言·python
是三好2 小时前
JUC并发编程
java·开发语言
哈哈不让取名字2 小时前
分布式日志系统实现
开发语言·c++·算法
3GPP仿真实验室2 小时前
【MATLAB源码】6G:感知辅助毫米波 MIMO 信道估计仿真平台
开发语言·matlab·智能电视
catchadmin2 小时前
Laravel12 + Vue3 的免费可商用 PHP 管理后台 CatchAdmin V5.1.1 发布
开发语言·php
编程(变成)小辣鸡3 小时前
JVM、JRE和JDK 的关系
java·开发语言·jvm
a程序小傲3 小时前
得物Java面试被问:流批一体架构的实现和状态管理
java·开发语言·数据库·redis·缓存·面试·架构