Latest web development tutorials
×

C курс

C Язык учебника C Краткое введение C параметры окружающей среды C Структура программы C Базовый синтаксис C Типы данных C переменная C постоянная C Storage Class C операторы C судья C циркуляция C функция C Обзорное правила C массив C указатель C строка C структура C союз C поле Bit C typedef C Входной и Выходной C грамотность документов C препроцессор C заголовок C Слепки C Обработка ошибок C Рекурсия C Переменный параметр C Управление памятью C Параметры командной строки C Классические 100 случаев

C Стандартная библиотека

C Стандартная библиотека - справочное руководство C Стандартная библиотека - <assert.h> C Стандартная библиотека - <ctype.h> C Стандартная библиотека - <errno.h> C Стандартная библиотека - <float.h> C Стандартная библиотека - <limits.h> C Стандартная библиотека - <locale.h> C Стандартная библиотека - <math.h> C Стандартная библиотека - <setjmp.h> C Стандартная библиотека - <signal.h> C Стандартная библиотека - <stdarg.h> C Стандартная библиотека - <stddef.h> C Стандартная библиотека - <stdio.h> C Стандартная библиотека - <stdlib.h> C Стандартная библиотека - <string.h> C Стандартная библиотека - <time.h>

Типы данных C

На языке C, тип данных относится к широкому диапазону систем для переменной или объявления функции различных типов. Тип переменной определяет переменную дискового пространства, занимаемого, и как интерпретировать сохраненные структуры битов.

C можно разделить на следующие категории:

序号类型与描述
1基本类型:
它们是算术类型,包括两种类型:整数类型和浮点类型。
2枚举类型:
它们也是算术类型,被用来定义在程序中只能赋予其一定的离散整数值的变量。
3void 类型:
类型说明符void表明没有可用的值。
4派生类型:
它们包括:指针类型、数组类型、结构类型、共用体类型和函数类型。

тип массива и структура типа упоминаемых как составных типов. Тип функции относится к типу возвращаемых значений функции. В следующем разделе этой главы мы представим базовый тип, другие типы объясним в спину несколько глав.

Integer тип

В следующей таблице приведены сведения о стандартных целочисленных типов размеров для хранения и диапазонов значений:

类型存储大小值范围
char1 字节-128 到 127 或 0 到 255
unsigned char1 字节0 到 255
signed char1 字节-128 到 127
int2 或 4 字节-32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647
unsigned int2 或 4 字节0 到 65,535 或 0 到 4,294,967,295
short2 字节-32,768 到 32,767
unsigned short2 字节0 到 65,535
long4 字节-2,147,483,648 到 2,147,483,647
unsigned long4 字节0 到 4,294,967,295

Обратите внимание, что размер различных типов систем хранения, связанных с количеством битов, но система общего назначения 64-бит на основе.

Вот разница между 32-битной и 64-битной размера системной памяти (Windows и то же):

Для того , чтобы получить тип переменной или точного размера на конкретной платформе, вы можете использовать операторSIZEOF.ВыражениеSizeOf (тип), чтобы дать объект или тип байтов памяти. Следующий пример демонстрирует Получить Int размер шрифта:

#include <stdio.h>
#include <limits.h>

int main()
{
   printf("int 存储大小 : %lu \n", sizeof(int));
   
   return 0;
}

При компиляции в Linux и выполнить эту программу, она будет производить следующие результаты:

int 存储大小 : 4 

Тип Float

В следующей таблице приведены сведения о стандартной плавающей запятой размер хранения тип, диапазон значений и точность:

类型存储大小值范围精度
float4 字节1.2E-38 到 3.4E+386 位小数
double8 字节2.3E-308 到 1.7E+30815 位小数
long double16 字节3.4E-4932 到 1.1E+493219 位小数

Float.h заголовочный файл определяет макросы могут быть использованы в программе и других соответствующих деталей значений вещественных чисел, представленных в двоичной системе. Следующие примеры будут выводить с плавающей точкой пространство для хранения типа, а также его диапазон значений:

#include <stdio.h>
#include <float.h>

int main()
{
   printf("float 存储最大字节数 : %lu \n", sizeof(float));
   printf("float 最小值: %E\n", FLT_MIN );
   printf("float 最大值: %E\n", FLT_MAX );
   printf("精度值: %d\n", FLT_DIG );
   
   return 0;
}

При компиляции в Linux и выполнить эту программу, она будет производить следующие результаты:

float 存储最大字节数 : 4 
float 最小值: 1.175494E-38
float 最大值: 3.402823E+38
精度值: 6

недействительным тип

недействительным Тип указано значение не доступно. Он обычно используется в следующих трех случаях:

序号类型与描述
1函数返回为空
C 中有各种函数都不返回值,或者您可以说它们返回空。不返回值的函数的返回类型为空。例如void exit (int status);
2函数参数为空
C 中有各种函数不接受任何参数。不带参数的函数可以接受一个 void。例如int rand(void);
3指针指向 void
类型为 void * 的指针代表对象的地址,而不是类型。例如,内存分配函数void *malloc( size_t size );返回指向 void 的指针,可以转换为任何数据类型。

Теперь, если вы до сих пор не может полностью понять тип пустот, не беспокойтесь слишком много, в последующих разделах мы будем подробно останавливаться на этих понятиях.