c语言中的数据类型是指用于声明不同类型的变量或函数的扩展系统。变量的类型决定了它在存储中占据多少空间以及如何解释所存储的位模式。
C中的类型可以分类如下-
序号 | 类型与说明 |
---|---|
1 | 基本类型 它们是算术类型,并且进一步分为:(a)整数类型和(b)浮点类型。 |
2 | 枚举类型 它们还是算术类型,用于定义只能在整个程序中分配某些离散整数值的变量。 |
3 | void类型 类型说明符void指示没有可用值。 |
4 | 派生类型 它们包括(a)指针类型,(b)数组类型,(c)结构类型,(d)联合类型和(e)函数类型。 |
数组类型和结构类型统称为集合类型。函数的类型指定函数的返回值的类型。
整数类型
下表提供了标准整数类型的详细信息及其存储大小和值范围-
Type | Storage size | Value range |
---|---|---|
char | 1 byte | -128 to 127 or 0 to 255 |
unsigned char | 1 byte | 0 to 255 |
signed char | 1 byte | -128 to 127 |
int | 2 or 4 bytes | -32,768 to 32,767 or -2,147,483,648 to 2,147,483,647 |
unsigned int | 2 or 4 bytes | 0 to 65,535 or 0 to 4,294,967,295 |
short | 2 bytes | -32,768 to 32,767 |
unsigned short | 2 bytes | 0 to 65,535 |
long | 8 bytes | -9223372036854775808 to 9223372036854775807 |
unsigned long | 8 bytes | 0 to 18446744073709551615 |
浮点类型
下表提供了标准浮点类型的详细信息以及存储大小和值范围及其精度-
Type | Storage size | Value range | Precision |
---|---|---|---|
float | 4 byte | 1.2E-38 to 3.4E+38 | 6 decimal places |
double | 8 byte | 2.3E-308 to 1.7E+308 | 15 decimal places |
long double | 10 byte | 3.4E-4932 to 1.1E+4932 | 19 decimal places |
void类型
void类型指定没有可用值。它在三种情况下使用-
序号 | 类型与说明 |
---|---|
1 | 函数返回为空 C中有各种函数不返回任何值,或者可以说它们返回void。没有返回值的函数的返回类型为void。例如,void exit(int status); |
2 | 函数参数为void C中有各种函数,它们不接受任何参数。没有参数的函数可以接受空白。例如,int rand(void); |
3 | 无效指针 类型为void *的指针表示对象的地址,但不表示其类型。例如,一个内存分配函数void * malloc(size_t size); 返回指向void的指针,该指针可以转换为任何数据类型。 |