Стандартная библиотека C - Краткое руководство
В assert.h заголовочный файл стандартной библиотеки C предоставляет макрос, называемый assert который можно использовать для проверки предположений, сделанных программой, и вывода диагностического сообщения, если это предположение неверно.
Определенный макрос assert относится к другому макросу NDEBUGкоторый не является частью <assert.h>. Если NDEBUG определен как имя макроса в исходном файле, в точке, где включен <assert.h>,assert макрос определяется следующим образом -
#define assert(ignore) ((void)0)
Макросы библиотеки
Ниже приводится единственная функция, определенная в заголовке assert.h:
Sr.No. | Описание функции |
---|---|
1 | void assert (выражение типа int) На самом деле это макрос, а не функция, которую можно использовать для добавления диагностики в вашу программу C. |
В ctype.h Заголовочный файл стандартной библиотеки C объявляет несколько функций, которые полезны для тестирования и сопоставления символов.
Все функции принимает int как параметр, значение которого должно быть EOF или представлено как беззнаковый символ.
Все функции возвращают ненулевое значение (истина), если аргумент c удовлетворяет описанному условию, и ноль (ложь), если нет.
Библиотечные функции
Ниже приведены функции, определенные в заголовке ctype.h:
Sr.No. | Описание функции |
---|---|
1 | int isalnum (int c) Эта функция проверяет, является ли переданный символ буквенно-цифровым. |
2 | int isalpha (int c) Эта функция проверяет, является ли переданный символ буквенным. |
3 | интервал iscntrl (интервал c) Эта функция проверяет, является ли переданный символ контрольным. |
4 | int isdigit (int c) Эта функция проверяет, является ли переданный символ десятичной цифрой. |
5 | int isgraph (int c) Эта функция проверяет, имеет ли переданный символ графическое представление с использованием локали. |
6 | int islower (int c) Эта функция проверяет, является ли переданный символ строчной буквой. |
7 | int isprint (int c) Эта функция проверяет, можно ли распечатать переданный символ. |
8 | int ispunct (int c) Эта функция проверяет, является ли переданный символ символом пунктуации. |
9 | int isspace (int c) Эта функция проверяет, является ли переданный символ пробелом. |
10 | int isupper (int c) Эта функция проверяет, является ли переданный символ прописной буквой. |
11 | int isxdigit (int c) Эта функция проверяет, является ли переданный символ шестнадцатеричной цифрой. |
Библиотека также содержит две функции преобразования, которые принимают и возвращают int.
Sr.No. | Описание функции |
---|---|
1 | int tolower (int c) Эта функция преобразует прописные буквы в строчные. |
2 | интервал туппер (интервал c) Эта функция преобразует строчные буквы в прописные. |
Классы персонажей
Sr.No. | Класс персонажа и описание |
---|---|
1 | Digits Это набор целых чисел {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}. |
2 | Hexadecimal digits Это набор {0 1 2 3 4 5 6 7 8 9 ABCDEF abcdef}. |
3 | Lowercase letters Это набор строчных букв {abcdefghijklmnopqrstu vwxyz}. |
4 | Uppercase letters Это набор заглавных букв {ABCDEFGHIJKLMNOPQRSTU VWXYZ}. |
5 | Letters Это набор строчных и прописных букв. |
6 | Alphanumeric characters Это набор цифр, строчных и прописных букв. |
7 | Punctuation characters Это набор! "# $% & '() * +, -. /:; <=>? @ [\] ^ _` {|} ~ |
8 | Graphical characters Это набор буквенно-цифровых символов и знаков пунктуации. |
9 | Space characters Это набор из табуляции, новой строки, вертикальной табуляции, подачи формы, возврата каретки и пробела. |
10 | Printable characters Это набор буквенно-цифровых символов, знаков пунктуации и пробелов. |
11 | Control characters В ASCII эти символы имеют восьмеричные коды от 000 до 037 и 177 (DEL). |
12 | Blank characters Это пробелы и табуляции. |
13 | Alphabetic characters Это набор строчных и прописных букв. |
В errno.h заголовочный файл стандартной библиотеки C определяет целочисленную переменную errno, который устанавливается системными вызовами и некоторыми библиотечными функциями в случае ошибки, чтобы указать, что пошло не так. Этот макрос расширяется до изменяемого lvalue типа int, поэтому он может быть как прочитан, так и изменен программой.
В errnoустанавливается на ноль при запуске программы. Некоторые функции стандартной библиотеки C изменяют свое значение на отличное от нуля, чтобы сигнализировать о некоторых типах ошибок. Вы также можете изменить его значение или сбросить его до нуля по своему усмотрению.
В errno.h заголовочный файл также определяет список макросов с указанием различных кодов ошибок, который будет расширен до целочисленных константных выражений с типом int.
Макросы библиотеки
Ниже приведены макросы, определенные в заголовке errno.h:
Sr.No. | Макрос и описание |
---|---|
1 | extern int errno Этот макрос устанавливается системными вызовами и некоторыми библиотечными функциями в случае ошибки, чтобы указать, что пошло не так. |
2 | Ошибка домена EDOM Этот макрос представляет ошибку домена, которая возникает, если входной аргумент находится за пределами домена, в котором определена математическая функция и для errno задано значение EDOM. |
3 | ERANGE Ошибка диапазона Этот макрос представляет ошибку диапазона, которая возникает, если входной аргумент находится за пределами диапазона, в котором определена математическая функция, а для errno задано значение ERANGE. |
В float.hЗаголовочный файл стандартной библиотеки C содержит набор различных платформенно-зависимых констант, связанных со значениями с плавающей запятой. Эти константы предложены ANSI C. Они позволяют создавать более переносимые программы. Прежде чем проверять все константы, хорошо понять, что число с плавающей запятой состоит из следующих четырех элементов:
Sr.No. | Компонент и описание компонентов |
---|---|
1 | S знак (+/-) |
2 | b основание или основание системы счисления экспоненты, 2 для двоичного, 10 для десятичного, 16 для шестнадцатеричного и так далее ... |
3 | e экспонента, целое число от минимума emin и максимум emax. |
4 | p точность, количество цифр с основанием b в мантиссе. |
Основываясь на приведенных выше 4 компонентах, значение с плавающей запятой будет следующим:
floating-point = ( S ) p x be
or
floating-point = (+/-) precision x baseexponent
Макросы библиотеки
Следующие значения зависят от реализации и определяются с помощью директивы #define, но эти значения не могут быть ниже, чем указано здесь. Обратите внимание, что во всех случаях FLT относится к типуfloat, DBL относится к double, а LDBL относится к long double.
Sr.No. | Макрос и описание |
---|---|
1 | FLT_ROUNDS Определяет режим округления для сложения с плавающей запятой и может иметь любое из следующих значений:
|
2 | FLT_RADIX 2 Это определяет базовое основание системы счисления экспоненты. Основание-2 - двоичное, основание-10 - нормальное десятичное представление, основание-16 - шестнадцатеричное. |
3 | FLT_MANT_DIG DBL_MANT_DIG LDBL_MANT_DIG Эти макросы определяют количество цифр в номере (в базе FLT_RADIX). |
4 | FLT_DIG 6 DBL_DIG 10 LDBL_DIG 10 Эти макросы определяют максимальное количество десятичных цифр (основание 10), которое может быть представлено без изменений после округления. |
5 | FLT_MIN_EXP DBL_MIN_EXP LDBL_MIN_EXP Эти макросы определяют минимальное отрицательное целое число для экспоненты в базе FLT_RADIX. |
6 | FLT_MIN_10_EXP -37 DBL_MIN_10_EXP -37 LDBL_MIN_10_EXP -37 Эти макросы определяют минимальное отрицательное целое число для экспоненты с основанием 10. |
7 | FLT_MAX_EXP DBL_MAX_EXP LDBL_MAX_EXP Эти макросы определяют максимальное целочисленное значение для экспоненты в базовом FLT_RADIX. |
8 | FLT_MAX_10_EXP +37 DBL_MAX_10_EXP +37 LDBL_MAX_10_EXP +37 Эти макросы определяют максимальное целочисленное значение для экспоненты с основанием 10. |
9 | FLT_MAX 1E+37 DBL_MAX 1E+37 LDBL_MAX 1E+37 Эти макросы определяют максимальное конечное значение с плавающей запятой. |
10 | FLT_EPSILON 1E-5 DBL_EPSILON 1E-9 LDBL_EPSILON 1E-9 Эти макросы определяют наименее значимую представляемую цифру. |
11 | FLT_MIN 1E-37 DBL_MIN 1E-37 LDBL_MIN 1E-37 Эти макросы определяют минимальные значения с плавающей запятой. |
пример
В следующем примере показано использование нескольких констант, определенных в файле float.h.
#include <stdio.h>
#include <float.h>
int main () {
printf("The maximum value of float = %.10e\n", FLT_MAX);
printf("The minimum value of float = %.10e\n", FLT_MIN);
printf("The number of digits in the number = %.10e\n", FLT_MANT_DIG);
}
Давайте скомпилируем и запустим указанную выше программу, которая даст следующий результат:
The maximum value of float = 3.4028234664e+38
The minimum value of float = 1.1754943508e-38
The number of digits in the number = 7.2996655210e-312
В limits.hзаголовок определяет различные свойства различных типов переменных. Макросы, определенные в этом заголовке, ограничивают значения различных типов переменных, таких как char, int и long.
Эти ограничения указывают, что переменная не может хранить какое-либо значение за пределами этих ограничений, например, беззнаковый символ может хранить до максимального значения 255.
Макросы библиотеки
Следующие значения зависят от реализации и определяются с помощью директивы #define, но эти значения не могут быть ниже, чем указано здесь.
Макрос | Значение | Описание |
---|---|---|
CHAR_BIT | 8 | Определяет количество бит в байте. |
SCHAR_MIN | -128 | Определяет минимальное значение для подписанного char. |
SCHAR_MAX | +127 | Определяет максимальное значение для подписанного char. |
UCHAR_MAX | 255 | Определяет максимальное значение для беззнакового символа. |
CHAR_MIN | -128 | Определяет минимальное значение для типа char, и его значение будет равно SCHAR_MIN, если char представляет отрицательные значения, в противном случае - нулю. |
CHAR_MAX | +127 | Определяет значение для типа char, и его значение будет равно SCHAR_MAX, если char представляет отрицательные значения, иначе UCHAR_MAX. |
MB_LEN_MAX | 16 | Определяет максимальное количество байтов в многобайтовом символе. |
SHRT_MIN | -32768 | Определяет минимальное значение для короткого int. |
SHRT_MAX | +32767 | Определяет максимальное значение для короткого int. |
USHRT_MAX | 65535 | Определяет максимальное значение для беззнакового короткого int. |
INT_MIN | -2147483648 | Определяет минимальное значение для int. |
INT_MAX | +2147483647 | Определяет максимальное значение для int. |
UINT_MAX | 4294967295 | Определяет максимальное значение для беззнакового int. |
LONG_MIN | -9223372036854775808 | Определяет минимальное значение для long int. |
LONG_MAX | +9223372036854775807 | Определяет максимальное значение для long int. |
ULONG_MAX | 18446744073709551615 | Определяет максимальное значение для беззнакового long int. |
пример
В следующем примере показано использование нескольких констант, определенных в limits.h файл.
#include <stdio.h>
#include <limits.h>
int main() {
printf("The number of bits in a byte %d\n", CHAR_BIT);
printf("The minimum value of SIGNED CHAR = %d\n", SCHAR_MIN);
printf("The maximum value of SIGNED CHAR = %d\n", SCHAR_MAX);
printf("The maximum value of UNSIGNED CHAR = %d\n", UCHAR_MAX);
printf("The minimum value of SHORT INT = %d\n", SHRT_MIN);
printf("The maximum value of SHORT INT = %d\n", SHRT_MAX);
printf("The minimum value of INT = %d\n", INT_MIN);
printf("The maximum value of INT = %d\n", INT_MAX);
printf("The minimum value of CHAR = %d\n", CHAR_MIN);
printf("The maximum value of CHAR = %d\n", CHAR_MAX);
printf("The minimum value of LONG = %ld\n", LONG_MIN);
printf("The maximum value of LONG = %ld\n", LONG_MAX);
return(0);
}
Давайте скомпилируем и запустим указанную выше программу, которая даст следующий результат:
The number of bits in a byte 8
The minimum value of SIGNED CHAR = -128
The maximum value of SIGNED CHAR = 127
The maximum value of UNSIGNED CHAR = 255
The minimum value of SHORT INT = -32768
The maximum value of SHORT INT = 32767
The minimum value of INT = -2147483648
The maximum value of INT = 2147483647
The minimum value of CHAR = -128
The maximum value of CHAR = 127
The minimum value of LONG = -9223372036854775808
The maximum value of LONG = 9223372036854775807
В locale.hЗаголовок определяет настройки для конкретного местоположения, например форматы даты и символы валюты. Вы найдете несколько макросов, определенных вместе с важной структуройstruct lconv и две важные функции, перечисленные ниже.
Макросы библиотеки
Ниже приведены макросы, определенные в заголовке, и эти макросы будут использоваться в двух функциях, перечисленных ниже:
Sr.No. | Макрос и описание |
---|---|
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:
Sr.No. | Описание функции |
---|---|
1 | char * setlocale (int категория, const char * locale) Устанавливает или считывает информацию, зависящую от местоположения. |
2 | struct lconv * localeconv (недействительно) Устанавливает или считывает информацию, зависящую от местоположения. |
Структура библиотеки
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
Ниже приводится описание каждого из полей -
Sr.No. | Поле и описание |
---|---|
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, то символ валюты появляется перед положительным денежным значением. Если равно 0, то символ валюты появляется после положительного денежного значения. |
14 | p_sep_by_space Если равно 1, то символ валюты отделяется пробелом от положительного денежного значения. Если равно 0, то между символом валюты и положительным денежным значением нет пробела. |
15 | n_cs_precedes Если равно 1, то символ валюты предшествует отрицательному денежному значению. Если равно 0, то символ валюты заменяет отрицательное денежное значение. |
16 | n_sep_by_space Если равно 1, то символ валюты отделяется пробелом от отрицательного денежного значения. Если равно 0, то между символом валюты и отрицательным денежным значением нет пробела. |
17 | p_sign_posn Представляет положение положительного_знака в положительном денежном значении. |
18 | n_sign_posn Представляет позицию отрицательного_знака в отрицательном денежном выражении. |
Следующие значения используются для p_sign_posn и n_sign_posn -
Значение | Описание |
---|---|
0 | В круглых скобках заключено значение и символ валюты. |
1 | Знак стоит перед значением и символом валюты. |
2 | Знак следует за значением и символом валюты. |
3 | Знак непосредственно предшествует значению и символу валюты. |
4 | Знак сразу следует за значением и символом валюты. |
В math.hзаголовок определяет различные математические функции и один макрос. Все функции, доступные в этой библиотеке, принимаютdouble как аргумент и возврат double в результате.
Макросы библиотеки
В этой библиотеке определен только один макрос -
Sr.No. | Макрос и описание |
---|---|
1 | HUGE_VAL Этот макрос используется, когда результат функции не может быть представлен в виде числа с плавающей запятой. Если величина правильного результата слишком велика для представления, функция устанавливает для errno значение ERANGE, чтобы указать ошибку диапазона, и возвращает конкретное очень большое значение, названное макросом HUGE_VAL или его отрицанием (- HUGE_VAL). Если величина результата слишком мала, вместо этого возвращается нулевое значение. В этом случае для errno может быть установлено значение ERANGE, а может и нет. |
Библиотечные функции
Ниже приведены функции, определенные в заголовке math.h:
Sr.No. | Описание функции |
---|---|
1 | двойной acos (двойной x) Возвращает арккосинус x в радианах. |
2 | двойной азин (двойной х) Возвращает арксинус x в радианах. |
3 | двойной атан (двойной х) Возвращает арктангенс x в радианах. |
4 | двойной atan2 (двойной y, двойной x) Возвращает арктангенс в радианах y / x на основе знаков обоих значений для определения правильного квадранта. |
5 | двойной cos (двойной x) Возвращает косинус радианного угла x. |
6 | двойной сш (двойной х) Возвращает гиперболический косинус x. |
7 | двойной грех (двойной х) Возвращает синус радианного угла x. |
8 | двойной зз (двойной х) Возвращает гиперболический синус x. |
9 | двойной танх (двойной х) Возвращает гиперболический тангенс x. |
10 | двойной опыт (двойной х) Возвращает значение e в x степени. |
11 | двойной frexp (двойной x, int * показатель степени) Возвращаемое значение - мантисса, а целое число, на которое указывает экспонента, - это показатель степени. Результирующее значение - x = мантисса * 2 ^ экспонента. |
12 | двойной ldexp (двойной x, int показатель) Возврат x умноженный на 2 в степени экспоненты. |
13 | двойной журнал (двойной х) Возвращает натуральный логарифм (логарифм по основанию-е) числа. x. |
14 | двойной log10 (двойной x) Возвращает десятичный логарифм (десятичный логарифм) числа. x. |
15 | двойной modf (двойной x, двойной * целое) Возвращаемое значение представляет собой дробную составляющую (часть после десятичной дроби) и устанавливает целочисленное значение для целочисленного компонента. |
16 | двойной pow (двойной x, двойной y) Возвращает x в степени y. |
17 | двойной sqrt (двойной x) Возвращает квадратный корень из x. |
18 | двойной потолок (двойной х) Возвращает наименьшее целочисленное значение, большее или равное x. |
19 | двойные фабрики (двойной х) Возвращает абсолютное значение x. |
20 | двойной этаж (двойной х) Возвращает наибольшее целое число, меньшее или равное x. |
21 год | двойной fmod (двойной x, двойной y) Возвращает остаток от деления x на y. |
В setjmp.h заголовок определяет макрос setjmp(), одна функция longjmp(), и один тип переменной jmp_buf, для обхода нормального вызова функции и возврата.
Библиотечные переменные
Ниже приводится тип переменной, определенный в заголовке setjmp.h:
Sr.No. | Переменная и описание |
---|---|
1 | jmp_buf Это тип массива, используемый для хранения информации для макроса. setjmp() и функция longjmp(). |
Макросы библиотеки
В этой библиотеке определен только один макрос -
Sr.No. | Макрос и описание |
---|---|
1 | int setjmp (среда jmp_buf) Этот макрос сохраняет текущее окружение в переменнуюenvironment для последующего использования функцией longjmp(). Если этот макрос возвращается непосредственно из вызова макроса, он возвращает ноль, но если он возвращается изlongjmp() вызов функции, то возвращается ненулевое значение. |
Библиотечные функции
Ниже приводится единственная функция, определенная в заголовке setjmp.h:
Sr.No. | Описание функции |
---|---|
1 | void longjmp (среда jmp_buf, значение int) Эта функция восстанавливает среду, сохраненную последним вызовом setjmp() макрос в том же вызове программы с соответствующим jmp_buf аргумент. |
В signal.h заголовок определяет тип переменной sig_atomic_t, два вызова функций и несколько макросов для обработки различных сигналов, сообщаемых во время выполнения программы.
Библиотечные переменные
Ниже приводится тип переменной, определенный в заголовке signal.h -
Sr.No. | Переменная и описание |
---|---|
1 | sig_atomic_t Это из inttype и используется как переменная в обработчике сигнала. Это интегральный тип объекта, к которому можно получить доступ как к атомарной сущности даже при наличии асинхронных сигналов. |
Макросы библиотеки
Ниже приведены макросы, определенные в заголовке signal.h, и эти макросы будут использоваться в двух перечисленных ниже функциях. ВSIG_ макросы используются с функцией сигнала для определения функций сигнала.
Sr.No. | Макрос и описание |
---|---|
1 | SIG_DFL Обработчик сигналов по умолчанию. |
2 | SIG_ERR Представляет ошибку сигнала. |
3 | SIG_IGN Сигнал игнорируется. |
В SIG макросы используются для представления номера сигнала в следующих условиях:
Sr.No. | Макрос и описание |
---|---|
1 | SIGABRT Аварийное завершение программы. |
2 | SIGFPE Ошибка с плавающей точкой, такая как деление на ноль. |
3 | SIGILL Незаконная операция. |
4 | SIGINT Сигнал прерывания, например Ctrl-C. |
5 | SIGSEGV Недействительный доступ к хранилищу, например, нарушение сегмента. |
6 | SIGTERM Запрос на расторжение. |
Библиотечные функции
Ниже приведены функции, определенные в заголовке signal.h -
Sr.No. | Описание функции |
---|---|
1 | void (* сигнал (int сиг, void (* func) (int))) (int) Эта функция устанавливает функцию для обработки сигнала, то есть обработчика сигнала. |
2 | int поднять (int sig) Эта функция вызывает сигнал sigбудут созданы. Аргумент sig совместим с макросами SIG. |
В stdarg.h заголовок определяет тип переменной va_list и три макроса, которые можно использовать для получения аргументов функции, когда количество аргументов неизвестно, т.е. переменное количество аргументов.
Функция переменных аргументов определяется многоточием (, ...) в конце списка параметров.
Библиотечные переменные
Ниже приводится тип переменной, определенный в заголовке stdarg.h:
Sr.No. | Переменная и описание |
---|---|
1 | va_list Этот тип подходит для хранения информации, необходимой для трех макросов. va_start(), va_arg() и va_end(). |
Макросы библиотеки
Ниже приведены макросы, определенные в заголовке stdarg.h:
Sr.No. | Макрос и описание |
---|---|
1 | void va_start (va_list ap, last_arg) Этот макрос инициализирует ap переменная, которая будет использоваться с va_arg и va_endмакросы. Вlast_arg это последний известный фиксированный аргумент, передаваемый функции, то есть аргумент перед многоточием. |
2 | введите va_arg (va_list ap, тип) Этот макрос извлекает следующий аргумент в списке параметров функции с типом type. |
3 | void va_end (va_list ap) Этот макрос позволяет использовать функцию с переменными аргументами, которая использует va_startмакрос для возврата. Еслиva_end не вызывается перед возвратом из функции, результат не определен. |
В stddef.hзаголовок определяет различные типы переменных и макросы. Многие из этих определений также появляются в других заголовках.
Библиотечные переменные
Ниже приведены типы переменных, определенные в заголовке stddef.h:
Sr.No. | Переменная и описание |
---|---|
1 | ptrdiff_t Это целочисленный тип со знаком, являющийся результатом вычитания двух указателей. |
2 | size_t Это беззнаковый целочисленный тип, являющийся результатом sizeof ключевое слово. |
3 | wchar_t Это интегральный тип размера константы широких символов. |
Макросы библиотеки
Ниже приведены макросы, определенные в заголовке stddef.h:
Sr.No. | Макрос и описание |
---|---|
1 | НОЛЬ Этот макрос является значением константы нулевого указателя. |
2 | offsetof (тип, член-указатель) В результате получается постоянное целое число типа size_t, которое представляет собой смещение в байтах элемента структуры от начала структуры. Член задается указателем члена , а имя структуры задается типом . |
В stdio.h header определяет три типа переменных, несколько макросов и различные функции для выполнения ввода и вывода.
Библиотечные переменные
Ниже приведены типы переменных, определенные в заголовке stdio.h:
Sr.No. | Переменная и описание |
---|---|
1 | size_t Это беззнаковый целочисленный тип, являющийся результатом sizeof ключевое слово. |
2 | FILE Это тип объекта, подходящий для хранения информации о файловом потоке. |
3 | fpos_t Это тип объекта, подходящий для хранения любой позиции в файле. |
Макросы библиотеки
Ниже приведены макросы, определенные в заголовке stdio.h:
Sr.No. | Макрос и описание |
---|---|
1 | NULL Этот макрос является значением константы нулевого указателя. |
2 | _IOFBF, _IOLBF и _IONBF Это макросы, которые расширяются до интегральных постоянных выражений с разными значениями и подходят для использования в качестве третьего аргумента функции setvbuf функция. |
3 | BUFSIZ Этот макрос представляет собой целое число, которое представляет размер буфера, используемого setbuf функция. |
4 | EOF Этот макрос представляет собой отрицательное целое число, которое указывает на то, что достигнут конец файла. |
5 | FOPEN_MAX Этот макрос представляет собой целое число, которое представляет максимальное количество файлов, которое система может гарантировать для одновременного открытия. |
6 | FILENAME_MAX Этот макрос представляет собой целое число, которое представляет наибольшую длину массива символов, подходящего для хранения максимально длинного имени файла. Если реализация не устанавливает ограничений, тогда это значение должно быть рекомендованным максимальным значением. |
7 | L_tmpnam Этот макрос представляет собой целое число, которое представляет наибольшую длину массива символов, подходящего для хранения максимально возможного временного имени файла, созданного tmpnam функция. |
8 | SEEK_CUR, SEEK_END, и SEEK_SET Эти макросы используются в fseek функция для поиска различных позиций в файле. |
9 | TMP_MAX Этот макрос - максимальное количество уникальных имен файлов, которые функция tmpnam может генерировать. |
10 | stderr, stdin, и stdout Эти макросы являются указателями на типы ФАЙЛОВ, которые соответствуют стандартным потокам ошибок, стандартному вводу и стандартным потокам вывода. |
Библиотечные функции
Ниже приведены функции, определенные в заголовке stdio.h:
Следуйте той же последовательности функций для лучшего понимания и использования Try it(Онлайн-компилятор), потому что файл, созданный в первой функции, будет использоваться в последующих функциях.
Sr.No. | Описание функции |
---|---|
1 | int fclose (ФАЙЛ * поток) Закрывает поток. Все буферы очищаются. |
2 | void clearerr (ФАЙЛ * поток) Очищает индикаторы конца файла и ошибки для данного потока. |
3 | int feof (ФАЙЛ * поток) Проверяет индикатор конца файла для данного потока. |
4 | int ferror (ФАЙЛ * поток) Проверяет индикатор ошибки для данного потока. |
5 | int fflush (ФАЙЛ * поток) Очищает выходной буфер потока. |
6 | int fgetpos (ФАЙЛ * поток, fpos_t * pos) Получает текущую позицию в файле потока и записывает ее в pos. |
7 | ФАЙЛ * fopen (const char * filename, const char * mode) Открывает имя файла, на которое указывает имя файла, в заданном режиме. |
8 | size_t fread (void * ptr, size_t size, size_t nmemb, FILE * stream) Считывает данные из заданного потока в массив, на который указывает ptr. |
9 | ФАЙЛ * freopen (const char * filename, const char * mode, FILE * stream) Связывает новое имя файла с данным открытым потоком и одновременно закрывает старый файл в потоке. |
10 | int fseek (ФАЙЛ * поток, длинное смещение int, откуда int) Устанавливает позицию файла потока на заданное смещение. Смещение аргумента обозначает количество байтов для поиска из заданной позиции откуда . |
11 | int fsetpos (ФАЙЛ * поток, const fpos_t * pos) Устанавливает позицию файла данного потока в данную позицию. Аргумент pos - это позиция, заданная функцией fgetpos. |
12 | long int ftell (FILE * поток) Возвращает текущую позицию в файле данного потока. |
13 | size_t fwrite (const void * ptr, size_t size, size_t nmemb, FILE * stream) Записывает данные из массива, на который указывает ptr, в заданный поток. |
14 | int remove (const char * имя файла) Удаляет указанное имя файла, чтобы оно больше не было доступно. |
15 | int переименование (const char * old_filename, const char * new_filename) Заставляет имя файла, на которое ссылается old_filename, быть изменено на new_filename. |
16 | пустая перемотка (ФАЙЛ * поток) Устанавливает позицию файла в начало файла данного потока. |
17 | void setbuf (ФАЙЛ * поток, символ * буфер) Определяет, как поток должен быть буферизован. |
18 | int setvbuf (ФАЙЛ * поток, символ * буфер, режим int, размер size_t) Еще одна функция, определяющая, как поток должен буферизоваться. |
19 | ФАЙЛ * tmpfile (недействительно) Создает временный файл в режиме двоичного обновления (wb +). |
20 | char * tmpnam (char * str) Создает и возвращает действительное временное имя файла, которого не существует. |
21 год | int fprintf (ФАЙЛ * поток, const char * формат, ...) Отправляет форматированный вывод в поток. |
22 | int printf (const char * формат, ...) Отправляет форматированный вывод на стандартный вывод. |
23 | int sprintf (char * str, const char * format, ...) Отправляет форматированный вывод в строку. |
24 | int vfprintf (ФАЙЛ * поток, const char * формат, va_list arg) Отправляет форматированный вывод в поток с использованием списка аргументов. |
25 | int vprintf (const char * формат, va_list arg) Отправляет форматированный вывод в стандартный вывод с использованием списка аргументов. |
26 | int vsprintf (char * str, const char * format, va_list arg) Отправляет форматированный вывод в строку с использованием списка аргументов. |
27 | int fscanf (ФАЙЛ * поток, const char * формат, ...) Читает форматированный ввод из потока. |
28 | int scanf (const char * формат, ...) Читает форматированный ввод со стандартного ввода. |
29 | int sscanf (const char * str, const char * format, ...) Читает форматированный ввод из строки. |
30 | int fgetc (ФАЙЛ * поток) Получает следующий символ (беззнаковый символ) из указанного потока и перемещает индикатор позиции для потока. |
31 год | char * fgets (char * str, int n, FILE * поток) Считывает строку из указанного потока и сохраняет ее в строке, на которую указывает str. Он останавливается при чтении (n-1) символов, при чтении символа новой строки или при достижении конца файла, в зависимости от того, что наступит раньше. |
32 | int fputc (int char, FILE * поток) Записывает символ (беззнаковый char), указанный аргументом char, в указанный поток и перемещает индикатор позиции для потока. |
33 | int fputs (const char * str, FILE * поток) Записывает строку в указанный поток до нулевого символа, но не включая его. |
34 | int getc (ФАЙЛ * поток) Получает следующий символ (беззнаковый символ) из указанного потока и перемещает индикатор позиции для потока. |
35 год | int getchar (недействительно) Получает символ (беззнаковый символ) из стандартного ввода. |
36 | char * получает (char * str) Считывает строку из stdin и сохраняет ее в строке, на которую указывает str. Он останавливается при чтении символа новой строки или при достижении конца файла, в зависимости от того, что наступит раньше. |
37 | int putc (int char, FILE * поток) Записывает символ (беззнаковый char), указанный аргументом char, в указанный поток и перемещает индикатор позиции для потока. |
38 | int putchar (int char) Записывает символ (беззнаковый символ), указанный аргументом char, в стандартный вывод. |
39 | int помещает (const char * str) Записывает строку в стандартный вывод до нулевого символа, но не включая его. К выводу добавляется символ новой строки. |
40 | int ungetc (int char, FILE * поток) Помещает символ char (беззнаковый символ) в указанный поток, чтобы был прочитан следующий символ. |
41 год | пустота perror (const char * str) Печатает описательное сообщение об ошибке в stderr. Сначала печатается строка str, за которой следует двоеточие, а затем пробел. |
В stdlib.h header определяет четыре типа переменных, несколько макросов и различные функции для выполнения общих функций.
Библиотечные переменные
Ниже приведены типы переменных, определенные в заголовке stdlib.h:
Sr.No. | Переменная и описание |
---|---|
1 | size_t Это беззнаковый целочисленный тип, являющийся результатом sizeof ключевое слово. |
2 | wchar_t Это целочисленный тип размером с wide символьная константа. |
3 | div_t Это структура, возвращаемая div функция. |
4 | ldiv_t Это структура, возвращаемая ldiv функция. |
Макросы библиотеки
Ниже приведены макросы, определенные в заголовке stdlib.h:
Sr.No. | Макрос и описание |
---|---|
1 | NULL Этот макрос является значением константы нулевого указателя. |
2 | EXIT_FAILURE Это значение, которое функция выхода должна вернуть в случае сбоя. |
3 | EXIT_SUCCESS Это значение, которое функция выхода должна вернуть в случае успеха. |
4 | RAND_MAX Этот макрос - максимальное значение, возвращаемое функцией rand. |
5 | MB_CUR_MAX Этот макрос представляет собой максимальное количество байтов в многобайтовом наборе символов, которое не может быть больше MB_LEN_MAX. |
Библиотечные функции
Ниже приведены функции, определенные в заголовке stlib.h:
Sr.No. | Описание функции |
---|---|
1 | двойной atof (const char * str) Преобразует строку, на которую указывает аргумент str, в число с плавающей запятой (тип double). |
2 | int atoi (константа char * str) Преобразует строку, на которую указывает аргумент str, в целое число (тип int). |
3 | длинный int atol (const char * str) Преобразует строку, на которую указывает аргумент str, в длинное целое число (тип long int). |
4 | двойной strtod (const char * str, char ** endptr) Преобразует строку, на которую указывает аргумент str, в число с плавающей запятой (тип double). |
5 | длинный int strtol (const char * str, char ** endptr, int base) Преобразует строку, на которую указывает аргумент str, в длинное целое число (тип long int). |
6 | беззнаковое длинное int strtoul (const char * str, char ** endptr, int base) Преобразует строку, на которую указывает аргумент str, в длинное целое число без знака (тип unsigned long int). |
7 | void * calloc (size_t nitems, size_t size) Выделяет запрошенную память и возвращает указатель на нее. |
8 | свободный от пустоты (void * ptr Освобождает память, ранее выделенную вызовом calloc, malloc или realloc . |
9 | пустота * malloc (размер_т размер) Выделяет запрошенную память и возвращает указатель на нее. |
10 | void * realloc (void * ptr, size_t размер) Пытается изменить размер блока памяти, на который указывает ptr, который был ранее выделен вызовом malloc или calloc . |
11 | void abort (недействительно) Вызывает аварийное завершение программы. |
12 | int atexit (пустота (* функция) (пустота)) Вызывает указанную функцию func вызывается при нормальном завершении программы. |
13 | недействительный выход (статус int) Вызывает нормальное завершение программы. |
14 | char * getenv (const char * имя) Ищет строку среды, на которую указывает имя, и возвращает связанное значение в строку. |
15 | система int (const char * строка) Команда, указанная в строке, передается в среду хоста для выполнения командным процессором. |
16 | void * bsearch (const void * key, const void * base, size_t nitems, size_t size, int (* compare) (const void *, const void *)) Выполняет бинарный поиск. |
17 | void qsort (void * base, size_t nitems, size_t size, int (* compare) (const void *, const void *)) Сортирует массив. |
18 | интервал абс (интервал x) Возвращает абсолютное значение x. |
19 | div_t div (целое число, целое число) Делит число (числитель) на номинал (знаменатель). |
20 | длинные int labs (long int x) Возвращает абсолютное значение x. |
21 год | ldiv_t ldiv (длинное целое число, длинное целое число) Делит число (числитель) на номинал (знаменатель). |
22 | int rand (пусто) Возвращает псевдослучайное число в диапазоне от 0 до RAND_MAX . |
23 | void srand (беззнаковое целое семя) Эта функция запускает генератор случайных чисел, используемый функцией rand. |
24 | int mblen (const char * str, size_t n) Возвращает длину многобайтового символа, на который указывает аргумент str . |
25 | size_t mbstowcs (schar_t * pwcs, const char * str, size_t n) Преобразует строку многобайтовых символов, на которую указывает аргумент str, в массив, на который указывает pwcs . |
26 | int mbtowc (whcar_t * pwc, const char * str, size_t n) Проверяет многобайтовый символ, на который указывает аргумент str . |
27 | size_t wcstombs (char * str, const wchar_t * pwcs, size_t n) Преобразует коды, хранящиеся в массиве pwcs, в многобайтовые символы и сохраняет их в строке str . |
28 | int wctomb (char * str, wchar_t wchar) Проверяет код, соответствующий многобайтовому символу, заданному аргументом wchar . |
В string.h header определяет один тип переменной, один макрос и различные функции для управления массивами символов.
Библиотечные переменные
Ниже приводится тип переменной, определенный в строке заголовка. H -
Sr.No. | Переменная и описание |
---|---|
1 | size_t Это беззнаковый целочисленный тип, являющийся результатом sizeof ключевое слово. |
Макросы библиотеки
Ниже приведен макрос, определенный в строке заголовка. H -
Sr.No. | Макрос и описание |
---|---|
1 | NULL Этот макрос является значением константы нулевого указателя. |
Библиотечные функции
Ниже приведены функции, определенные в строке заголовка. H -
Sr.No. | Описание функции |
---|---|
1 | void * memchr (const void * str, int c, size_t n) Ищет первое вхождение символа c (беззнаковый символ) в первых n байтах строки, на которую указывает аргумент str . |
2 | int memcmp (const void * str1, const void * str2, size_t n) Сравнивает первые n байтов str1 и str2 . |
3 | void * memcpy (void * dest, const void * src, size_t n) Копирует n символов из src в dest . |
4 | void * memmove (void * dest, const void * src, size_t n) Еще одна функция для копирования n символов из str2 в str1 . |
5 | void * memset (void * str, int c, size_t n) Копирует символ c (беззнаковый символ) в первые n символов строки, на которую указывает аргумент str . |
6 | char * strcat (char * dest, const char * src) Добавляет строку, на которую указывает src, в конец строки, на которую указывает dest . |
7 | char * strncat (char * dest, const char * src, size_t n) Добавляет строку, на которую указывает src, в конец строки, на которую указывает dest, длиной до n символов. |
8 | char * strchr (константа char * str, int c) Ищет первое вхождение символа c (беззнаковый символ) в строке, на которую указывает аргумент str . |
9 | int strcmp (const char * str1, const char * str2) Сравнивает строку, на которую указывает str1, со строкой, на которую указывает str2 . |
10 | int strncmp (const char * str1, const char * str2, size_t n) Сравнивает не более первых n байтов строк str1 и str2 . |
11 | int strcoll (const char * str1, const char * str2) Сравнивает строку str1 с str2 . Результат зависит от настройки LC_COLLATE местоположения. |
12 | char * strcpy (char * dest, const char * src) Копирует строку, на которую указывает src, в dest . |
13 | char * strncpy (char * dest, const char * src, size_t n) Копирует до n символов из строки, на которую указывает src в dest . |
14 | size_t strcspn (const char * str1, const char * str2) Вычисляет длину начального сегмента str1, который полностью состоит из символов, не входящих в str2. |
15 | char * strerror (int errnum) Ищет во внутреннем массиве номер ошибки errnum и возвращает указатель на строку сообщения об ошибке. |
16 | size_t strlen (const char * str) Вычисляет длину строки str до завершающего нулевого символа, но не включая его. |
17 | char * strpbrk (const char * str1, const char * str2) Находит первый символ в строке str1, который соответствует любому символу, указанному в str2 . |
18 | char * strrchr (константа char * str, int c) Ищет последнее вхождение символа c (беззнаковый символ) в строке, на которую указывает аргумент str . |
19 | size_t strspn (const char * str1, const char * str2) Вычисляет длину начального сегмента str1, который полностью состоит из символов в str2 . |
20 | char * strstr (const char * стог сена, const char * игла) Находит первое вхождение всей строковой иглы (не включая завершающий нулевой символ), которое появляется в строке сена . |
21 год | char * strtok (char * str, const char * delim) Разбивает строку str на серию токенов, разделенных разделителем . |
22 | size_t strxfrm (char * dest, const char * src, size_t n) Преобразует первый n символы строки src в текущую локаль и помещает их в строку dest. |
В time.h Заголовок определяет четыре типа переменных, два макроса и различные функции для управления датой и временем.
Библиотечные переменные
Ниже приведены типы переменных, определенные в заголовке time.h -
Sr.No. | Переменная и описание |
---|---|
1 | size_t Это беззнаковый целочисленный тип, являющийся результатом sizeof ключевое слово. |
2 | clock_t Этот тип подходит для хранения процессорного времени. |
3 | time_t is Этот тип подходит для хранения календарного времени. |
4 | struct tm Это структура, используемая для хранения времени и даты. |
Структура tm имеет следующее определение -
struct tm {
int tm_sec; /* seconds, range 0 to 59 */
int tm_min; /* minutes, range 0 to 59 */
int tm_hour; /* hours, range 0 to 23 */
int tm_mday; /* day of the month, range 1 to 31 */
int tm_mon; /* month, range 0 to 11 */
int tm_year; /* The number of years since 1900 */
int tm_wday; /* day of the week, range 0 to 6 */
int tm_yday; /* day in the year, range 0 to 365 */
int tm_isdst; /* daylight saving time */
};
Макросы библиотеки
Ниже приведены макросы, определенные в заголовке time.h -
Sr.No. | Макрос и описание |
---|---|
1 | NULL Этот макрос является значением константы нулевого указателя. |
2 | CLOCKS_PER_SEC Этот макрос представляет количество тактов процессора в секунду. |
Библиотечные функции
Ниже приведены функции, определенные в заголовке time.h -
Sr.No. | Описание функции |
---|---|
1 | char * asctime (const struct tm * timeptr) Возвращает указатель на строку, которая представляет день и время структуры timeptr. |
2 | clock_t часы (недействительно) Возвращает время процессора, используемое с начала эры, определенной реализацией (обычно с начала программы). |
3 | char * ctime (const time_t * таймер) Возвращает строку, представляющую местное время на основе аргумента timer. |
4 | double difftime (time_t time1, time_t time2) Возвращает разницу в секундах между time1 и time2 (time1-time2). |
5 | struct tm * gmtime (const time_t * таймер) Значение таймера разбивается на структуру tm и выражается в универсальном координированном времени (UTC), также известном как среднее время по Гринвичу (GMT). |
6 | struct tm * localtime (const time_t * таймер) Значение таймера разбивается на структуру tm и выражается в местном часовом поясе. |
7 | time_t mktime (структура tm * timeptr) Преобразует структуру, на которую указывает timeptr, в значение time_t в соответствии с местным часовым поясом. |
8 | size_t strftime (char * str, size_t maxsize, const char * format, const struct tm * timeptr) Форматирует время, представленное в структуре timeptr, в соответствии с правилами форматирования, определенными в format и сохраненными в str. |
9 | time_t время (time_t * таймер) Вычисляет текущее время в календаре и кодирует его в формат time_t. |