【C语言】数据类型(基本类型、构造类型、类型转换)

简介: 不包含小数部分的数据都成为整型数据。在C语言中,根据数值的取值范围,可以将整型分为短整型(short int)、基本整型(int)、长整型(long int)。整型数据可以被修饰符signed和unsigned修饰,其中,被signed修饰的整型称为有符号的整型,被unsigned修饰的整型称为无符号的整型。

⏰打卡:DAY1

🏆今日学习目标:数据类型(基本类型、构造类型、类型转换)

✨个人主页:颜颜yan_的个人主页

🎉专栏系列:从0开始学C语言


前言


最近C语言忘了好多,开始复习ing,记一下近日的笔记~


C语言中的数据类型分为4中,分别是基本类型、构造类型、指针类型、空类型。


5f9072861f924231b3d6523b9214cfd4.png


这里查看一下每种数据类型的大小👇


747ed04720334d3295cbe32d7783d4d7.png


基本类型


整型


不包含小数部分的数据都成为整型数据。在C语言中,根据数值的取值范围,可以将整型分为短整型(short int)、基本整型(int)、长整型(long int)。整型数据可以被修饰符signed和unsigned修饰,其中,被signed修饰的整型称为有符号的整型,被unsigned修饰的整型称为无符号的整型。


字节(Byte)是计算机存储空间的一种单位,它是内存分配空间的一个基础单位,即内存分配空间至少是1个字节。


最小的存储单位——位(bit),是一个二进制数字0或1占一位。


1B=8bit;


int类型在打印时使用%d


浮点型


浮点数分为单精度浮点数(float)和双精度浮点数(double)两种,其中double型变量所表示的浮点数比float型变量更精确。单精度浮点数后面以F或f结尾,双精度浮点数以D或d结尾。


浮点数的后缀可以省略,若省略,则默认为双精度浮点数。


double类型打印时使用%lf,float类型打印时使用%f。


字符型


字符型变量用于存储一个单一字符,在C语言中用char表示,其中每个字符变量都会占用1个字节。在给字符型变量赋值时,需要用一对英文半角格式的单引号(‘’)把字符括起来。

比如,'A’的声明方式:== char ch = ‘A’;==


字符型打印时使用%c。


构造类型


数组


数组是一组具有相同数据类型的变量集合,这些变量称为数组的元素,数组的类型由数组中存储的元素的类型决定。定义数组时要制定数组类型、数组大小。


int arr[5]; //定义一个int类型的数组,大小为5
char str[10]; //定义一个char类型的数组,大小为10
float ff[10]; //定义一个float类型的数组,大小为10


枚举类型


枚举类型用于定义值可以被一一列举的变量。声明方式如下:


enum 枚举名 {标识符1 = 整型常量1,标识符2 = 整型常量2,…}


enum是声明枚举类型的关键字,枚举名表示枚举变量的名称。


注意:枚举值是常量,在程序中不能给其赋值。


共用体


共用体又叫联合体,它可以把不同数据类型的变量整合在一起。使用union关键字进行声明,定义格式如下:


 union 共用体类型名称
 { 
  数据类型 成员名1;
  数据类型 成员名2;
   ...
  数据类型 成员名n;
}
//定义共用体数据类型为data
union data
{
  int i;
  char ch;
}


共用体中的所有成员共用一块内存,在引用共用体变量时,只有一个成员变量是有效的。


结构体


结构体与共用体类似,可以将不同数据类型的变量整合在一起,区别在于,结构体中的所有成员都占有内存,在引用接哦古提变量时,所有成员都有效。结构体使用关键字struct定义。


类型转换


隐式类型转换


隐式类型转换是指系统自动进行的类型转换。


1.不同类型的数据进行运算,系统会自动将低字节数据类型转换为高字节数据类型,即从下往上转换。


2.在赋值类型不同时,即变量的数据类型与所赋值的数据类型不同,系统会将“=”右边的值转换为变量的数据类型再将值赋值给变量。


显式类型转换


显式类型转换是使用强制类型转换运算符,将一个变量或表达式转化成所需的类型。

基本格式为:(类型名)(表达式)


1.浮点数与整型的转换:将浮点数转换成整数时,将舍弃浮点数的小数部分,只保留整数部分。将整型值赋给浮点型变量,数值不变,只将形式改为浮点形式,即小数点后带若干个0。


2.单、双精度浮点型的转换:float类型数据参与运算时需要在尾部加0扩充为double数据类型。double型数据转换为float型时,会造成数据精度丢失,有效位以外的数据将会进行四舍五入。


