初识C语言(2)数据类型

简介: 初识C语言(2)数据类型

第一个C语言程序

我们先把如下代码写入编译器中(我采用的是VS2013,编译器和我不一样也没事)。

#include <stdio.h>
int main()
{
    printf("hello world\n");
    return 0;
}


简单介绍一下,main函数是程序的入口,一个工程中只有一个且必须有一个main函数。因为如果没有mian函数程序就没了入口,无法正常运行。如果有两个main函数,程序就不知道哪个是入口,会出现故障。


#include <stdio.h>是头文件,就是我们需要使用哪个函数时候必须引用的文件。此时我们要使用printf这个函数,而这个函数位于stdio.h这个头文件下。


return 0;表示函数已经结束


printf()(链接中有关于printf的简单使用)中没有打"",或者是打成了中文的“”。注意,我们写程序的时候,输入法一定一定要切换成英文状态!!!


注意,新手易犯错误

1,main写成mian。报错如下,注意,出现报错的时候,从第一个看起,后面的很多报错可能只是因为前面的一两个错误导致。现在我们就只是把main写成mian,就出现两个报错。

2,不打“;”。分号“;”表示一条语句结束

数据类型

计算机最小单位bit

首先我们需要知道计算机的最小单位——bit。我们都知道计算机是二进制的,全部由0和1组合而成。而一个bit表是一个0或者1。而4个bit就表示1个BYTE(字节)。1024BYTE(字节)=1KB; 1024KB=1MB; 1024MB=1GB; 1024GB=1TB; 1024TB=1PB; 1024PB=1EB; 1024EB=1ZB; 1024ZB=1YB。


数据类型大小

现在我们已经知道了bit,字节的概念之后,抛出一下概念。

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


一个char表示一个字节的数据,short占两个字节。int四个,long四个,long long八个,float四个,double四个。


但是我们需要注意,这里的是在32位的系统下才正确。如果是8位或者64位的系统下部分类型所占字节不同。比如8位的系统下int只有两个字节。


这个时候有人就会有疑惑,int,long,float都是四个字节。有什么区别呢?C语言标准是这样规定的:int最少16位(2字节),long不能比int短,short不能比int长。早期的操作系统是16位系统,int用2字节表示,long用4字节表示。而float和int与long不同,float是浮点型数据(就是有小数点的数据,比如3.14,5.46这种),int和long则是整形数据(只能是整数,比如3,5,6这种)。


如何判断不同呢系统下数据类型大小

这个时候我们可以用一个库函数sizeof()了。你在sizeof()中写入数据类型,然后利用printf打印出来即可。如下

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


结果

为什么需要这些数据类型

我们需要知道,我们的所有数据其实是存放在一个特定的区域的。而计算机一开始不知道这个数据需要多大的区域。像一个十进制数字8转换成二进制就算1000,需要一个字节存储。而十进制128转换成二进制就算1000 0000 需要两个字节。如果这个变量从8变成128,这个时候我们就需要预留给计算机足够的内存存放这个变量了。


如果不能理解,打个比方。你是一个老板,工厂里面有一批货需要放在一个100平方米的地方存放。但是因为销售的产品不可能一时间都卖出去,有可能会造成积压,这个时候就需要200平方米的仓库了。可是你建房子也不是说建好就建好的,这个时候,老板就需要考虑,我建这个仓库一开始就需要大约多大的空间呢?空间太小,物品积压,难道都丢了?空间太大,增加成本没必要。所以在仓库建立之初就需要规划好。而这个数据类型可以理解为规划仓库大小。


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