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

相关推荐
SuperEugene10 小时前
VXE-Table 4.x 实战规范:列配置 + 合并单元格 + 虚拟滚动,避坑卡顿 / 错乱 / 合并失效|表单与表格规范篇
开发语言·前端·javascript·vue.js·前端框架·vxetable
xushichao198910 小时前
高性能密码学库
开发语言·c++·算法
偷懒下载原神10 小时前
【linux操作系统】信号
linux·运维·服务器·开发语言·c++·git·后端
小涛不学习10 小时前
Java面试全攻略(基础 + 集合 + 并发 + JVM + 框架)
java·开发语言
m0_5180194810 小时前
C++代码混淆与保护
开发语言·c++·算法
m0_5698814710 小时前
C++中的智能指针详解
开发语言·c++·算法
爱丽_10 小时前
AQS 原理主线:state、CLH 队列、独占/共享与实战排查
java·开发语言·jvm
2401_8735449211 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
add45a11 小时前
C++中的组合模式
开发语言·c++·算法
dys_Codemonkey11 小时前
ROS 2 环境配置与 Shell 配置文件详解(zsh/bash)ROS 2 多工作空间规范配置
开发语言·chrome·bash