3.char类型与int类型的转换:将int型数值赋值给char型变量,只保留其最低8位,高位部分舍弃;将char型数值赋值给int型变量时,如果原来char型数据取正值,则转换后仍为正值;如果原来char型数据可正可负,则转换后也仍然保持原值。


4.int类型与long类型的转换:long型数据赋给int型变量时,将低16位值赋给int型变量,而将高16位截断舍弃(这里假定int型占2个字节)。将int型数据赋给long型变量时,其外部值保持不变,而内部形式有所改变。


5.无符号整数之间的转换:将一个unsigned型数据赋给一个长度相同的整型变量时,内部的存储方式不变,但外部值可能改变。将一个非unsigned整型数据赋给一个长度相同的unsigned型变量时,内部存储形式不变,但外部表示时总是无符号的。


总结


以上就是今天的学习内容啦~

如果有兴趣的话可以订阅专栏,持续更新呢~

咱们下期再见~


21171af076ec4133bbbdcc52ae97b4e1.gif

相关文章
|
1月前
|
存储 程序员 编译器
C 语言中的数据类型转换:连接不同数据世界的桥梁
C语言中的数据类型转换是程序设计中不可或缺的一部分,它如同连接不同数据世界的桥梁,使得不同类型的变量之间能够互相传递和转换,确保了程序的灵活性与兼容性。通过强制类型转换或自动类型转换,C语言允许开发者在保证数据完整性的前提下,实现复杂的数据处理逻辑。
|
23小时前
|
C语言
【C语言程序设计——入门】基本数据类型与表达式(头歌实践教学平台习题)【合集】
这份文档详细介绍了编程任务的多个关卡,涵盖C语言的基础知识和应用。主要内容包括: 1. **目录**:列出所有关卡,如`print函数操作`、`转义字符使用`、`数的向上取整`等。 2. **各关卡的任务描述**:明确每关的具体编程任务,例如使用`printf`函数输出特定字符串、实现向上取整功能等。 3. **相关知识**:提供完成任务所需的背景知识,如格式化输出、算术运算符、关系运算符等。 4. **编程要求**:给出具体的代码编写提示。 5. **测试说明**:包含预期输入输出,帮助验证程序正确性。 6. 文档通过逐步引导学习者掌握C语言的基本语法和常用函数,适合初学者练习编程技能。
15 1
|
5月前
|
存储 编译器 C语言
c语言的基本类型
c语言的基本类型
106 1
|
5月前
|
存储 安全 C语言
C语言中的数据类型
C语言中的数据类型
107 1
|
5月前
|
存储 C语言
C语言数据类型、变量和运算符以及printf相关问题
C语言数据类型、变量和运算符以及printf相关问题
|
1月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
53 8
|
3月前
|
存储 C语言
【c语言】数据类型和变量
本文介绍了C语言中的数据类型和变量。数据类型分为内置类型和自定义类型,内置类型包括字符型、整型、浮点型等,每种类型有不同的内存大小和取值范围。变量分为全局变量和局部变量,它们在内存中的存储位置也有所不同,分别位于静态区和栈区。通过示例代码和图解,详细阐述了这些概念及其应用。
60 1
|
3月前
|
Java 编译器 C语言
【一步一步了解Java系列】:探索Java基本类型与C语言的区别
【一步一步了解Java系列】:探索Java基本类型与C语言的区别
67 2
|
3月前
|
C语言
3.4 C语言基本数据类型2
在C语言中,声明一个整型(int)变量时,需先写入'int'关键字,后跟变量名并以分号结尾。若同时声明多个变量,可在'int'后用逗号分隔列出所有变量名。例如,`int erns;` 或 `int hogs, cows, goats;` 都是合法声明。变量声明后需通过赋值语句如 `cows = 112;` 或使用函数如 `scanf()` 来初始化其值。
70 10
|
3月前
|
存储 程序员 C语言
3.1 C语言基本数据类型
在C语言中,整数类型如`int`类型是很有用的,它属于有符号整型,意味着该类型的值必须是整数,并且可以是正整数、负整数或者零。`int`类型的数值范围依据计算机系统有所不同,通常取决于系统的位宽。例如,在早期16位的IBM PC兼容机上,`int`类型使用16位存储,取值范围为-32768至32767;而在当前32位系统中,使用32位存储,拥有更宽泛的取值范围。随着64位处理器的普及,`int`类型能够存储的整数范围将进一步扩大。根据ISO C标准,`int`类型的最小取值范围被规定为-32768到32767。系统通常会利用一个特殊的位来表示整数的正负。
74 10