色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

C語言常見的一些標準庫

Q4MP_gh_c472c21 ? 來源:嵌入式ARM ? 作者:嵌入式ARM ? 2020-11-18 16:22 ? 次閱讀

有很多工程師喜歡自己封裝一些標準庫已有的函數,其實自己封裝的函數,并不一定比標準庫好,有時候反而代碼更冗余,且有bug。下面就來分享一下C語言常見的一些標準庫。

標準頭文件包括:

一、標準定義(

文件里包含了標準庫的一些常用定義,無論我們包含哪個標準頭文件,都會被自動包含進來。

這個文件里定義:

類型size_t(sizeof運算符的結果類型,是某個無符號整型);

類型ptrdiff_t(兩個指針相減運算的結果類型,是某個有符號整型);

類型wchar_t(寬字符類型,是一個整型,其中足以存放本系統所支持的所有本地環境中的字符集的所有編碼值。這里還保證空字符的編碼值為0);

符號常量NULL(空指針值);

宏offsetot(這是一個帶參數的宏,第一個參數應是一個結構類型,第二個參數應是結構成員名。

offsetot(s,m)

求出成員m在結構類型t的變量里的偏移量)。

注:其中有些定義也出現在其他頭文件里(如NULL)。

二、錯誤信息

定義了一個int類型的表達式errno,可以看作一個變量,其初始值為0,一些標準庫函數執行中出錯時將它設為非0值,但任何標準庫函數都設置它為0。

里還定義了兩個宏EDOM和ERANGE,都是非0的整數值。數學函數執行中遇到參數錯誤,就會將errno置為EDOM,如出現值域錯誤就會將errno置為ERANGE。

三、輸入輸出函數(

文件打開和關閉:

FILE *fopen(const char *filename, const char *mode);int fclose(FILE * stream);字符輸入輸出:

int fgetc(FILE *fp);int fputc(int c, FILE *fp);getc和putc與這兩個函數類似,但通過宏定義實現。通常有下面定義:

#define getchar() getc(stdin)#define putchar(c) putc(c, stdout)int ungetc(int c, FILE* stream); //把字符 c 退回流 stream

格式化輸入輸出:

int scanf(const char *format, ...);int printf(const char *format, ...);int fscanf(FILE *stream, const char *format, ...);int fprintf(FILE *stream, const char *format, ...);int sscanf(char *s, const char *format, ...);int sprintf(char *s, const char *format, ...);

行式輸入輸出:

char *fgets(char *buffer, int n, FILE *stream);int fputs(const char *buffer, FILE *stream);char *gets(char *s);int puts(const char *s);

直接輸入輸出:

size_t fread(void *pointer, size_t size, size_t num, FILE *stream);size_t fwrite(const void *pointer, size_t size, size_t num, FILE *stream);

四、數學函數(

1.三角函數:

三角函數 sin cos tan
反三角函數 asin acos atan
雙曲函數 sinh cosh tanh

2.指數和對數函數:

以e為底的指數函數 exp
自然對數函數 log
以10為底的對數函數 log10

3.其他函數:

平方根 sqrt
絕對值 fabs
乘冪,第一個參數作為底,第二個是指數 double pow(double, double)
實數的余數,兩個參數分別是被除數和除數 double fmod(double, double)

注:所有上面未給出類型特征的函數都取一個參數,其參數與返回值都是double類型。

下面函數返回雙精度值(包括函數ceil和floor)。在下表里,除其中有特別說明的參數之外,所有函數的其他參數都是double類型。

函數原型 意義解釋
ceil(x) 求出不小于x的最小整數(返回與這個整數對應的double值)
floor(x) 求出不大于x的最大整數(返回與這個整數對應的double值)
atan2(y, x) 求出tan-1(y/x),其值的范圍是[-pai,pai]
ldexp(x, int n) 求出x*2n
frexp(x, int*exp) 把x分解為y*2n,是位于區間[1/2,1)里的一個小數,作為函數結果返回,整數n通過指針*exp返回(應提供一個int變量地址)。當x為0時這兩個結果的值都是0
modf(x, double
*ip)
把x分解為小數部分和整數部分,小數部分作為函數返回值,整數部分通過指針*ip返回。

五、字符處理函數(

見下表:

int isalpha(c) c是字母字符
int isdigit(c) c是數字字符
int isalnum(c) c是字母或數字字符
int isspace(c) c是空格、制表符、換行符
int isupper(c) c是大寫字母
int islower(c) c是小寫字母
int iscntrl(c) c是控制字符
int isprint(c) c是可打印字符,包括空格
int isgraph(c) c是可打印字符,不包括空格
int isxdigit(c) c是十六進制數字字符
int ispunct(c) c是標點符號
int tolower(int c) 當c是大寫字母時返回對應小寫字母,否則返回c本身
int toupper(int c) 當c是小寫字母時返回對應大寫字母,否則返回c本身

注:條件成立時這些函數返回非0值。最后兩個轉換函數對于非字母參數返回原字符。

六、字符串函數(

1.字符串函數

所有字符串函數列在下表里,函數描述采用如下約定:s、t表示 (char *)類型的參數,cs、ct表示(const char*)類型的參數(它們都應表示字符串)。n表示size_t類型的參數(size_t是一個無符號的整數類型),c是整型參數(在函數里轉換到char):

函數原型 意義解釋
size_t strlen(cs) 求出cs的長度
char *strcpy(s,ct) 把ct復制到s。要求s指定足夠大的字符數組
char *strncpy(s,ct,n) 把ct里的至多n個字符復制到s。要求s指定一個足夠大的字符數組。如果ct里的字符不夠n個,就在s里填充空字符。
char *strcat(s,ct) 把ct里的字符復制到s里已有的字符串之后。s應指定一個保存著字符串,而且足夠大的字符數組。
char *strncat(s,ct,n) 把ct里的至多n個字符復制到s里已有的字符串之后。s應指定一個保存著字符串,而且足夠大的字符數組。
int strcmp(cs,ct) 比較字符串cs和ct的大小,在cs大于、等于、小于ct時分別返回正值、0、負值。
int strncmp(cs,ct,n) 比較字符串cs和ct的大小,至多比較n個字符。在cs大于、等于、小于ct時分別返回正值、0、負值。
char *strchr(cs,c) 在cs中查尋c并返回c第一個出現的位置,用指向這個位置的指針表示。當cs里沒有c時返回值NULL
char *strrchr(cs,c) 在cs中查尋c并返回c最后一個出現的位置,沒有時返回NULL
size_t strspn(cs,ct) 由cs起確定一段全由ct里的字符組成的序列,返回其長度
size_t strcspn(cs,ct) 由cs起確定一段全由非ct里的字符組成的序列,返回其長度
char *strpbrk(cs,ct) 在cs里查尋ct里的字符,返回第一個滿足條件的字符出現的位置,沒有時返回NULL
char *strstr(cs,ct) 在cs中查尋串ct(查詢子串),返回ct作為cs的子串的第一個出現的位置,ct未出現在cs里時返回NULL
char *strerror(n) 返回與錯誤編號n相關的錯誤信息串(指向該錯誤信息串的指針)
char *strtok(s,ct) 在s中查尋由ct中的字符作為分隔符而形成的單詞

2.存儲區操作

還有一組字符數組操作函數(存儲區操作函數),名字都以mem開頭,以某種高效方式實現。在下面原型中,參數s和t的類型是(void *),cs和ct的類型是(const void *),n的類型是size_t,c的類型是int(轉換為unsigned char)。

函數原型 意義解釋
void *memcpy(s,ct,n) 從ct處復制n個字符到s處,返回s
void *memmove(s,ct,n) 從ct處復制n個字符到s處,返回s,這里的兩個段允許重疊
int memcmp(cs,ct,n) 比較由cs和ct開始的n個字符,返回值定義同strcmp
void *memchr(cs,c,n) 在n個字符的范圍內查尋c在cs中的第一次出現,如果找到,返回該位置的指針值,否則返回NULL
void *memset(s,c,n) 將s的前n個字符設置為c,返回s

七、功能函數(

1.隨機數函數:

函數原型 意義解釋
int rand(void) 生成一個0到RAND_MAX的隨機整數
void srand(unsigned seed) 用seed為隨后的隨機數生成設置種子值

2.動態存儲分配函數:

函數原型 意義解釋
void *calloc(size_t n, size_t size) 分配一塊存儲,其中足以存放n個大小為size的對象,并將所有字節用0字符填充。返回該存儲塊的地址。不能滿足時返回NULL
void *malloc(size_t size) 分配一塊足以存放大小為size的存儲,返回該存儲塊的地址,不能滿足時返回NULL
void *realloc(void *p, size_t size) 將p所指存儲塊調整為大小size,返回新塊的地址。如能滿足要求,新塊的內容與原塊一致;不能滿足要求時返回NULL,此時原塊不變
void free(void *p) 釋放以前分配的動態存儲塊

3.幾個整數函數

幾個簡單的整數函數見下表,div_t和ldiv_t是兩個預定義結構類型,用于存放整除時得到的商和余數。div_t類型的成分是int類型的quot和rem,ldiv_t類型的成分是long類型的quot和rem。

函數原型 意義解釋
int abs(int n) 求整數的絕對值
long labs(long n) 求長整數的絕對值
div_t div(int n, int m) 求n/m,商和余數分別存放到結果結構的對應成員里
ldiv_t ldiv(long n, long m) 同上,參數為長整數

4.數值轉換

函數原型 意義解釋
double atof(const char *s) 由串s構造一個雙精度值
int atoi(const char *s) 由串s構造一個整數值
long atol(const char *s) 由串s構造一個長整數值

5.執行控制

1)非正常終止函數abort。

原型是:

void abort(void);

2)正常終止函數exit。

原型是:

void exit(int status);

導致程序按正常方式立即終止。status作為送給執行環境的出口值,0表示成功結束,兩個可用的常數為EXIT_SUCCESS,EXIT_FAILURE。

3)正常終止注冊函數atexit。

原型是:

int atexit(void (*fcn)(void))

可用本函數把一些函數注冊為結束動作。被注冊函數應當是無參無返回值的函數。注冊正常完成時atexit返回值0,否則返回非零值。

6.與執行環境交互

1)向執行環境傳送命令的函數system。

原型是:

int system(const char *s);

把串s傳遞給程序的執行環境要求作為系統命令執行。如以NULL為參數調用,函數返回非0表示環境里有命令解釋器。如果s不是NULL,返回值由實現確定。

2)訪問執行環境的函數getenv。

原型是:

char *getenv(const char *s);

從執行環境中取回與字符串s相關聯的環境串。如果找不到就返回NULL。本函數的具體結果由實現確定。在許多執行環境里,可以用這個函數去查看“環境變量”的值。

7.常用函數bsearch和qsort

1)二分法查找函數bsearch:

