数据类型的应用 C语言

简介: 数据类型的应用 C语言

前言

刚开始学编程的时候总是囫囵吞枣,一个程序能够运行我就当他是完成了,就导致之前看别人的单片机案例程序时一些数据类型的定义觉得莫名其妙,今天看到的一个视频解决了之前这方面的疑惑,顺手记录一下。


一、数字后面 + L

之前写的代码就都是  int a = 100  这样赋值就好了,但当时看到一句初始化赋值操作long a = 10000000L,这里倒不是不加L这句话会有什么问题,这里不会出问题但是放到别的编译环境下可能会有问题,之前我们的变量定义一般只关注前面的变量会不会溢出,但在一些编译器后面的常数也是会溢出的,因为那些编译器会默认用int去临时存放我们后面的常数导致溢出,所以为了程序的可移植性,我们要在常量后面加一个L去表示这个常数要用long类型来临时存储,从而增加程序的可移植性。

二、int类型的范围

当时刚学习编程的时候,在书本上了解到的int类型的范围是-32768~32767,在考试里也是这样,但其实int类型的范围是随着操作系统的位数和编译器改变的,所以一般写c语言项目的时候,我们都应该先了解自己当前的编译环境下的数据类型的范围,不仅是int,除了char之外所有的数据类型都会因为环境不同而发生改变

三、少用float

案例里的浮点数变量基本都是由double定义的,这里的原因和第一个大块比较类似,就是你输入一个浮点数时系统会默认以double作为临时变量来存储,用float来接收会导致精度损失(虽然感觉也没损失什么呢),但就是按照标准写法来,用double接收浮点数而少用float。

四、unsigned char

之前没见过这样的写法,没有符号的字符串?确实是没有符号的字符串,符号这方面往ascll码想就行。有符号的与无符号的差别在哪呢(我们平时见到的大多应该是无符号的)。signed char能表示的数据范围是-128~127,unsigned char能表示的数据范围是0~255。还有就是把一个char类型的变量强制转换为int、long等数据类型时,对于signed char类型的变量,系统会认为最高位为符号位,然后对最高位进行扩展,若最高位为1,则扩展到int时高位都以1填充。对于unsigned char类型的变量,系统会直接进行无符号扩展,扩展的高位都以0填充

这里需要注意的是以后我们写char的时候,最好把前面是否有符号给写上,而不是只写一个char,因为在gcc里char默认为unsigned char,而在vc里char默认为signed char,这就导致你的代码在不同的编译环境里会有不同的效果,所以这里写char的时候就不要偷懒啦。


总结

在刚开始学习编程的时候可以忽略这些细节,以入门为主,但是在这之后碰到了还是要记录下来。上面的四点我感觉都是挺常见的,这方面书写的习惯也需要改正一下。

相关文章
|
30天前
|
存储 算法 C语言
通义灵码在考研C语言和数据结构中的应用实践 1-5
通义灵码在考研C语言和数据结构中的应用实践,体验通义灵码的强大思路。《趣学C语言和数据结构100例》精选了五个经典问题及其解决方案,包括求最大公约数和最小公倍数、统计字符类型、求特殊数列和、计算阶乘和双阶乘、以及求斐波那契数列的前20项和。通过这些实例,帮助读者掌握C语言的基本语法和常用算法,提升编程能力。
60 4
|
28天前
|
存储 C语言
【c语言】数据类型和变量
本文介绍了C语言中的数据类型和变量。数据类型分为内置类型和自定义类型,内置类型包括字符型、整型、浮点型等,每种类型有不同的内存大小和取值范围。变量分为全局变量和局部变量,它们在内存中的存储位置也有所不同,分别位于静态区和栈区。通过示例代码和图解,详细阐述了这些概念及其应用。
36 1
ly~
|
1月前
|
网络协议 算法 关系型数据库
C语言的应用
C 语言因其高效性和对硬件的直接访问能力,在多个领域有广泛应用。在系统软件领域,它被用于开发操作系统(如 Unix 和 Linux 的内核)和嵌入式系统(如汽车电子控制系统)。在游戏开发中,C 语言常用于构建游戏引擎的底层部分(如 Unity 和 Unreal Engine 的核心模块)及性能要求高的独立游戏。此外,C 语言也用于数据库管理系统(如 MySQL 和 PostgreSQL 的核心功能)和网络编程(如 TCP/IP 协议栈和网络服务器的核心模块)。
ly~
33 3
|
1月前
|
Java Unix Linux
1.3 C语言的应用范围
C语言自20世纪80年代以来一直是主流编程语言,适用于小型计算机、个人电脑及大型机。因其高效紧凑且易于修改和移植,广泛用于软件开发。尽管后来C++和JAVA流行起来,但C语言仍然是软件行业核心,并在嵌入式系统、科学编程和操作系统开发如Linux中扮演重要角色。即使到现在,掌握C语言仍是一项重要技能。不是必须得是计算机专家才能使用C语言,学习C语言同时也能学到很多C++的知识。
49 8
|
1月前
|
C语言
3.4 C语言基本数据类型2
在C语言中,声明一个整型(int)变量时,需先写入'int'关键字,后跟变量名并以分号结尾。若同时声明多个变量,可在'int'后用逗号分隔列出所有变量名。例如,`int erns;` 或 `int hogs, cows, goats;` 都是合法声明。变量声明后需通过赋值语句如 `cows = 112;` 或使用函数如 `scanf()` 来初始化其值。
44 10
|
1月前
|
存储 程序员 C语言
3.1 C语言基本数据类型
在C语言中,整数类型如`int`类型是很有用的,它属于有符号整型,意味着该类型的值必须是整数,并且可以是正整数、负整数或者零。`int`类型的数值范围依据计算机系统有所不同,通常取决于系统的位宽。例如,在早期16位的IBM PC兼容机上,`int`类型使用16位存储,取值范围为-32768至32767;而在当前32位系统中,使用32位存储,拥有更宽泛的取值范围。随着64位处理器的普及,`int`类型能够存储的整数范围将进一步扩大。根据ISO C标准,`int`类型的最小取值范围被规定为-32768到32767。系统通常会利用一个特殊的位来表示整数的正负。
34 10
|
1月前
|
C语言
3.1C语言基本数据类型
在C语言中,初始化变量是指为变量设定初始值,通常在声明时直接完成,例如 `int cows=32;`。应注意避免在同一语句中混合初始化与未初始化的变量,如 `int dogs, cats=94;` 这样的写法容易引起误解。此外,整型常量如21、32等在C语言中被视为int类型,但非常大的整数则不然,且带有小数点或指数的数值不属于整型常量。
27 9
|
1月前
|
存储 C语言
初识C语言:常量与变量中寻找数据类型
初识C语言:常量与变量中寻找数据类型
|
2月前
|
存储 C语言
【C语言基础考研向】02 数据类型-常量-变量
本文介绍了编程中的基本概念,包括数据类型分类、常量与变量的定义及使用。首先概述了四大类数据类型:基本类型(整型、浮点、字符型)、构造类型(数组、结构体)、指针类型和空类型。接着阐述了常量与变量的区别及命名规则,并详细说明了整型、浮点型和字符型数据的特点与应用。最后总结了常见的易错点,如字符串与字符常量的区别及浮点数的默认输出格式。
|
1月前
|
存储 编译器 程序员
C语言数据类型详解
C语言数据类型详解