Latest web development tutorials

Typy danych C

W języku C, typ danych odnosi się do szerokiej gamy systemów do zmiennych lub deklaracja funkcji różnych typów. Typ zmiennej określa zmienną miejsca zajmowanego oraz sposobu interpretacji przechowywanych wzorców bitowych.

C można podzielić na następujące kategorie:

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

typu Array i struktura typu określonego jako kruszywo typów. Typ funkcji odnosi się do typu wartości zwracanej przez funkcję. W dalszej części tego rozdziału będziemy wprowadzać podstawowy typ inne typy wyjaśni w plecy kilka rozdziałów.

Typ Integer

Poniższa tabela zawiera szczegółowe informacje na temat standardowych typów całkowitych rozmiarów przechowywania i zakresy wartości:

类型存储大小值范围
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

Należy zauważyć, że wielkości różnych typów układów pamięci związane z liczbą bitów, a 64-bitowy system ogólnego przeznaczenia, na podstawie.

Tutaj są różnice między 32-bitowej i 64-bitowej wielkości pamięci systemowej (Windows takie same):

W celu uzyskania typ zmiennej lub dokładnej wielkości na konkretnej platformie, można użyć operatorasizeof.sizeofwyrażenie(Type),otrzymując obiektu lub typu bajtów pamięci. Poniższy przykład demonstruje Get int rozmiar czcionki:

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

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

Podczas kompilacji Linuksa i wykonać powyższy program, będzie produkować następujące wyniki:

int 存储大小 : 4 

typu float

Poniższa tabela zawiera szczegółowe informacje na temat standardowej zmiennoprzecinkowej rozmiarem pamięci typu, zakres wartości i precyzji:

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

Float.h plik nagłówkowy definiuje makra mogą być używane w programie oraz innymi istotnymi szczegółami wartościach rzeczywistych liczb reprezentowanych w formacie binarnym. Poniższe przykłady wyprowadzać zmiennoprzecinkową schowek typu, jak również jej zakres wartości:

#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;
}

Podczas kompilacji Linuksa i wykonać powyższy program, będzie produkować następujące wyniki:

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

Typ void

Typ void określona wartość nie jest dostępna. Stosuje się ją zazwyczaj w trzech następujących przypadków:

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

Teraz, jeśli nadal nie może w pełni zrozumieć typ void, nie martw się zbytnio, w kolejnych rozdziałach będziemy opracowywać na tych pojęć.