当前位置: 首页 > news >正文

C语言中的数据类型

目录

一、数据类型

1.基本类型

2.sizeof运算符

3.signed和unsigned 

二、基本数据类型的取值范围

1.比特位

2.字节

3.符号位

4.补码

 5.基本数据类型的取值范围


一、数据类型

1.基本类型

(1)整数类型

  • short int
  • int
  • long int
  • long long int

(2)浮点数类型

  • float
  • double
  • long double

(3)字符类型

  • char

(4)布尔类型

  • _Bool

(5)枚举类型

  • enum

2.sizeof运算符

sizeof 运算符用于获得数据类型或表达式的长度

如:-sizeof(object);              //sizeof(对象)

       -sizeof(type_name);      //sizeof(类型)

       -sizeof object;               //sizeof 对象

代码举例:

#include <stdio.h>int main()
{int i;char j;float k;i = 123;j = 'C';k = 3.14;printf("size of int is %d\n",sizeof(int));printf("size of i is %d\n",sizeof(i));printf("size of char is %d\n",sizeof(char));printf("size of j is %d\n",sizeof j);printf("size of float is %d\n",sizeof(float));printf("size of k is %d\n",sizeof k);return 0;
} 

代码运行结果:

size of int is 4

size of i is 4

size of char is 1

size of j is 1

size of float is 4

size of k is 4

 分别打印各类型所占字节:

#include <stdio.h>int main()
{printf("int = %d\n",sizeof(int));printf("short int = %d\n",sizeof(short));printf("long int = %d\n",sizeof(long));printf("long long int = %d\n",sizeof(long long));printf("char = %d\n",sizeof(char));printf("_Bool = %d\n",sizeof(_Bool));printf("float = %d\n",sizeof(float));printf("double = %d\n",sizeof(double));printf("long double = %d\n",sizeof(long double));return 0;}

运行结果(设备不同,结果可能也不同):

int = 4

short int = 2

long int = 4

long long int = 8

char = 1

_Bool = 1

float = 4

double = 8

long double = 16

3.signed和unsigned 

        signed:代表有符号的,第一个位代表正负,剩余的代表大小,例如:signed int 大小区间为-128-127。(默认为signed)

        unsigned:代表无符号的,所有的位都为大小,没有负数,例如:unsigned int 大小区间为:0-255。

  • [signed] short [int]
  • unsigned short [int]
  • [signed] int
  • unsigned int
  • [signed] long [int]
  • unsigned long [int]
  • [signed] long long [int]
  • unsigned long long [int]

代码举例:

#include <stdio.h>int main()
{short i;unsigned short j;i = -1;j = -1;printf("%d\n",i);//d为打印带符号的 printf("%u\n",j);//u为打印不带符号的 return 0;
}

运行结果:

-1

65535

 可见,打印 j 时,结果并不是我们期望出现的-1,而是65535,这与数据类型的取值范围有关。

二、基本数据类型的取值范围

1.比特位

CPU能读懂的最小单位是:比特位,bit,b。每个比特位只能存放二进制数,即0和1.

2.字节

内存机构最小寻址单位:字节,Byte,B

注:1Byte = 8 bit

一个字节能存放的最大的数(2^{31}-1)用二进制表示为:

11111111

该数转化为十进制为:2147483647

 打印2^{32}-1,代码如下:

# include <stdio.h>
#include <math.h>int main()
{unsigned int result = pow(2,32) - 1;printf("result = %u\n",result);return 0;
}

运行结果:

4294967295

 注意:若不加“unsigned”,则输出结果为2147483647.这是因为默认情况下int是signed类型的,也就是说左边第一位是符号位,所以必须加“unsigned”来使其变为一个无符号的整型变量,使得32位都用来存放数值。

3.符号位

  • 存放signed类型的存储单元中,左边第一位表示符号位。如果该位为0,表示该整数是一个正数;如果该位为1,表示该整数是一个负数。
  • 一个32位的整型变量,除去左边第一位符号位,剩下表示值的只有31个比特位。

4.补码

  • 正数的补码是该数的二进制形式。
  • 负数的补码需要通过以下几步获得:

(1)先取得该数的绝对值的二进制形式

(2)再将第1步的值按位取反(除符号位)

(3)最后将第2步的值加1

 5.基本数据类型的取值范围

数据类型字节数取值范围
char1-128~127
unsigned char210~255
short2-32768~32767
unsigned short20~65535
int4-2147483648~2147483647
unsigned int40~4294967295
long4-2147483648~2147483647
unsigned long40~4294967295
long long8-9223372036854775808~9223372036854775807
unsigned long long80~18446744073709551615
数据类型字节数取值范围(绝对值)
float41.17549*10^-38~3.40282*10^38
double82.22507*10^-308~1.79769*10^308
long double122.22507*10^-308~1.79769*10^308


 

http://www.lryc.cn/news/67799.html

相关文章:

  • 什么是微服务中的熔断器设计模式?
  • Ubuntu查看系统日志的几种方法
  • 【ubuntu】安装ZIP
  • DiffDock源码解析
  • 1099 Build A Binary Search Tree(超详细注解+38行代码)
  • [刷题]贪心入门
  • 项目集战略一致性
  • Linux学习 Day3
  • 前端开发推荐vscode安装什么插件?
  • 如何打造完整的客户服务体系?
  • 裸奔时代,隐私何处寻?
  • 从期望最大化(EM)到变分自编码器(VAE)
  • 【数学杂记】表达式中的 s.t. 是什么意思
  • flink watermark介绍及watermark的窗口触发机制
  • Spring Cloud: 云原生微服务实践
  • 存bean和取bean
  • 39. 组合总和
  • 100行以内Python能做那些事
  • Android 电源键事件流程分析
  • 游戏搬砖简述-1
  • 多线程基础总结
  • 视频理解AI模型分类与汇总
  • 【Linux】多线程 --- 线程同步与互斥+生产消费模型
  • 17.模型的定义
  • golang 记录交叉编译sqlite的报错信息 go build -ldflags
  • ChatGPT AI使用成本
  • 腾讯云与中电金信发布联合核心方案
  • 老胡的周刊(第090期)
  • 2023-数仓常见问题以及解决方案
  • 没关系,前端还死不了