C语言变量和数据类型的使用

简介: C语言变量和数据类型的使用

前言

上一篇文章我们学习了C语言变量和数据类型的基本概念那么今天我们就具体的来看看如何在代码中使用他们吧。

一、将变量输出打印到控制台

1.整形变量的输出

下面我们定义一个变量a,并赋值为5,然后使用printf将其打印输出到控制台。

代码:

#include <stdio.h>
int main(void)
{
  int a = 5;
  printf("a = %d\n", a);
  return 0;
}

实现:

image.png

其他的大家应该都不难理解。

我们主要来理解一下这个%d:

%d是C语言中的格式控制符,用于输出整型变量的值。在printf函数中,可以使用%d来格式化输出一个整型变量的值。

在上面的例子中%d用于格式化输出a的值,%d将会被替换为a的实际值,并输出到标准输出设备上。


这里将%d替换为5,所以最后输出结果就是a = 5了。

printf("a = %d\n", a);

%d可以用于控制输出的格式,例如控制输出的宽度、精度、填充字符等。可以使用%d的一些修饰符来实现这些功能,例如:

%10d:将输出的整数占据10个字符的宽度,不足部分用空格填充;

%-10d:将输出的整数占据10个字符的宽度,不足部分用空格填充,并且左对齐;

#include <stdio.h>
int main(void)
{
  int a = 5;
  printf("a = %d\n", a);//正常输出
  printf("a = %10d\n", a);//不足部分用空格填充
  printf("a = %-10d\n", a);//不足部分用空格填充,并且左对齐
  return 0;
}

根据代码和效果大家应该可以很清楚的知道这几个的具体区别了。

image.png

2.浮点型变量的输出

%f是C语言中的格式控制符,用于输出浮点型变量的值。在printf函数中,可以使用%f来格式化输出一个浮点型变量的值。

1.flaot的输出

代码:

#include <stdio.h>
int main(void)
{
  float a = 3.14;
  printf("a = %f\n", a);
  return 0;
}

实现:

image.png

2.doble的输出

代码:

#include <stdio.h>
int main(void)
{
  double b = 3.14;
  printf("b = %f\n", b);
  return 0;
}

效果:

image.png

3.float和double输出的区别

float和double都是C语言中的浮点型数据类型,但是它们在内存中占据的空间大小不同,float占4个字节,而double占8个字节。因此,double可以表示的数字范围比float更大,并且具有更高的精度。


在输出float和double类型的变量时,可以使用printf函数和相应的格式控制符来控制输出的方式。在printf函数中,%f和%lf分别用于输出float和double类型的变量。


代码:

#include <stdio.h>
int main(void)
{
  float f = 3.14159;
  double d = 3.14159265358979323846;
  printf("f = %f\n", f);
  printf("d = %lf\n", d);
  return 0;
}

效果:

image.png

从效果上来都只保留了小数点后6位但是你仔细观察输出的最后一位就会发现float输出的最后一位是0,而double输出的最后一位是3。

因为这个编译器默认只输出6位小数,所以我们就会得到上述结果了。


使用float类型的变量可以节省内存空间,但是可能会损失一些精度;而使用double类型的变量可以获得更高的精度,但是会占用更多的内存空间。在实际程序中,需要根据具体的需求和性能要求选择合适的数据类型。


4.%f,%10.2f…

%f可以用于控制输出的格式,例如控制输出的宽度、精度、填充字符等。可以使用%f的一些修饰符来实现这些功能,例如:


%10.2f:将输出的浮点数占据10个字符的宽度,保留2位小数,不足部分用空格填充;


%-10.2f:将输出的浮点数占据10个字符的宽度,保留2位小数,不足部分用空格填充,并且左对齐;


%010.2f:将输出的浮点数占据10个字符的宽度,保留2位小数,不足部分用0填充;


%.2f:将输出的浮点数保留2位小数;

等等。

总之,%f是C语言中的格式控制符,用于输出浮点型变量的值,并可以通过一些修饰符来控制输出的格式。在C语言中,格式控制符是非常重要的概念,它可以让程序输出更加灵活、美观。

#include <stdio.h>
int main(void)
{
  float a = 3.14;
  printf("a = %10.2f\n", a);
  printf("a = %.2f\n", a);
  printf("a = %-10.2f\n", a);
  printf("a = %010.2f\n", a);
  return 0;
}

效果:

image.png

二、数据类型的大小

在C语言中,不同的数据类型在内存中占据的空间大小是不同的,可以使用sizeof运算符来获取一个数据类型在内存中占据的字节数。下面是一些常见数据类型的大小:


char类型:1字节


short类型:2字节


int类型:4字节


long类型:4字节或8字节(根据编译器不同而不同)


float类型:4字节


double类型:8字节

这里我们只对short,int,float,double进行测试:


这里使用sizeof来获取数据类型所占空间的大小。

