C语言学习(二)——C语言数据类型

目录

1.基本类型

2.枚举类型 (enum)

[3.void 类型](#3.void 类型)

4.查看数据类型的存储大小

5.类型转换


在 C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。

C语言的数据类型系统主要分为‌基本类型、枚举类型、void类型和派生类型‌四大类。‌‌

1.基本类型

‌**字符型‌:**用于存储单个字符,占用1字节。‌‌

‌char‌:可表示字符或小范围整数。

**‌ 整型‌:**用于存储整数,包括有符号和无符号两种形式。

‌int‌:最常见的整型,通常占用4字节。‌‌

‌short‌:短整型,通常占用2字节。‌‌

‌long‌:长整型,大小通常为4或8字节,取决于系统和编译器。‌‌

‌long long‌:超长整型(C99标准),通常占用8字节。

注意,各种类型的存储大小与系统位数有关,但目前通用的以64位系统为主。‌‌

**‌浮点型‌:**用于存储小数或进行科学计算。‌‌

‌float‌:单精度浮点型,通常占用4字节,提供约6-7位有效数字。‌‌

‌double‌:双精度浮点型,通常占用8字节,提供约15-16位有效数字。‌‌

‌long double‌:扩展精度浮点型,精度和大小因编译器和系统而异。

注:各种类型的存储大小与系统位数有关‌‌

**‌布尔型‌:**用于表示逻辑值真(true)或假(false)。C99标准引入了‌_Bool‌类型,通常占用1字节,取值为0或1;使用‌bool‌、‌true‌和‌false‌需包含<stdbool.h>头文件。‌‌

2.枚举类型 (enum)

枚举类型用于定义一组具名的整数常量,增强代码的可读性。

3.void 类型

void类型表示"无类型"。它主要有两种用途:‌‌

  • 用于指定函数不返回任何值。‌‌。
  • 用于声明通用指针(void*),该指针可以指向任何类型的数据,但在使用前需要进行类型转换。

4.查看数据类型的存储大小

使用表达式 sizeof(type) 得到对象或类型的存储字节大小。

cpp 复制代码
#include <stdio.h>

int main()

{

   printf("int 存储大小 : %lu \n", sizeof(int));  //%lu 为 32 位无符号整数

   printf("char存储大小 : %lu \n", sizeof(char));

   printf("short存储大小 : %lu \n", sizeof(short));

   return 0;

}
cpp 复制代码
#include <stdio.h>

#include <float.h>  //头文件 float.h 定义了宏

int main()

{

   printf("float 存储最大字节数 : %lu \n", sizeof(float));

   printf("float 最小值: %E\n", FLT_MIN );  //%E 为以指数形式输出单、双精度实数

   printf("float 最大值: %E\n", FLT_MAX );

   printf("精度值: %d\n", FLT_DIG );

   return 0;

}

5.类型转换

类型转换是将一个数据类型的值转换为另一种数据类型的值。

C 语言中有两种类型转换:

**隐式类型转换:**隐式类型转换是在表达式中自动发生的,无需进行任何明确的指令或函数调用。它通常是将一种较小的类型自动转换为较大的类型,例如,将int类型转换为long类型或float类型转换为double类型。隐式类型转换也可能会导致数据精度丢失或数据截断。

**显式类型转换:**显式类型转换需要使用强制类型转换运算符(type casting operator),它可以将一个数据类型的值强制转换为另一种数据类型的值。强制类型转换可以使程序员在必要时对数据类型进行更精确的控制,但也可能会导致数据丢失或截断。

(1)隐式类型转换:

cpp 复制代码
#include <stdio.h>

int main()

{

   int a=20;

   float b=1.2;

   double c=a+b;

   printf("c的值为%0.5f\n",c);

   printf("c的大小为%lu \n",sizeof(c));

   return 0;

}

(2)显式类型转换实例:

cpp 复制代码
#include <stdio.h>

int main()

{

   float a = 2.14159;

   int b = (int)a; // 显式将double类型转换为int类型

   printf("b的值为%d\n",b);

   return 0;

}
相关推荐
大大杰哥2 分钟前
leetcode hot100(3)子串
c++·算法·leetcode
fish_xk6 分钟前
哈希的了解
算法·哈希算法
水木流年追梦6 分钟前
大模型入门-应用篇1-prompt技术
开发语言·python·算法·prompt
WL_Aurora10 分钟前
【每日一题】位运算
python·算法
多加点辣也没关系10 分钟前
数据结构与算法总章
数据结构·算法
影sir10 分钟前
STL容器——vector类
c++·算法·stl
Brilliantwxx12 分钟前
【C++】stack_queue与deque模版(模拟实现+认识+对比)
开发语言·c++·笔记·算法·list
hnjzsyjyj14 分钟前
洛谷 P1305:新二叉树 ← DFS
数据结构·dfs
爱吃香芋派OvO15 分钟前
ComfyUI 视频创作实战手册:节点搭建 + 性能优化 + 批量生成
人工智能·算法·机器学习
数智工坊17 分钟前
【深度学习RL】A3C:异步强化学习的革命——用CPU打败GPU的深度RL算法
论文阅读·人工智能·深度学习·算法·transformer