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

相关推荐
LDR0061 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术1 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园1 天前
C++20 Modules 模块详解
java·开发语言·spring
swordbob1 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
源分享1 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.1 天前
C语言--day30
c语言·开发语言
何以解忧,唯有..1 天前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
謓泽1 天前
C语言不是语法,是通往机器的地图。
c语言·开发语言
云水一下1 天前
从零开始学 PHP 系列(一):PHP 的前世今生与开发环境搭建
开发语言·php
飞天狗1111 天前
零基础JavaWeb入门——第五课第二小节:九大内置对象 · 第2个:response(响应对象)
java·开发语言