void *bsearch(const void *key, const void *base, size_t n, size_t size, int (*cmp)(const void *keyval, const void *datum));

函數指針參數cmp的實參應是一個與字符串比較函數strcmp類似的函數,確定排序的順序,當第一個參數keyval比第二個參數datum大、相等或小時分別返回正、零或負值。

2)快速排序函數qsort:

qsort對于比較函數cmp的要求與bsearch一樣。設有數組base[0],...,base[n-1],元素大小為size。用qsort可以把這個數組的元素按cmp確定的上升順序重新排列。

void qsort(void *base, size_t n, size_t size, int (*cmp)(const void *, const void *));

責任編輯:xj

原文標題:C語言常用標準庫解讀

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關注!文章轉載請注明出處。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 封裝
    +關注

    關注

    126

    文章

    7873

    瀏覽量

    142893
  • C語言
    +關注

    關注

    180

    文章

    7604

    瀏覽量

    136692
  • 函數
    +關注

    關注

    3

    文章

    4327

    瀏覽量

    62573

原文標題:C語言常用標準庫解讀

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    HAL標準的區別 HAL與CMSIS的關系

    在嵌入式系統開發中,HAL(硬件抽象層)標準是兩種常用的軟件,它們在功能和使用場景上有所不同。 1. 標準
    的頭像 發表于 12-02 14:02 ?392次閱讀

    云原生和數據哪個好一些

    云原生和數據哪個好一些?云原生和數據各有其獨特的優勢,適用于不同的場景。云原生強調高效資源利用、快速開發部署和高可伸縮性,適合需要高度靈活性和快速迭代的應用。而數據則注重數據
    的頭像 發表于 11-29 10:07 ?127次閱讀

    一些常見的動態電路

    無論是模電還是數電,理論知識相對來說還是比較枯燥,各種電路原理理解清楚不算容易,換種生動形象的方式或許會增加一些趣味性,也更容易理解這些知識。下面整理了一些常見的電路,以動態圖形的方
    的頭像 發表于 11-16 09:26 ?320次閱讀
    <b class='flag-5'>一些</b><b class='flag-5'>常見</b>的動態電路

    編程語言的誤區與常見問題

    誤區:編程語言的選擇 常見問題: 初學者在選擇編程語言時,往往會被市場上的熱門語言所吸引,而忽視了自己的實際需求和興趣。
    的頭像 發表于 11-15 09:35 ?270次閱讀

    NPU支持的編程語言有哪些

    NPU(Neural Processing Unit)是種專門為深度學習和人工智能應用設計的處理器。NPU支持的編程語言通常與它所集成的平臺或框架緊密相關。以下是一些常見的編程
    的頭像 發表于 11-15 09:21 ?606次閱讀

    分享一些常見的電路

    理解模電和數電的電路原理對于初學者來說可能比較困難,但通過一些生動的教學方法和資源,可以有效地提高學習興趣和理解能力。 下面整理了一些常見的電路,以動態圖形的方式展示。 整流電路 單相橋式整流
    的頭像 發表于 11-13 09:28 ?285次閱讀
    分享<b class='flag-5'>一些</b><b class='flag-5'>常見</b>的電路

    c語言怎么做可視化界面

    C語言種通用的編程語言,廣泛應用于系統編程、嵌入式開發等領域。雖然C語言本身并不支持直接創建
    的頭像 發表于 06-06 10:46 ?2283次閱讀

    stm32使用workbench只生成了一些.h和.c文件,然后該如何使用它們?

    使用workbench只生成了一些.h和.c文件,然后該如何使用它們?還需要手動在MDK中建立工程添加標準再把這些文件加進去么?哪位有相關開發經驗,請賜教!
    發表于 05-15 07:29

    AWTK 開源串口屏開發(18) - 用 C 語言自定義命令

    編寫代碼即可實現常見的應用。但是,有時候我們需要自定義一些命令,以實現一些特殊的功能。本文檔介紹如何使用C語言自定義命令。1.實現hmi_m
    的頭像 發表于 05-11 08:24 ?436次閱讀
    AWTK 開源串口屏開發(18) - 用 <b class='flag-5'>C</b> <b class='flag-5'>語言</b>自定義命令

    C語言:嵌入式開發中的關鍵編譯器角色

    嵌入式程序開發跟硬件密切相關,需要使用C語言來讀寫底層寄存器、存取數據、控制硬件等,C語言和硬件之間由編譯器來聯系,一些
    發表于 04-26 14:53 ?610次閱讀
    <b class='flag-5'>C</b><b class='flag-5'>語言</b>:嵌入式開發中的關鍵編譯器角色

    C語言的指針用法

    C語言編程中善用指針可以簡化一些任務的處理,而對于一些任務(比如動態內存分配),必須要有指針才行的。也就是說精通C指針編程是很有必要的,幫助
    發表于 03-05 14:22 ?346次閱讀
    <b class='flag-5'>C</b><b class='flag-5'>語言</b>的指針用法

    介紹C語言中錯誤處理和異常處理的一些常用的方法和策略

    C語言種低級的、靜態的、結構化的編程語言,它沒有提供像C++或Java等高級語言中的異常處理
    的頭像 發表于 02-28 14:25 ?617次閱讀

    ArkTS語言基礎類-解析

    被設計用來傳輸和存儲數據,是種可擴展標記語言語言基礎類提供了[XML生成、解析與轉換]的能力。 URL、URI構造和解析能力:其中[URI]是統
    發表于 02-20 16:44

    plc編程語言c語言的聯系 c語言和PLC有什么區別

    語言,主要用于開發各種應用程序。盡管PLC編程語言C語言一些相似之處,但它們之間也存在一些
    的頭像 發表于 02-05 14:21 ?4093次閱讀

    如何解決C語言中的“訪問權限沖突”異常?C語言引發異常原因分析

    一些措施來解決和防止其發生。本文將詳細介紹C語言中訪問權限沖突異常的原因以及解決方法。 、訪問權限沖突異常的原因分析 訪問權限沖突異常可分為兩類:訪問私有成員和訪問未定義成員。下面分
    的頭像 發表于 01-12 16:03 ?5632次閱讀
    主站蜘蛛池模板: 抽插妇女疯狂视频| 私密按摩师在线观看 百度网盘| 国产制服丝袜91在线| 丰满的女友1在线观看| 冰山高冷受被c到哭np双性| 99久久综合精品免费| 99精品视频在线观看| 99精品免费久久久久久久久日本| 1a级毛片免费观看| 92午夜理论第1000集 app| 97超碰在线视频 免费| 91在线青春娱乐精品分类| 99精品视频在线观看免费播放| 99国产这里只有精品视频| 99国产小视频| 厕所RXXX| 国产精品丰满人妻AV麻豆| 国产WW高清大片免费看| 国产国产成人人免费影院| 国产精品婷婷久青青原| 国产小伙和50岁熟女23p| 国产日韩欧美综合久久| 好硬好湿好大再深一点动态图| 国产一区内射最近更新| 精品国产原创在线观看视频| 极品美女久久久久久久久久久| 九色PORNY真实丨国产大胸| 久久看片网| 欧美日韩精品不卡在线观看| 日本久久久| 亚洲国产区中文在线观看| 一本久道久久综合婷婷五月| 3DNagoonimation动漫| 白百合在线观看| 国产伦精品一区二区三区免费观看| 国产亚洲精品看片在线观看| 精品无码国产AV一区二区三区| 伦理片在线线249| 日操夜操天天操| 亚洲国产日韩欧美在线a乱码| 在线观看日韩一区|