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 程序。通过了解并熟练使用这些函数,我们可以更好地处理内存分配、数据转换、排序和搜索等任务。

相关推荐
网域小星球23 分钟前
C 语言从 0 入门(十七)|结构体指针 + 动态内存 + 文件综合实战
c语言·开发语言·文件操作·结构体指针·动态内存·综合项目
aq553560029 分钟前
三大编程语言深度对比:C# vs 易语言 vs 汇编
开发语言·汇编·c#
独特的螺狮粉33 分钟前
云隙一言:鸿蒙Flutter框架 实现的随机名言应用
开发语言·flutter·华为·架构·开源·harmonyos
光泽雨35 分钟前
c# 文件编译的过程
开发语言·c#
赤水无泪1 小时前
09 C++ 11 新增的标准
开发语言
格林威1 小时前
工业相机 SDK 在 Docker 容器中的部署与权限配置(含 USB/GigE)
开发语言·人工智能·数码相机·计算机视觉·docker·容器·工业相机
哎嗨人生公众号1 小时前
手写求导公式,让轨迹优化性能飞升,150ms变成9ms
开发语言·c++·算法·机器人·自动驾驶
code_whiter1 小时前
C++6(模板)
开发语言·c++
一只旭宝2 小时前
【C++ 入门精讲1】初始化、const、引用、内联函数 | 超详细手写笔记(附完整代码)
开发语言·c++
XiYang-DING2 小时前
【Java】二叉搜索树(BST)
java·开发语言·python