C語(yǔ)言中通用工具庫(kù)stdlib.h的一些常用函數(shù)
前言
C語(yǔ)言標(biāo)準(zhǔn)庫(kù)中的stdlib.h是一個(gè)通用工具庫(kù),其中包含了很多有用的函數(shù),這些函數(shù)可以用來(lái)進(jìn)行各種各樣的操作,例如內(nèi)存分配、類型轉(zhuǎn)換、隨機(jī)數(shù)生成等等。
下面是stdlib.h中一些常用函數(shù)的介紹:
1、malloc和free:用于動(dòng)態(tài)內(nèi)存分配和釋放。
malloc函數(shù)用于在堆(heap)中分配指定大小的內(nèi)存,返回一個(gè)指向該內(nèi)存的指針。free函數(shù)用于釋放之前分配的內(nèi)存,將內(nèi)存歸還給系統(tǒng)。
示例代碼:
#include <stdio.h> #include <stdlib.h> int main() { int *p = (int*)malloc(sizeof(int)); // 分配4字節(jié)大小的內(nèi)存 if (p == NULL) { printf("Failed to allocate memory!\n"); return 1; } *p = 10; // 給指針p指向的內(nèi)存賦值為10 printf("%d\n", *p); // 輸出10 free(p); // 釋放內(nèi)存 return 0; }
運(yùn)行結(jié)果:
10
2、atoi和atof:用于將字符串轉(zhuǎn)換為整數(shù)或浮點(diǎn)數(shù)。
atoi函數(shù)用于將字符串轉(zhuǎn)換為整數(shù),atof函數(shù)用于將字符串轉(zhuǎn)換為浮點(diǎn)數(shù)。
示例代碼:
#include <stdio.h> #include <stdlib.h> int main() { char str1[] = "123"; char str2[] = "3.14"; int num = atoi(str1); printf("%d\n", num); // 輸出123 double dnum = atof(str2); printf("%f\n", dnum); // 輸出3.140000 return 0; }
運(yùn)行結(jié)果:
123
3.140000
3、rand和srand:用于生成隨機(jī)數(shù)和設(shè)置隨機(jī)數(shù)種子。
rand函數(shù)用于生成一個(gè)偽隨機(jī)數(shù),srand函數(shù)用于設(shè)置隨機(jī)數(shù)種子。
示例代碼:
#include <stdio.h> #include <stdlib.h> #include <time.h> int main() { srand(time(NULL)); // 設(shè)置隨機(jī)數(shù)種子為當(dāng)前時(shí)間 for (int i = 0; i < 10; i++) { printf("%d ", rand() % 100); // 生成0~99之間的隨機(jī)數(shù) } printf("\n"); return 0; }
運(yùn)行結(jié)果:
75 56 93 58 99 33 30 22 23 56
4、system:用于執(zhí)行系統(tǒng)命令。
system函數(shù)用于執(zhí)行指定的系統(tǒng)命令,例如清屏、打開文件等。
示例代碼:
#include <stdio.h> #include <stdlib.h> int main() { system("clear"); // 清屏 return 0; }
注意:system函數(shù)在不同操作系統(tǒng)上可能有不同的實(shí)現(xiàn),使用時(shí)需要注意。
5、exit:用于退出程序。
exit函數(shù)用于正常退出程序,并返回一個(gè)指定的退出碼(通常用0表示正常退出,非0表示異常退出)。
示例代碼:
#include <stdio.h> #include <stdlib.h> int main() { printf("Hello, world!\n"); exit(0); // 正常退出程序 return 0; // 這一句不會(huì)被執(zhí)行 }
運(yùn)行結(jié)果:
Hello, world!
6、qsort:用于快速排序。
qsort函數(shù)用于對(duì)數(shù)組進(jìn)行快速排序,需要指定數(shù)組的起始地址、元素個(gè)數(shù)、每個(gè)元素的大小和一個(gè)比較函數(shù)。
示例代碼:
#include <stdio.h> #include <stdlib.h> int compare(const void *a, const void *b) { return (*(int*)a - *(int*)b); } int main() { int arr[] = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5}; int len = sizeof(arr) / sizeof(int); qsort(arr, len, sizeof(int), compare); for (int i = 0; i < len; i++) { printf("%d ", arr[i]); } printf("\n"); return 0; }
運(yùn)行結(jié)果:
1 1 2 3 3 4 5 5 5 6 9
7、abs:用于取絕對(duì)值。
abs函數(shù)用于取整數(shù)的絕對(duì)值。
示例代碼:
#include <stdio.h> #include <stdlib.h> int main() { int num1 = -10; int num2 = 20; printf("%d\n", abs(num1)); // 輸出10 printf("%d\n", abs(num2)); // 輸出20 return 0; }
運(yùn)行結(jié)果:
10
20
8、labs:用于取長(zhǎng)整數(shù)的絕對(duì)值。
labs函數(shù)用于取長(zhǎng)整數(shù)的絕對(duì)值。
示例代碼:
#include <stdio.h> #include <stdlib.h> int main() { long num1 = -123456789; long num2 = 987654321; printf("%ld\n", labs(num1)); // 輸出123456789 printf("%ld\n", labs(num2)); // 輸出987654321 return 0; }
運(yùn)行結(jié)果:
123456789
987654321
9、atof:用于將字符串轉(zhuǎn)換為浮點(diǎn)數(shù)。
atof函數(shù)用于將字符串轉(zhuǎn)換為浮點(diǎn)數(shù)。
示例代碼:
#include <stdio.h> #include <stdlib.h> int main() { char str[] = "3.14"; double dnum = atof(str); printf("%f\n", dnum); // 輸出3.140000 return 0; }
運(yùn)行結(jié)果:
3.140000
除了上面提到的函數(shù),stdlib.h中還有許多其他有用的函數(shù),可以根據(jù)需要進(jìn)行調(diào)用。這個(gè)庫(kù)在C語(yǔ)言中非常常用,因?yàn)樗峁┝嗽S多基本的功能,可以方便地進(jìn)行各種操作。
總結(jié)
到此這篇關(guān)于C語(yǔ)言中通用工具庫(kù)stdlib.h的一些常用函數(shù)的文章就介紹到這了,更多相關(guān)C語(yǔ)言通用工具庫(kù)stdlib.h內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MFC控件之CListCtrl的應(yīng)用實(shí)例教程
這篇文章主要介紹了MFC控件中CListCtrl的應(yīng)用方法,包括了針對(duì)表格的一些操作,是MFC中比較重要的一個(gè)控件類,需要的朋友可以參考下2014-08-08簡(jiǎn)單掌握桶排序算法及C++版的代碼實(shí)現(xiàn)
桶排序是將要排序的算法按桶分組排序之后再遍歷匯總的一種線性排序算法,下面就讓我們來(lái)通過小例子簡(jiǎn)單掌握桶排序算法及C++版的代碼實(shí)現(xiàn)^^2016-07-07Qt中集成并使用SQLite數(shù)據(jù)庫(kù)的超完整指南
這篇文章主要介紹了Qt中集成并使用SQLite數(shù)據(jù)庫(kù)的相關(guān)資料,包括環(huán)境配置、連接數(shù)據(jù)庫(kù)、執(zhí)行SQL操作、事務(wù)處理、使用模型-視圖編程、錯(cuò)誤處理、高級(jí)技巧與注意事項(xiàng)以及常見問題解答,需要的朋友可以參考下2025-04-04C++使struct對(duì)象擁有可變大小的數(shù)組(詳解)
下面小編就為大家?guī)?lái)一篇C++使struct對(duì)象擁有可變大小的數(shù)組(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2016-12-12C語(yǔ)言實(shí)現(xiàn)圖書管理系統(tǒng)課程設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)圖書管理系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07C/C++實(shí)現(xiàn)快速排序算法的思路及原理解析
這篇文章主要介紹了C/C++實(shí)現(xiàn)快速排序算法的思路及原理解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01數(shù)據(jù)結(jié)構(gòu)之矩陣行列和相等的實(shí)例
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)之矩陣行列和相等的實(shí)例的相關(guān)資料,希望通過本文能幫助到大家,讓大家掌握這部分內(nèi)容,需要的朋友可以參考下2017-10-10