C语言基础--数据类型

简介: 数据类型

1.数据类型的介绍
在C语言中有很多的内置类型,如

char //字符数据类型 short //短整型 int //整形 long //长整型 long long //更长的整形 float //单精度浮点数 double //双精度浮点数

使用这些内置类型就意味着开辟内存的大小和看待内存空间的视角,是C语言中必不可少的。

接下来,我们将它们进行分类

1.整型家族

char unsigned char signed char short unsigned short [int] signed short [int] int unsigned int signed int long unsigned long [int] signed long [int]

其中char也算是整型家族的,因为char在内存中是以ASCII值得形式去存储的,可以看做是一种特殊的整型

2.浮点数家族

float

double

3.构造类型

数组类型 结构体类型 struct 枚举类型 enum 联合类型 union

4.指针类型

int pi; char pc; float pf; void pv;

5.空类型

void 表示无类型

2.整型在内存中的存储方式
计算机是如何储存整型数据的呢? 事实上,在计算机中存储整型的方式存在三种,分别是原码 反码 和 补码 三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”。 对于正数而言,原反补码都是一样的 对于负数而言,三者之间存在相互转化的关系

原码

直接将二进制按照正负数的形式翻译成二进制就可以。

反码

将原码的符号位不变,其他位依次按位取反就可以得到了。

补码

将反码加1即可得到

那么为什么计算机还要再负数上区分出原码反码补码的转化关系呢? 为什么对于整形来说:数据存放内存中其实存放的是补码? 为什么不直接使用原码存储,这样岂不是更加方便?

事实上,只要举一个例子就可以很好地解释上面的问题

int main()
{

int a = 1;
int b = -1;
printf("%d", a + b);
return 0;

}

复制代码
int main()
{

int a = 1;
int b = -1;
a是正数,原码反码补码相同
//00000000000000000000000000000001
//b是负数,原码反码补码需要相互转化
//10000000000000000000000000000001--原码
//11111111111111111111111111111110--反码
//11111111111111111111111111111111--补码



//假设正数负数都使用原码
//00000000000000000000000000000001  --a的原码
//10000000000000000000000000000001  --b的原码
//10000000000000000000000000000010  相加后的结果-->  -2???
// 
//11111111111111111111111111111111  --b的补码
//00000000000000000000000000000001  --a的原码
//00000000000000000000000000000000  --相加后的结果为0

return 0;

}
复制代码
通过上面的正反对比就可以知道为什么在内存中存储的是补码

在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域 统一处理; 同时,加法和减法也可以统一处理(CPU只有加法器)此外,补码与原码相互转换,其运算过程 是相同的,不需要额外的硬件电路。

3.大小端字节序的判断
首先,什么是大小端?

大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地 址中; 小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地 址中。

那么为什么要有大小端之分呢? 简单来说,当我们的数据大于一个字节的时候,就会涉及到多个字节的顺序安排问题,由此有了大小端存储的方式。 可以通过调试时的内存窗口来查看大小端,大小端存储取决于编译器的实现方式。

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