locale.h 頭文件定義了特定地域的設置,好比日期格式和貨幣符號。接下來咱們將介紹一些宏,以及一個重要的結構 struct lconv 和兩個重要的函數。html
下面列出了頭文件 locale.h 中定義的宏,這些宏將在下列的兩個函數中使用:git
序號 | 宏 & 描述 |
---|---|
1 | LC_ALL 設置下面的全部選項。 |
2 | LC_COLLATE 影響 strcoll 和 strxfrm 函數。 |
3 | LC_CTYPE 影響全部字符函數。 |
4 | LC_MONETARY 影響 localeconv 函數提供的貨幣信息。 |
5 | LC_NUMERIC 影響 localeconv 函數提供的小數點格式化和信息。 |
6 | LC_TIME 影響 strftime 函數。 |
下面列出了頭文件 locale.h 中定義的函數:數組
序號 | 函數 & 描述 |
---|---|
1 | char setlocale(int category, const char locale) 設置或讀取地域化信息。 |
2 | struct lconv *localeconv(void) 設置或讀取地域化信息。 |
typedef struct { char *decimal_point; char *thousands_sep; char *grouping; char *int_curr_symbol; char *currency_symbol; char *mon_decimal_point; char *mon_thousands_sep; char *mon_grouping; char *positive_sign; char *negative_sign; char int_frac_digits; char frac_digits; char p_cs_precedes; char p_sep_by_space; char n_cs_precedes; char n_sep_by_space; char p_sign_posn; char n_sign_posn; } lconv
如下是各字段的描述:異步
序號 | 字段 & 描述 |
---|---|
1 | decimal_point 用於非貨幣值的小數點字符。 |
2 | thousands_sep 用於非貨幣值的千位分隔符。 |
3 | grouping 一個表示非貨幣量中每組數字大小的字符串。每一個字符表明一個整數值,每一個整數指定當前組的位數。值爲 0 意味着前一個值將應用於剩餘的分組。 |
4 | int_curr_symbol 國際貨幣符號使用的字符串。前三個字符是由 ISO 4217:1987 指定的,第四個字符用於分隔貨幣符號和貨幣量。 |
5 | currency_symbol 用於貨幣的本地符號。 |
6 | mon_decimal_point 用於貨幣值的小數點字符。 |
7 | mon_thousands_sep 用於貨幣值的千位分隔符。 |
8 | mon_grouping 一個表示貨幣值中每組數字大小的字符串。每一個字符表明一個整數值,每一個整數指定當前組的位數。值爲 0 意味着前一個值將應用於剩餘的分組。 |
9 | positive_sign 用於正貨幣值的字符。 |
10 | negative_sign 用於負貨幣值的字符。 |
11 | int_frac_digits 國際貨幣值中小數點後要顯示的位數。 |
12 | frac_digits 貨幣值中小數點後要顯示的位數。 |
13 | p_cs_precedes 若是等於 1,則 currency_symbol 出如今正貨幣值以前。若是等於 0,則 currency_symbol 出如今正貨幣值以後。 |
14 | p_sep_by_space 若是等於 1,則 currency_symbol 和正貨幣值之間使用空格分隔。若是等於 0,則 currency_symbol 和正貨幣值之間不使用空格分隔。 |
15 | n_cs_precedes 若是等於 1,則 currency_symbol 出如今負貨幣值以前。若是等於 0,則 currency_symbol 出如今負貨幣值以後。 |
16 | n_sep_by_space 若是等於 1,則 currency_symbol 和負貨幣值之間使用空格分隔。若是等於 0,則 currency_symbol 和負貨幣值之間不使用空格分隔。 |
17 | p_sign_posn 表示正貨幣值中正號的位置。 |
18 | n_sign_posn 表示負貨幣值中負號的位置。 |
下面的值用於 p_sign_posn 和 n_sign_posn:函數
值 | 描述 |
---|---|
0 | 封裝值和 currency_symbol 的括號。 |
1 | 放置在值和 currency_symbol 以前的符號。 |
2 | 放置在值和 currency_symbol 以後的符號。 |
3 | 緊挨着放置在值和 currency_symbol 以前的符號。 |
4 | 緊挨着放置在值和 currency_symbol 以後的符號。 |
math.h 頭文件定義了各類數學函數和一個宏。在這個庫中全部可用的功能都帶有一個 double 類型的參數,且都返回 double 類型的結果。atom
下面是這個庫中定義的惟一的一個宏:spa
序號 | 宏 & 描述 |
---|---|
1 | HUGE_VAL 當函數的結果不能夠表示爲浮點數時。若是是由於結果的幅度太大以至於沒法表示,則函數會設置 errno 爲 ERANGE 來表示範圍錯誤,並返回一個由宏 HUGE_VAL 或者它的否認(- HUGE_VAL)命名的一個特定的很大的值。若是結果的幅度過小,則會返回零值。在這種狀況下,error 可能會被設置爲 ERANGE,也有可能不會被設置爲 ERANGE。 |
下面列出了頭文件 math.h 中定義的函數:指針
序號 | 函數 & 描述 |
---|---|
1 | double acos(double x) 返回以弧度表示的 x 的反餘弦。 |
2 | double asin(double x) 返回以弧度表示的 x 的反正弦。 |
3 | double atan(double x) 返回以弧度表示的 x 的反正切。 |
4 | double atan2(double y, double x) 返回以弧度表示的 y/x 的反正切。y 和 x 的值的符號決定了正確的象限。 |
5 | double cos(double x) 返回弧度角 x 的餘弦。 |
6 | double cosh(double x) 返回 x 的雙曲餘弦。 |
7 | double sin(double x) 返回弧度角 x 的正弦。 |
8 | double sinh(double x) 返回 x 的雙曲正弦。 |
9 | double tanh(double x) 返回 x 的雙曲正切。 |
10 | double exp(double x) 返回 e 的 x 次冪的值。 |
11 | double frexp(double x, int *exponent) 把浮點數 x 分解成尾數和指數。返回值是尾數,並將指數存入 exponent 中。所得的值是 x = mantissa * 2 ^ exponent。 |
12 | double ldexp(double x, int exponent) 返回 x 乘以 2 的 exponent 次冪。 |
13 | double log(double x) 返回 x 的天然對數(基數爲 e 的對數)。 |
14 | double log10(double x) 返回 x 的經常使用對數(基數爲 10 的對數)。 |
15 | double modf(double x, double *integer) 返回值爲小數部分(小數點後的部分),並設置 integer 爲整數部分。 |
16 | double pow(double x, double y) 返回 x 的 y 次冪。 |
17 | double sqrt(double x) 返回 x 的平方根。 |
18 | double ceil(double x) 返回大於或等於 x 的最小的整數值。 |
19 | double fabs(double x) 返回 x 的絕對值。 |
20 | double floor(double x) 返回小於或等於 x 的最大的整數值。 |
21 | double fmod(double x, double y) 返回 x 除以 y 的餘數。 |
setjmp.h 頭文件定義了宏 setjmp()、函數 longjmp() 和變量類型 jmp_buf,該變量類型會繞過正常的函數調用和返回規則。code
下面列出了頭文件 setjmp.h 中定義的變量:htm
序號 | 變量 & 描述 |
---|---|
1 | jmp_buf 這是一個用於存儲宏 setjmp() 和函數 longjmp() 相關信息的數組類型。 |
下面是這個庫中定義的惟一的一個宏:
序號 | 宏 & 描述 |
---|---|
1 | int setjmp(jmp_buf environment) 這個宏把當前環境保存在變量 environment 中,以便函數 longjmp() 後續使用。若是這個宏直接從宏調用中返回,則它會返回零,可是若是它從 longjmp() 函數調用中返回,則它會返回一個非零值。 |
下面是頭文件 setjmp.h 中定義的惟一的一個函數:
序號 | 函數 & 描述 |
---|---|
1 | void longjmp(jmp_buf environment, int value) 該函數恢復最近一次調用 setjmp() 宏時保存的環境,jmp_buf 參數的設置是由以前調用 setjmp() 生成的。 |
signal.h 頭文件定義了一個變量類型 sig_atomic_t、兩個函數調用和一些宏來處理程序執行期間報告的不一樣信號。
下面是頭文件 signal.h 中定義的變量類型:
序號 | 變量 & 描述 |
---|---|
1 | sig_atomic_t 這是 int 類型,在信號處理程序中做爲變量使用。它是一個對象的整數類型,該對象能夠做爲一個原子實體訪問,即便存在異步信號時,該對象能夠做爲一個原子實體訪問。 |
下面是頭文件 signal.h 中定義的宏,這些宏將在下列兩個函數中使用。SIG_ 宏與 signal 函數一塊兒使用來定義信號的功能。
序號 | 宏 & 描述 |
---|---|
1 | SIG_DFL 默認的信號處理程序。 |
2 | SIG_ERR 表示一個信號錯誤。 |
3 | SIG_IGN 忽視信號。 |
SIG 宏用於表示如下各類條件的信號碼:
序號 | 宏 & 描述 |
---|---|
1 | SIGABRT 程序異常終止。 |
2 | SIGFPE 算術運算出錯,如除數爲 0 或溢出。 |
3 | SIGILL 非法函數映象,如非法指令。 |
4 | SIGINT 中斷信號,如 ctrl-C。 |
5 | SIGSEGV 非法訪問存儲器,如訪問不存在的內存單元。 |
6 | SIGTERM 發送給本程序的終止請求信號。 |
下面是頭文件 signal.h 中定義的函數:
序號 | 函數 & 描述 |
---|---|
1 | void (signal(int sig, void (func)(int)))(int) 該函數設置一個函數來處理信號,即信號處理程序。 |
2 | int raise(int sig) 該函數會促使生成信號 sig。sig 參數與 SIG 宏兼容。 |
stdarg.h 頭文件定義了一個變量類型 va_list 和三個宏,這三個宏可用於在參數個數未知(即參數個數可變)時獲取函數中的參數。
可變參數的函數通在參數列表的末尾是使用省略號(,...)定義的。
下面是頭文件 stdarg.h 中定義的變量類型:
序號 | 變量 & 描述 |
---|---|
1 | va_list 這是一個適用於 va_start()、va_arg() 和 va_end() 這三個宏存儲信息的類型。 |
下面是頭文件 stdarg.h 中定義的宏:
序號 | 宏 & 描述 |
---|---|
1 | void va_start(va_list ap, last_arg) 這個宏初始化 ap 變量,它與 va_arg 和 va_end 宏是一塊兒使用的。last_arg 是最後一個傳遞給函數的已知的固定參數,即省略號以前的參數。 |
2 | type va_arg(va_list ap, type) 這個宏檢索函數參數列表中類型爲 type 的下一個參數。 |
3 | void va_end(va_list ap) 這個宏容許使用了 va_start 宏的帶有可變參數的函數返回。若是在從函數返回以前沒有調用 va_end,則結果爲未定義。 |
stddef .h 頭文件定義了各類變量類型和宏。這些定義中的大部分也出如今其它頭文件中。
下面是頭文件 stddef.h 中定義的變量類型:
序號 | 變量 & 描述 |
---|---|
1 | ptrdiff_t 這是有符號整數類型,它是兩個指針相減的結果。 |
2 | size_t 這是無符號整數類型,它是 sizeof 關鍵字的結果。 |
3 | wchar_t 這是一個寬字符常量大小的整數類型。 |
下面是頭文件 stddef.h 中定義的宏:
序號 | 宏 & 描述 |
---|---|
1 | NULL 這個宏是一個空指針常量的值。 |
2 | offsetof(type, member-designator) 這會生成一個類型爲 size_t 的整型常量,它是一個結構成員相對於結構開頭的字節偏移量。成員是由 member-designator 給定的,結構的名稱是在 type 中給定的。 |