#include <stdio.h>
int main(void)
{
  int a = 10;
  double b = 3.14;
  float c = 3.1;
  short d = 4;
  printf("int size is %d\n", sizeof(int));
  printf("double size is %d\n", sizeof(double));
  printf("float size is %d\n", sizeof(float));
  printf("short size is %d\n", sizeof(short));
  return 0;
}

效果:

image.png

在程序中正确理解数据类型的大小非常重要,可以避免在内存分配、数据传输、类型转换等方面出现问题。由于不同数据类型的大小可能会有所不同,因此在开发程序时需要注意数据类型的选择和使用,以确保程序正确、高效地运行。


总结

在实际编程中大家根据数据类型所占内存大小和数据范围的大小来具体的选择使用哪个数据类型。


相关文章
|
3月前
|
存储 程序员 编译器
C 语言中的数据类型转换:连接不同数据世界的桥梁
C语言中的数据类型转换是程序设计中不可或缺的一部分,它如同连接不同数据世界的桥梁,使得不同类型的变量之间能够互相传递和转换,确保了程序的灵活性与兼容性。通过强制类型转换或自动类型转换,C语言允许开发者在保证数据完整性的前提下,实现复杂的数据处理逻辑。
|
26天前
|
存储 人工智能 程序员
一文彻底搞清楚C语言的数据类型和变量
本文介绍了数据类型(基本、构造、指针、空类型)、变量(使用、命名规则、作用域)和常量(字面、符号、枚举、表达式),帮助初学者理解编程基础概念。坚持学习,定能创造奇迹!
198 1
一文彻底搞清楚C语言的数据类型和变量
|
2月前
|
C语言
【C语言程序设计——入门】基本数据类型与表达式(头歌实践教学平台习题)【合集】
这份文档详细介绍了编程任务的多个关卡,涵盖C语言的基础知识和应用。主要内容包括: 1. **目录**:列出所有关卡,如`print函数操作`、`转义字符使用`、`数的向上取整`等。 2. **各关卡的任务描述**:明确每关的具体编程任务,例如使用`printf`函数输出特定字符串、实现向上取整功能等。 3. **相关知识**:提供完成任务所需的背景知识,如格式化输出、算术运算符、关系运算符等。 4. **编程要求**:给出具体的代码编写提示。 5. **测试说明**:包含预期输入输出,帮助验证程序正确性。 6. 文档通过逐步引导学习者掌握C语言的基本语法和常用函数,适合初学者练习编程技能。
88 1
|
3月前
|
存储 编译器 C语言
【C语言】C语言的变量和声明系统性讲解
在C语言中,声明和定义是两个关键概念,分别用于告知编译器变量或函数的存在(声明)和实际创建及分配内存(定义)。声明可以多次出现,而定义只能有一次。声明通常位于头文件中,定义则在源文件中。通过合理组织头文件和源文件,可以提高代码的模块化和可维护性。示例包括全局变量、局部变量、函数、结构体、联合体、数组、字符串、枚举和指针的声明与定义。
104 12
|
3月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
103 8
|
3月前
|
C语言
【C语言】全局搜索变量却找不到定义?原来是因为宏!
使用条件编译和 `extern` 来管理全局变量的定义和声明是一种有效的技术,但应谨慎使用。在可能的情况下,应该优先考虑使用局部变量、函数参数和返回值、静态变量或者更高级的封装技术(如结构体和类)来减少全局变量的使用。
61 5
|
5月前
|
存储 C语言
【c语言】数据类型和变量
本文介绍了C语言中的数据类型和变量。数据类型分为内置类型和自定义类型,内置类型包括字符型、整型、浮点型等,每种类型有不同的内存大小和取值范围。变量分为全局变量和局部变量,它们在内存中的存储位置也有所不同,分别位于静态区和栈区。通过示例代码和图解,详细阐述了这些概念及其应用。
96 1
|
5月前
|
存储 C语言
C语言指针与指针变量的区别指针
指针是C语言中的重要概念,用于存储内存地址。指针变量是一种特殊的变量,用于存放其他变量的内存地址,通过指针可以间接访问和修改该变量的值。指针与指针变量的主要区别在于:指针是一个泛指的概念,而指针变量是具体的实现形式。
|
5月前
|
存储 C语言
C语言:设置地址为 0x67a9 的整型变量的值为 0xaa66
在C语言中,可以通过指针操作来实现对特定地址的访问和赋值。要将地址为 0x67a9 的整型变量值设为 0xaa66,可以先定义一个指向该地址的指针,并通过该指针对该内存位置进行赋值操作。需要注意的是,直接操作内存地址具有一定风险,必须确保地址合法且可写。代码示例应考虑字节序及内存对齐问题。
|
5月前
|
存储 C语言
初识C语言:常量与变量中寻找数据类型
初识C语言:常量与变量中寻找数据类型