C语言入门系列之2.数据类型、运算符和表达式(二)(上)

简介: C语言常见数据类型如下:

字符数据在内存中的存储形式及使用方法:

每个字符变量被分配一个字节的内存空间,因此只能存放一个字符。

字符值是以ASCII码的形式存放在变量的内存单元之中的,如x的十进制ASCII码是120,y的十进制ASCII码是121。

对字符变量a、b赋予’x’和’y’值:

a ='x';
b = '7';

实际上是在a、b两个单元内存放120和55的二进制值。

向字符变量赋以整数:

#include <stdio.h>
int main()
{
    char a, b;
    a = 120;
    b = 121;
    printf("%c, %c\n", a, b);
    printf("%d, %d\n", a, b);
  return 0; 
}

显示:

x, y
120, 121

本程序中定义a、b为字符型,但在赋值语句中赋以整型值。

从结果可以看到,a、b值的输出形式取决于printf()函数格式串中的格式符,当格式符为"c"时,对应输出的变量值为字符,当格式符为"d"时,对应输出的变量值为整数。


下面的代码的效果是一样的:

#include <stdio.h>
int main()
{
    char a, b;
    a = 'x';
    b = 'y';
    printf("%c, %c\n", a, b);
    printf("%d, %d\n", a, b);
  return 0; 
}

练习--小写字母转变成大写字母:

#include <stdio.h>
int main()
{
    char a, b;
    a = 'a';
    b = 'b';
    a = a - 32;
    b = b - 32;
    printf("%c, %c\n%d, %d\n", a, b, a, b);
  return 0; 
}

打印:

A, B
65, 66

char a = 33int a = 33的比较:

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

打印:

!, !
33, 33

显然,效果是一样的,char是int的一种特殊情况,char占1个字节,int占4个字节,显然char更节省内存。

字符串常量

字符串常量是由一对双引号括起的字符序列。

例如:“CHINA”、“C program”、"$12.5" 等都是合法的字符串常量。

字符串常量和字符常量是不同的量。它们之间主要有以下区别:

  • 字符常量由单引号括起来,字符串常量由双引号括起来。
  • 字符常量只能是单个字符,占八位,字符串常量则可以含一个或多个字符。
  • 可以把一个字符常量赋值给一个字符变量,但不能把一个字符串常量赋值给一个字符变量。
    例如:可以char a = 'a';,但不能char a = "a";
  • 字符常量占一个字节的内存空间,字符串常量占的内存字节数等于字符串中字节数加1,增加的一个字节中存放字符 \0 (ASCII码为0),这是字符串结束的标志。

例如,字符串C program在内存中所占的字节示意如下:

image.png

字符常量’a’和字符串常量"a"虽然都只有一个字符,但在内存中的情况是不同的:

  • 'a’在内存中占一个字节;
  • "a"在内存中占二个字节。

对比如下:

2345_image_file_copy_75.jpg

6.变量赋初值

在程序中常常需要对变量赋初值,以便使用变量。

C语言中有多种方法为变量提供初值,在作变量定义的同时给变量赋以初值的方法称为初始化。

在变量定义中赋初值的一般形式为:

类型说明符 变量1 = 值1, 变量2 = 值2, ……;

例如:

int a=3;
int b, c=5;
float x=3.2, y=3f, z=0.75;
char ch1='K', ch2='P';

7.变量类型转换

变量的数据类型是可以转换的。

转换的方法有两种,一种是自动转换,一种是强制转换。

自动类型转换

自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。

自动转换遵循以下规则:

  • 若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
  • 转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算,来保证损失较低、精度较高。
  • 所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
  • char型和short型参与运算时,必须先转换成int型
  • 在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度大于左边时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。

类型自动转换的规则如下:

2345_image_file_copy_76.jpg

举例如下:

#include <stdio.h>
int main()
{
    float PI = 3.14159;
    int s, r = 5;
    s = r * r * PI;
    printf("s=%d\n", s);
  return 0; 
}

打印:

s=78

程序中,PI为实型,s、r为整型。在执行s = r * r * PI;语句时,r和PI都转换成double型计算,结果也为double型。但由于s为整型,故赋值结果仍为整型,舍去了小数部分。

显然,精度出现损失,可以将s声明为double或float型,计算结果就会更准确,如下:

#include <stdio.h>
int main()
{
    float s, PI = 3.14159;
    int r = 5;
    s = r * r * PI;
    printf("s=%f\n", s);
  return 0; 
}

打印:

s=78.539749

