C语言的数据类型——基本数据类型


前言

C语言的数据类型丰富,程序的编译需要知道数据的类型,下面主要探讨基本的数据类型。
在这里插入图片描述

一、计算机中内存的容量单位与储存形式

1.计算机中内存的容量单位

计算机中的数据是通过二进制的形式储存的。
一个比特位bit是计算机中最小的储存单位,用来存储0或1。
在这里插入图片描述

2.储存形式

计算机存储一个具体数字的编码方式要靠原码、反码和补码的方式来实现

计算机的符号位通过第一位(最左边的数字)来决定,0为正数,1为负数。
下面拿一个八位的二进制序列来举例

2.1原码

对于数字3

0000 0011 //原码

对于数字-3

1000 0011 //原码

由此也能知道在八位的二进制序列中,数字的储存范围是
1111 1111 ——01111 1111
-127——127

2.2反码

正数的反码是原码本身
负数的反码,在原码基础上,符号位不变,其余按位取反。

对于数字3

0000 0011 //原码
0000 0011 //反码

对于数字-3

1000 0011 //原码
1111 1100 //反码

2.3补码

正数的补码是原码本身
负数的反码,在反码基础上+1

对于数字3

0000 0011 //原码
0000 0011 //反码
0000 0011 //补码

对于数字-3

1000 0011 //原码
1111 1100 //反码
1111 1101 //反码

二、基本数据类型

1.整形

对于整形类型的数据来说,分为有符号【signed】和无符号【unsigned】类型(正负类型),在表示有符号类型时,可以省略【signed】。

整形可以分为:

- 基本型int
- 短整型short int
- 长整型long int

1.1基本型int

int的长度是4个字节,即32位。
对于无符号类型unsigned int,取值范围是0~(2^32)-1,即0-4,294,967,295。
对于有符号类型signed int,取值范围是-(2^32)/2-1~ (2^32)/2-1,即-2,147,483,648~2,147,483,647。

1.2短整型 short int

short int的长度是2个字节,即16位。
对于无符号类型unsigned short 【int】(int可省略),取值范围是0~(2^16)-1, 即0~65535。
对于有符号类型signed short【int】(int可省略),取值范围是-(2^16)/2-1~ (2^16)/2-1,即-32,768~-32,767。

1.3长整型 long int

short int的长度是4个字节,即32位。
对于无符号类型unsigned long【int】(int可省略),取值范围是0-4,294,967,295。
对于有符号类型signed long【int】(int可省略),取值范围是-2,147,483,648~2,147,483,647。

2.字符类型

字符类型 char的数据占一个字节。
一般来说,可以将字符类型当作整形来看待,所以字符类型也有符号位之分。
对于【signed】char,取值范围是-128~127。
对于unsigned char,取值范围是0~255。

对于单纯的char 类型而言,是signed还是unsigned类型是取决于编译器的,大部分情况下是signed。

3.浮点类型

浮点类型可以用来存储小数,又分为单精度类型float和双精度类型double。

float占4个字节,数值范围是1.2E-38 到 3.4E+38,精确到小数点后六位。
double占8个字节,数值范围是2.3E-308 到 1.7E+308,精确到小数点后15位。

*不能定义unsigned float和unsigned double类型。

4.布尔类型

布尔类型名为:_Bool或者bool。
是用来 判断真假的,布尔值通常用整数类型表示,0表示假,非零值表示真。
在使用布尔类型时, 需要引用头文件<stdbool.h>。

下面通过简单的例子熟悉布尔类型:

#include <stdio.h>
#include<stdbool.h >

int main() 
{
    bool a = 0;//此处为假
    if (a)
    {
        printf("apple\n");
    }
    _Bool b = 1;//此处为真
    if (b)
    {
        printf("APPLE\n");
    }
    return 0;
}

输出结果如下:

APPLE

三、数据类型的取值范围

下面,我们可以通过sizeof运算符来更加熟悉各种基本数据类型的取值范围。

sizeof是一个能够获取数据类型或者变量 在内存中占有的字节数运算符,其基本语法是:

  • sizeof(数据类型);
  • sizeof(合法的表达式);

注意:

  • 使用 sizeof 运算符时,它返回一个 size_t 类型的值,表示其参数所占用的字节数。size_t 是无符号整数类型,通常是 unsigned int 或 unsigned long,取决于编译器和平台。
  • sizeof 在编译时求值,因此它的结果是一个常量表达式,不会对运行时的实际数据进行求值。
#include <stdio.h>

int main() {
    printf("int              %lu字节\n", sizeof(int));
    printf("short            %lu字节\n", sizeof(short));
    printf("long             %lu字节\n", sizeof(long));
    printf("unsigned int     %lu字节\n", sizeof(unsigned int));
    printf("unsigned short   %lu字节\n", sizeof(unsigned short));
    printf("unsigned long    %lu字节\n", sizeof(unsigned long));
    printf("char             %lu字节\n", sizeof(char));
    printf("unsigned char    %lu字节\n", sizeof(unsigned char));
    printf("float            %lu字节\n", sizeof(float));
    printf("double           %lu字节\n", sizeof(double));
    
    return 0;
}


输出结果如下:

int             4字节
short           2字节
long            4字节
unsigned int    4字节
unsigned short  2字节
unsigned long   4字节
char            1字节
unsigned char   1字节
float           4字节
double          8字节

通过字节数和上述的介绍,我们也可以更加熟悉各种数据类型的取值范围:

数据类型大小 (字节)取值范围
int4-2147483648 ~2147483647
short2-32768 ~ 32767
long4-2147483648 ~2147483647
unsigned int40 ~4294967295
unsignedshort2 0 ~65535
unsignedlong4
char1-128 到 127 (有符号)或 0 ~ 255 (无符号)
unsigned char10~ 255
float4约 ±1.18E-38 ~ ±3.4E+38,精度约 6-7 位有效数字
double8约 ±2.23E-308 ~ ±1.80E+308,精度约 15-16 位有效数字
  • 25
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值