显然,此时结果精确度更高。

强制类型转换

强制类型转换是通过类型转换运算符来实现的。

其一般形式为:

(类型说明符)  (表达式)

其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。

例如:

(float) a      // 把a转换为实型
(int)(x+y)     // 把x+y的结果转换为整型

在使用强制转换时应注意以下问题:

  • 类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
  • 无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型

举例如下:

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

显示:

(int)f=3, f=3.141590

因此,(int)f的值为3(删去了小数)而f的值不变,仍为3.14159。

本例表明,f虽强制转为int型,但只在运算中起作用,是临时的,而f变量本身的类型并不改变。

相关文章
|
8月前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的运算符
本文详细介绍了C语言中的各类运算符,包括算术、关系、逻辑、位运算符、赋值、三目运算符及sizeof,帮助读者深入理解其用法与特性。君志所向,一往无前,希望在成长的路上有你相伴!
622 2
一文彻底搞清楚C语言的运算符
|
8月前
|
存储 人工智能 程序员
一文彻底搞清楚C语言的数据类型和变量
本文介绍了数据类型(基本、构造、指针、空类型)、变量(使用、命名规则、作用域)和常量(字面、符号、枚举、表达式),帮助初学者理解编程基础概念。坚持学习,定能创造奇迹!
1063 1
一文彻底搞清楚C语言的数据类型和变量
|
8月前
|
人工智能 Java 程序员
一文彻底搞定C语言的表达式和语句
本文介绍了C语言中的表达式和语句,涵盖算术、关系等表达式及各类语句的用法,帮助初学者理解核心概念。本文介绍C语言表达式(算术、关系等)和语句(表达式、复合、控制、函数、空语句),助你掌握核心概念。
446 0
一文彻底搞定C语言的表达式和语句
|
10月前
|
存储 NoSQL 编译器
【C语言】指针的神秘探险:从入门到精通的奇幻之旅 !
指针是一个变量,它存储另一个变量的内存地址。换句话说,指针“指向”存储在内存中的某个数据。
313 7
【C语言】指针的神秘探险:从入门到精通的奇幻之旅 !
|
9月前
|
存储 编译器 C语言
【C语言程序设计——入门】C语言入门与基础语法(头歌实践教学平台习题)【合集】
本文档介绍了C语言环境配置和编程任务,主要内容包括: - **C语言环境配置**:详细讲解了在Windows系统上配置C语言开发环境的步骤。 - **第1关:程序改错**:包含任务描述、相关知识(如头文件引用、基本语法规则)、编程要求、测试说明及通关代码。 - **第2关:scanf函数**:涉及`scanf`和`printf`函数的格式与使用方法,提供编程要求、测试说明及通关代码。 文档结构清晰,涵盖从环境搭建到具体编程任务的完整流程,适合初学者学习和实践。
186 4
|
9月前
|
C语言
【C语言程序设计——入门】基本数据类型与表达式(头歌实践教学平台习题)【合集】
这份文档详细介绍了编程任务的多个关卡,涵盖C语言的基础知识和应用。主要内容包括: 1. **目录**:列出所有关卡,如`print函数操作`、`转义字符使用`、`数的向上取整`等。 2. **各关卡的任务描述**:明确每关的具体编程任务,例如使用`printf`函数输出特定字符串、实现向上取整功能等。 3. **相关知识**:提供完成任务所需的背景知识,如格式化输出、算术运算符、关系运算符等。 4. **编程要求**:给出具体的代码编写提示。 5. **测试说明**:包含预期输入输出,帮助验证程序正确性。 6. 文档通过逐步引导学习者掌握C语言的基本语法和常用函数,适合初学者练习编程技能。
232 1
|
10月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
445 8
C语言------运算符与表达式
这篇文章是C语言运算符与表达式的实训教程,通过多个示例程序展示了如何使用算术运算符、关系运算符、逻辑运算符以及条件语句来解决实际问题,并介绍了如何通过函数库简化复杂数学运算。
C语言------运算符与表达式
|
程序员 C语言
【C语言基础考研向】06运算符与表达式
本文介绍了C语言中的运算符分类、算术运算符及表达式、关系运算符与表达式以及运算符优先级等内容。首先概述了13种运算符类型,接着详细说明了算术运算符的优先级与使用规则,以及关系运算符和表达式的真假值表示,并给出了C语言运算符优先级表。最后附有课后习题帮助巩固理解。
309 10
|
C语言
C语言算数运算符和算数表达式详解
C语言算数运算符和算数表达式详解
275 0