第三章 数据类型

合集下载

C语言第3章数据类型、运算符与表达式ppt课件

C语言第3章数据类型、运算符与表达式ppt课件
第三章
数据类型、运算符与表达式
1
主要内容
一、C的数据类型 二、常量与变量 三、基本数据类型 四、运算符与表达式
2
一、C的数据类型
(一) 什么是数据类型? (二) C语言的数据类型有哪些?
3
(一) 什么是数据类型?
对数据的描述
对操作的描述
数据结构+算法=程序
C语言中以 “数据类型”形式存在
4
所谓数据类型是按被定义变量的性质,表示形 式,占据存储空间的多少,构造特点来划分的。
int NUM=20; sum=PRICE*NUM;
11
符号常量优点
1、含义清楚。 2、在需要改变一个常量时,能够做到“一
改全改”
12
(二)变量
概念
变量代表内存中具有特定属性的一 个存储单元,它用来存放数据,也 就是变量的值。
13
(1)变量名。每个变量都有一个名字 ──变量名,代表一个地址。 (2)变量值。在程序运行过程中,变 量值存储在内存中。在程序中,通过 变量名来引用变量的值。
#include <stdio.h>
void main() {
int student,age; int if=adrress=1; float score=90;
stadent=2; Age=20; printf("%d %d %d %f",if,student,age,score); }
本程序中有 几处错误?
(5)标识符的有效长度随系统而异,如果超 长,则超长部分被舍弃。VC++6.0中规 定最大长度为247个字符。
23
请选出下列正确的标识符 M.D.John , 12%gf ,1add ,_ce36 ,age& 5thclass, lotus-1-2-3 , cd*ef , float,

3 数据类型、运算符和表达式

3 数据类型、运算符和表达式

三、整型数据
3.1.整型常量 整型常量即整常数按不同的进制区分, 整型常量即整常数按不同的进制区分 , 整型常数 有三种表示方法: 有三种表示方法:
十进制数: 以非0 220, 560, 十进制数: 以非0开始的数 如:220, -560, 45900 八进制数: 06; 0106, 八进制数: 以0开始的数 如:06; 0106, 十六进制数: 十六进制数: 以0X或0x开始的数 如:0X0D, 0XFF, 0x4e
一般情况下,符号常量名用大写、变量用小写。 一般情况下,符号常量名用大写、变量用小写。
3、符号常量的声明和使用 一般放在程序的前端, <…>在一块: 一般放在程序的前端,与#include < >在一块: #define 符号常量名 值 如:#define Zero 0 好处: 好处: 含义清楚 (#define Second 60) (#define (#define 一改全改 (#define PI 3.14)
3. 整型变量的溢出
main(){ i,j; int i,j; unsigned k,l,m; k,l,m; i=32767 32767; i=32767; j=i+1 j=i+1; l=65535 65535u l=65535u; m=l+2 m=l+2; printf("j=%d\n",j); printf("j=% n",j); printf("l=% n",l); printf("l=%u\n",l); printf("m=% n",m); printf("m=%u\n",m); }
3.2、整型变量 整型变量的分类:加上不同的修饰符 1 . 整型变量的分类 : 加上不同的修饰 符 , 整型变 量有以下几种类型; 量有以下几种类型; C 语言标准没有规定整型变量在计算机内存中所 占的字节数,它与具体的机器和操作系统有关: 占的字节数,它与具体的机器和操作系统有关:

第3章 数据类型 yw

第3章 数据类型 yw
68表38数字和字符之间的转换函数num2str将数字转变成为字符串int2str将整数转变成为字符串mat2str将矩阵转变成为可被eval函数使用的字符串str2double将字符串转变为双精度类型的数据str2num将字符串转变为数字sprintf格式化输出数据到命令行窗口sscanf读取格式化字符串69表39不同数值之间的转换函数hex2num将十六进制整数字符串转变成为双精度数据hex2dec将十六进制整数字符串转变成为十进制整数dec2hex将十进制整数转变成为十六进制整数字符串bin2dec将二进制整数字符串转变成为十进制整数dec2bin将十进制整数转变成为二进制整数字符串base2dec将指定数制类型的数字字符串转变成为十进制整数dec2base将十进制整数转变成为指定数制类型的数字字符串70例子322num2str函数和str2num函数的用法示例
一个正数的补码就是其原码,例如整数7在八位
计算机中的补码是0000 0111。 对于负数的补码是将数字的反码加上1,就得到 了这个数字的补码。例如-7在8位计算机中的补码是 1111 1001。
关于数字在计算机中二进制表示的详细解释请参
阅相应的计算机原理方面的书籍。
14
例子3-3(a) 数据位“与”操作。
计的一种数组。利用空数组可以修改数组的大小,但是不能 修改数组的维数。 下面通过具体的例子来说明空数组创建和使用的过程。 例子3-6 创建空数组。
和创建普通的数组(矩阵)一样,创建空数组也有不同的
方法,在MATLAB命令行窗口中键入下面的命令:
22
>> A = [] A= [] >> B = ones(2,3,0) B= Empty array: 2-by-3-by-0 >> C = randn(2,3,4,0) C= Empty array: 2-by-3-by-4-by-0 >> whos Name Size Bytes Class A 0x0 0 double array B 2x3x0 0 double array C 4-D 0 double array Grand total is 0 elements using 0 bytes

第三章 数据类型、常量、变量及表达式

第三章  数据类型、常量、变量及表达式
11
例如,要将文本框 的前景颜色设置为红色, 例如,要将文本框Text1的前景颜色设置为红色,可以 的前景颜色设置为红色 使用下面的语句: 使用下面的语句: Text1.ForeColor=vbRed 这里的vbRed就是系统常量。这比直接使用16进制数来 就是系统常量。这比直接使用 进制数来 这里的 就是系统常量 设置要直观得多。 设置要直观得多。 又如,窗口状态属性 可取0,1,2三个值,对应 三个值, 又如,窗口状态属性WindowsState可取 可取 三个值 三种不同状态。 三种不同状态。 在程序中使用语句 Myform.WindowsState=vbMaxmized, , 将窗口极大化,显然要比使用语句 将窗口极大化,显然要比使用语句Myform.WindowsState=2 易于阅读和理解。 易于阅读和理解。
9
5、日期常量 、
日期( 字节的浮点数来存储, 日期 ( Date) 型数据按 字节的浮点数来存储 , 表示日 ) 型数据按8字节的浮点数来存储 期范围从公元100年1月1日~9999年12月31日,而时间范围从 年 月 日 期范围从公元 年 月 日 0:00:00~23:59:59。 。 一种在字面上可被认作日期和时间的字符, 一种在字面上可被认作日期和时间的字符,只要用号码符 括起来, “#”括起来,都可以作为日期型数值常量。 括起来 都可以作为日期型数值常量。 例:#09/02/99#、#January 4,1989#,#2002-5-4 14:30:00 、 , PM#都是合法的日期型常量。 都是合法的日期型常量。 都是合法的日期型常量 说明:当以数值表示日期数据时,整数部分代表日期, 说明:当以数值表示日期数据时,整数部分代表日期, 而小数部分代表时间;例如 表示 表示1899年12月31日。大于 的 而小数部分代表时间;例如1表示 年 月 日 大于1的 整数表示该日期以后的日期, 和小于 和小于0的整数表示该日期以 整数表示该日期以后的日期,0和小于 的整数表示该日期以 前的日期。 前的日期。

C语言第3章数据类型

C语言第3章数据类型

序 设 计
C
6
§3.1 C语言的基本元素和数据类型
字符型 char 程序=算法+数据结构 基本类型 整型 int 单精度 float 实型(浮点型) 算法处理的对象是数据 双精度 double 数据结构是数据的组织形式 数组型 array 数据类型是指数据的内在表现形式 数据类型 结构体型 (含位段)struct (代码,存储,运算)。 构造类型 共用体型 union 枚举型 enum 自定义型 typedef 指针类型 (pointer) 空类型 void
内容提要:
C语言的基本元素和数据类型 常量与变量
各种数据类型的常量和变量
变量赋初值 各种类型的数据间的混合运算 几种基本运算符及其表达式
3
程 序 设 计
C
§3.1 C语言的基本元素和数据类型
一、符号集(字符集) C语言经常使用的基本符号共有以下五种: (1)大写字母:A~Z (2)小写字母:a~z (3)阿拉伯数字:0~9 (4)下划线:_ (5)标点符号和运算符
程 序 设 计
C
19
§3.4 实型数据
三、实型数据的舍入误差
虽然实型数据的表示形式有两种但在内存中均是以指 数形式存放 数 阶 若数据超过有效位,则被 小数 指数 符 符 舍去,故可能产生误差。 例3-4 #include <stdio.h> Void main( ) { float a, b; a=123456.789e5; b=a+20; printf(“a=%f, b=%f\n”, a,b); } a=12345678848.000000, b=12345678848.000000
C语言程序设计
C Programming Language

c语言第3章 数据类型及表达式

c语言第3章 数据类型及表达式

•除 当除号两边都是整型量时,叫做整除 整除, 当除号两边都是整型量时,叫做整除,运算结果只保 留整数部分。 留整数部分。 当除号任何一边有实型量时,运算结果是实数。 当除号任何一边有实型量时,运算结果是实数。 #include <stdio.h> main() main() { float div; div=1/2; printf( %f %f\ ,div); printf(“%f\n”,div); }
–规则: 规则: 规则
–见名知意 见名知意 –不宜混淆 不宜混淆
请指出下列标识符的正误: 请指出下列标识符的正误: main、count、!count、new、5abc、if、do、L_5、who、a123、 main、count、!count、new、5abc、if、do、L_5、who、a123、 _A、_123、c#、 _A、_123、c#、r-3、printf
h e l l o , w o r l d \0 • 注意: 注意: 字符常量和字符串常量是两个不同的概念 字符常量和字符串常量是两个不同的概念
char ch; ch=‘A ; ch= A’; char ch; ch=“A ;// ;//错误 ch= A”;//错误
A
\0
\0
3.7 字符型数据
3.7.3 字符型变量
3.3 常量
常量 • 定义:程序运行时值不能改变的量,即常数。 定义:程序运行时值不能改变的量,即常数。 • 分类: 分类: 符号常量: 符号常量:用标识符表示具体值 • 定义格式: 定义格式: • 一般用大写字母 直接常量: 直接常量:直接写出具体值 • 整型常量 • 实型常量 • 字符常量 • 字符串常量 常量值 #define 标识符 常量值

03数据类型和表达式

03数据类型和表达式

GDI+ Windows的应用程
序的丰富用户
数据库
的各种对象
26
3.2.3 不同数据类型的转换
隐式转换: 运算结果的数据类型向精度高的数据类型靠 Integer<Long<Single<Double<Currency
优先级
算术运算符>=字符运算符>关系运算符>逻辑运算
显式转换: Ctype(表达式,转换到类型名) 例如:Ctype(123,string)
程序设计与实践 VISUAL
上海理工大学 信息基础教研室
第三章 语言基础
1 2 3 4 5
变量、常量与数据类型 运算符和表达式 常用函数 程序结构和编码规则 综合应用
2
3.1 数据类型、变量和常量
整数 数值型 浮点数 货币型 字节型 字符型 逻辑型 日期型 对象型 短整型 长整型 整型 单精度型 双精度型
18
1. 算术运算符

5+10 mod 10 \ 9 / 3意
对算术运算符两边的操作数应是数 值型,若是数字字符或逻辑型,则自 动转换成数值类型后再运算。

30-True 结果是31,逻辑量True转为数值-1, False转为数值0 False + 10 + “4” 结果是: 14
注 意
字符和字符串都必须是用西文的双引号引起 ""表示空字符串,而" "表示有一个空格的字符; 若 字 符 串 中 有 双 引 号 , 例 如 , 要 表 示 字 符 串 : 123"abc , 则 用 连 续 两 个 双 引 号 表 示 , 即 : "123""abc"。

第三章 数据类型运算符与表达式

第三章 数据类型运算符与表达式

三、变量
3、变量值的存储 变量被定义以后,系统在运行时会为该变量分配一个相 应大小的存储空间,称为存储单元。 给变量赋值后,该变量对应的存储单元中会存放该值, 这个值称为变量的值。 那么变量的值在变量的存储单元中是如何表示的呢? (1)整数是以补码的形式存放的。 (正数的补码是其本身,负数的补码为原码按位取反加1) 如:int a=2, b; b= -2; a 00000000 00000010 b 11111111 11111110
(一)算术运算符和算术表达式
表达式的值: 表达式运算得到的最终结果为表达式的值。 也就是整个式子代表的值 如a=5,b=2; a+b 7
(二)赋值运算符和赋值表达式
赋值运算符:= 格式:变量=表达式 如:int a,b; 下面都是正确的赋值表达式 a=5; b=3; a=2+3; a=a+2; b=a*a; 赋值运算为“从右向左”结合的。 如x=y=z=3 它等价于:x=(y=(z=3))
第三章 数据类型运算符与表达式
信息管理系
3.0、C语言中标识符的概念
• 在程序中,由程序设计者使用的名字成为标 识符。标识符用以标志区分不同的东西。它 可以用作函数的名字、变量、常量的名字, 以及文件的名字等等。
一、C语言中的标识符分类
• 用户标识符 • 关键字(语句标识及类型标识)(P375附录II) 例如:real,main,char,int,float,double, long,if,for,switch,default,break等。 • 预定义标识符(函数名字等) 例如:define,include,printf,scanf,sin等。
2的原码表示:00000000 00000010 -2的补码表示:11111111 11111101+1=11111111 11111110

第三章 数据类型、运算符及表达式§31 字符及标识符

第三章 数据类型、运算符及表达式§31 字符及标识符

2关系运算符
比较两个操作数的大小的运算符,称为关系运算符。 关系运算的表达式,称为关系表达式。 例如, 3+5 > 7-4 关系表达式也有它的值。 如: 8 > 3, 该关系成立,因此关系表达式的值为真, 反之, 其值为假。 在C语言中,用数值1表示真,用数0表示假。 如,7 == 2,关系表达式为假,其值为0。 关系运算符的种类和表达式如下:

*C 语言提供的长整数的表示方法可以用来扩大整数的取值 范围. – 例如, 41l, 037l, 0x1fL 字母后面的l 或 L ,表示该数是长常数., 上面三个数,分别是十进制、八进制、十六进制长整数。 一个在整数中放不下的普通整数也被作为长整数,
因此, 把其后紧跟有 l 或 L 的整数叫显式长整数. • 在16位字长的机器上,长整数的位数是 32 位 ( 增长一倍 )。 故长十进制整数取值范围为 -2147483648 到 2147483647。 (2)整型变量: • 基本整型 int 如: int x; • 长整型 long 如: long int y; 或 long y ; • 无符号 unsugend 如: unsigend int z; 或 unsigend z。
• 关键字
具有固定意义的标识符,用户不能用作为自己的标识符, 它们共有32个,除符号常量外都用小写字母表示,就其用途 分五类。 (1) 数据类型 int char float double short ... (2) 存储类型 extern static register auto typedef (3) 控制语句 if else for while do .... (4) 运算符 sizeof (5) 符号常量 EOF BOF .... *它们的含义后面将会络续提到。 * 用户定义的标识符,不能和关键字同名。

计算机科学导论:第三章-数据存储

计算机科学导论:第三章-数据存储

三数据存储3.1 数据类型如今,数据以不同的形式出现,如: 数字、文本、音频、图像和视频.人们需要能够处理许多不同的数据类型:•工程程序使用计算机的主要是目的是处理数字:进行算术运算、求解代数或三角方程、找出微分方程的根等。

•文字处理程序使用计算机的主要目的是处理文本: 调整对齐、移动、删除等。

•计算机同样也处理音频数据。

我们可以使用计算机播放音乐,并且可以把声音作为数据输入到计算机中。

•图像处理程序使用计算机的主要目的是处理图像:创建、收缩、放大、旋转等。

•最后,计算机不仅能用来播放电影,还能创建我们在电影中所看到的特技效果。

计算机行业中使用术语多媒体来定义包含数字、文本、图像、音频和视频的信息。

计算机内部的数据格式•位(bit): 是存储在计算中的最小单位,0或1,代表设备的某一种状态•位模式(位流): 表示数据的不同类型,长度为8的位模式称为一个字节(byte)属于不同数据类型的数据可以以同样的位模式存储于内存中•字: 通常用于代表更长的位模式3.2 存储数字整数是完整的数字(即没有小数部分)。

整数可以被当作小数点位置固定的数字: 小数点固定在最右边。

因此,定点表示法用于存储整数,在这种表示法中,小数点是假定的,但并不存储。

整数通常使用定点表示法存储在内存中。

3.2.1 无符号整数无符号整数是指非负整数。

它的范围在$[0,+\infy)$。

计算机通常会定义一个2n−1表示最大的整数;其中n表示用于存储整数的二进制位数。

无符号整数的存储过程1.输入无符号整数2.将输入的无符号整数转为二进制表示,•如果二进制位数不足n,则在其最左端用0补齐•如果二进制位数超过n,则其不能存储在计算机中,出现溢出现象。

无符号整数存储溢出现象因为大小(即存储单元的位的数量)的限制,可以表达的整数范围是有限的。

在n位储单元中,我们可以存储的无符号整数仅为0到2n−1之间。

如果发生溢出现象则计算机丢掉最左边的位,并保留最右边无符号整数的应用无符号整数表示法可以提高存储的效率,因为不必存储整数的符号。

第3章 数据类型——指针习题(有答案)

第3章 数据类型——指针习题(有答案)
22.int (*pfa)(int,char*)=fa;
23.char *(*pfb)(const char *)=fb;
24.B
25.B
int(*pf1)(int);
pf1=f1;//或合并为:int(*pf1)(int)=f1;
char *(*pf2)(int,char *);
pf2=f2;//或合并为:char *(*pf2)(int,char*)=f2;
(2)函数指针的应用:
#include<iostream.h>
intadd(inta,intb){returna+b;}
20.已知变量a,b定义为:inta=99,&b=a;则cout<<a-1<<’,’<<b+1;的输出是()。
21.已知变量x,y定义为:intx[]={99,98,97},&y=x[1];则cout<<y-1<<’,’<<y*2;的输出是()。
22.已知函数fa的原形是:intfa(int,char*);,pfa是指向fa的指针,则pfa的定义是()
D.*(*(X+I)+j)
16.(单选)要使指针变量p指向2维数组A的第一个元素(0行0列元素),正确的赋值表达式是()。
A.p=A或p=A[0][0]
B.p=A[0]或p=A[0][0]
C.p=A[0]或p=&A[0][0]
D.p=A或p=&A[0][0]
17.下列程序功能是:将字符串中的小写字母都改成对应的大写字母,其他字母不变。请更改程序中的错误。
23.已知函数fb的原形是:char *fb(const char *);,pfb是指向fb的指针,则pfb的定义是()。

C语言教程第3章 数据类型、运算符与表达式

C语言教程第3章  数据类型、运算符与表达式
#include <stdio.h> void main( ) { int a,b,c,d; /*指定a、b、c、d为整型变量*/ unsigned u; /*指定u为无符号整型变量*/ a=12;b=-24;u=10; c=a+u;d=b+u; printf("a+u=%d,b+u=%d\n",c,d); } 运行结果为 a+u=22,b+u=-14
注意以下几点:
(4) 一个整常量后面加一个字母u,认为 是unsigned int型,如12345u,在内存 中按unsigned int规定的方式存放(存储 单元中最高位不作为符号位,而用来存 储数据,见图2.4(b)。如果写成-12345u, 则先将-12345转换成其补码53191,然 后按无符号数存储。
int a; unsigned int b;
一个整数(以13为例)在存储单元中 的存储情况
3. 整型变量的定义
int a,b; (指定变量a、b为整型) unsigned short c,d; (指定变量c、d为无符号短整型) long e,f; (指定变量e、f为长整型)
例3.2整型变量的定义与使用。
字符型变量用来存放字符常量,请注 意只能放一个字符,不要以为在一个字符 变量中可以放一个字符串(包括若干字符)。 字符变量的定义形式如下: char c1,c2;
c1='a';c2='b';
3.5.3 字符数据在内存中的存储 形式及其使用方法
字符的相应的ASCII代码放到存储单元中
例3.6向字符变量赋予整数。
单精度 ( float 型 占4B) 双精度 ( double 型 占8B )

C语言课件_第三章_数据类型

C语言课件_第三章_数据类型
第三章 数据类型
引言 1、计算机中的数据不单是简单的数字,所有计算机处理的信息,包括文字、 声音、图像等都是以一定的数据形式存储的。数据在内存中保存,存放的情况 由数据类型所决定。
2、数据类型即数据结构,决定了数据在内存中的存储形式。不同类型数据在 内存中所占存储空间的大小不同(同一类型数据在不同字长的计算机中所占存 储空间大小也不同),从而导致不同类型可存放数据的大小范围不同。但不论 何种数据类型,其在内存中都是以补码的形式存在的。 3、C语言提供的数据类型包括基本类型、构造类型、指针类型和空类型等,由 这些数据类型可构造出其它更复杂的数据结构(eg:表、栈、树等)。
C、存储:2个字节(Byte)即16位(bit),补码形式
第三章 数据类型
二、整型数据(描述的数据是整数的一个子集) 2、整型变量(分为基本整型、拓展整型) (1)基本整型 D、运算操作 a、算术运算 +(加法) -(减法) *(乘法) /(除法) %(求余)
运算规则:除了除法外,与数学中相同 eg:1+1=2 1-1=0 1*1=1 5%3=2
注意:由于字符在内存中是以二进制存放的,因此char和int可相互赋值,但必 须在一定范围内(0~255)。 (自学:P50 例3.6 向字符变量赋予整数、P51 例3.7 大小写字母的转换)
eg:char 型与 int 型互相赋值
#include <stdio.h> void main( )
{ int i; char c;
问题:用什么变量来存放字符串?
第三章 数据类型
五、变量与常量的定义 (符号常量和变量必须先定义,后使用) 1、常量(符号常量) 通过宏定义预处理命令来实现。 格式: #define 标识符 常量 例如: #define PRICE 30

C语言第3章数据类型、运算符、表达式

C语言第3章数据类型、运算符、表达式

例如
➢字符常量‘a’占一个字节 ➢字符串常量"a" 占2个字节
‘a’ → “a” →
0110 0001 ……
0110 0001 0000 0000
(97)10
(97)10 (0)10
7.变量赋初值
变量赋初值
C语言允许定义变量时赋予初值。
➢int i = 6;
也可对某个变量赋初值:
➢int a, b, c = 6;
如: 0x16, 0x28
4.整型数据
整型变量
分类:
➢基本型 用“ int ”定义; ➢短整型 用“ short int ”或 “ short ”定义; ➢长整型 用“ long ”或 “ long int ”定义; ➢无符号型 用“ unsigned ”定义,不存放符号;
整型变量定义方式
➢基本整型:int a, b, c; ➢短整型 : short int 或 short a, b, c; ➢长整型: long int 或 long a, b, c; ➢无符号型:unsigned a, b; unsigned short a, b
10+‘a’+1.5–8765.1234 ‘b’
8.各种数值型数据间的混合运算
转换方法(自动转换)
double float

long
unsigned
低 int char, short
图中“ ” 表示必定转换。如'a' +' b',先转换为int,结果为 int。
既使是同一种类型也按" "转换。
对于“++”和“--”的使用要避免二义性
10.赋值运算符和赋值表达式

C3-数据类型

C3-数据类型

3.5.3
字符型数据的存储方式及使用
字符数据在内存中存储的是字符的ASCII码 ─ 一 个无符号整数,其形式与整数的存储形式一样, 所以C语言允许字符型数据与整型数据之间通用。 (1)一个字符型数据,既可以字符形式输出,也 可以整数形式输出。(见50页例3.6) (2)允许对字符数据进行算术运算,此时就是对 它们的ASCII码值进行算术运算。 (见51页例3.7)
3. 长双精度: long double
3.4.3
实型常量的类型
–默认double型 –在实型常量后加字母f或F,认为它是float型
3.5
字符型数据
如 ‘a’ ‘A’ ‘?’ ‘\n’ ‘\101’
定义:用单引号括起来的单个普通字符或转义字符. 如 ‘A’——65 ‘a’——97 字符常量的值:该字符的ASCII码值 ‘0’——48 ‘\n’——10 转义字符:反斜线后面跟一个字符或一个代码值表示
2. 表达式和算术表达式
表达式的概念:用运算符和括号将运算对象(常量、变量和 函数等)连接起来的、符合C语言语法规则的式子,称为表 达式。
算术表达式:表达式中的运算符都是算术运算符。例如,3
+ 6 * 9、
(x + y) / 2 等,则称为算术表达式。
运算符的优先级与结合性:
(1)C语言规定了运算符的优先级和结合性。 所谓结合性是指,当一个操作数两侧的运算符具有相同的优先 级时,该操作数是先与左边的运算符结合,还是先与右边的运算符结 合。 自左至右的结合方向,称为左结合性。反之,称为右结合性。 结合性是C语言的独有概念。除 单目 运算符、 赋值运算符和 条 件运算符是右结合性外,其它运算符都是左结合性。
C H I N A

第三章 数据类型及其运算

第三章 数据类型及其运算

第三章 数据类型及其运算知识点提示1.C 的数据类型(基本类型、构造类型、指针类型、空类型)及其定义方法。

2.C 的运算符种类、运算优选级和结合性。

3.不同类型数据间的转换与运算。

4.C 表达式类型(赋值表达式、算术表达式、关系表达式、逻辑表达式、条件表达式、逗号表达式)和求值规则。

知识点一.C 的数据类型1.数据类型的概念数据类型在高级语言中的实质是为解决数据在程序中的表示(常量)、内存单元的分配(变量)及其加工的描述(算符和表达式)这三个基本问题。

在高级语言中,任何数据都是有类型的,即不同类型的数据有不同的存储属性及操作属性,将数据按其操作属性和存储属性进行分类,就是数据类型的概念。

2.C 的数据类型在C 语言中,数据类型分为基本类型、导出类型(构造类型)、空类型、指针类型。

基本类型有:整型、实型、字符型、枚举类型。

数据有常量与变量之分,它们分别属于这些类型。

3.常量在程序运行过程中,其值不发生变化的量,也就是在程序中直接给出的数据,在词法记号中属于文字。

常量分为字面常量(直接常量)和符号常量。

在C 语言中,符号常量是用无参数的宏定义实现的,即用标识符代表某一字面常量,其定义形式为:#define 标识符(宏名) 字面常量4.变量在程序运行过程中,其值可以改变的量。

变量实质在C 中是为解决不同类型数据在计算机中存储时内存单元的分配问题。

一个变量对应相应的内存单元,且变量有对应的变量名,变量名实际上是内存单元的符号地址。

将变量对应内存单元所存放的当前值,称为变量的值,对变量的访问是按地址进行的,即通过变量名找到相应内存单元的地址,对其存储单元进行读、写操作。

记住:变量的类型、变量名、变量的值是其三大基本属性。

5.整型数据·整型常量的表示方法十进制整数:如123,-456等。

八进制整数:以0为前导的八进制整数。

如0123、-03467,而0879非法。

十六进制数:以0x 为前导的十六进制整数。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

3.2.2 变量
一般规定不得使用系统的保留字作为变量或 其它标识符的名字。例如: 其它标识符的名字。例如: main,define,printf,for等均为保留字 等均为保留字。 main,define,printf,for等均为保留字。 保留字是系统做特定的函数名、定义(说明) 保留字是系统做特定的函数名、定义(说明) 语句命令字等使用的。 符、语句命令字等使用的。
0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
如果将这个最大值加1 就变成: 如果将这个最大值加1,就变成:
1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
3.3.2
整型变量
按照有符号数的表示方法,最高位为“1”时 按照有符号数的表示方法,最高位为“1”时, 该数是负数。 该数是负数。而负数的机内表示为它的补码 形式, 32768, 形式,因此该数实际上为 -32768,这种情况 成为整型数据的溢出。 成为整型数据的溢出。此时一般应定义为长 整型(long)。 整型(long)。 *加2的情况
3.5 3.5.1
字符型数据 字符常量
字符常量用单引号括起来的一个字符。 字符常量用单引号括起来的一个字符。 如: ’a’,‘c’,‘?’,‘9’, ,c,?,9, 这里的字符主要指ASCII码表中, ASCII码表中 这里的字符主要指ASCII码表中,可以在键 盘上输入的部分字符。 盘上输入的部分字符。
3.3.3 整型常量的类型
(1)当一个整数的值在-32768~+32767范围内, 当一个整数的值在-32768~+32767范围内, 范围内 自动地作为int型或short int型常量 int型或 型常量。 自动地作为int型或short int型常量。 当一个整数的值在(2)当一个整数的值在-21473648~+21473647 范围内,自动地作为long int型常量 型常量。 范围内,自动地作为long int型常量。 整型常量无unsigned unsigned型 (3)整型常量无unsigned型。但允许将常量 赋值给一个unsigned型变量。 unsigned型变量 赋值给一个unsigned型变量。 (4)整型常量后面加一个字母“L”(或小写 整型常量后面加一个字母“L”( 的“l”),则认为是long int 型。 ) 则认为是long
3.5.1
字符常量
除了上述形式之外, 除了上述形式之外,还允许以 “\” 开头的 特殊字符序列,也称特殊字符常量。 特殊字符序列,也称特殊字符常量。 特殊字符序列用来做“控制字符” 特殊字符序列用来做“控制字符”,实现某 种特定的功能。 种特定的功能。这种形式用来表示非显示字 实现特殊功能。不显示在屏幕上, 符,实现特殊功能。不显示在屏幕上,也不 在打印机上打印。 在打印机上打印。 做回车换行符。这里字符“ 如用 “\n” 做回车换行符。这里字符“n” 的意义已经转变,因此又被称为转义字符。 的意义已经转变,因此又被称为转义字符。 开头的特殊字符见P.48 P.48表 常用的以 ‘\’ 开头的特殊字符见P.48表3.3
3.2.2 变量
其值可以改变的量,称为变量。 其值可以改变的量,称为变量。 变量在内存中占据一组连续的存储单元, 变量在内存中占据一组连续的存储单元,存 放变量的值。其值是变化的。 放变量的值。其值是变化的。 每个变量有一个变量名。 每个变量有一个变量名。
3.2.2 变量
标识符:用来表示变量名、符号常量名、 标识符:用来表示变量名、符号常量名、函 数名、数组名、类型名、 数名、数组名、类型名、文件名等的字符序 列。 标识符由字母、数字和下划线组成。 标识符由字母、数字和下划线组成。而且第 一个字符必须为字母或下划线。 一个字符必须为字母或下划线。 标识符中的字母区分大小写。 标识符中的字母区分大小写。 标识符的长度在不同的C 标识符的长度在不同的C语言版本中有不同 的规定, 中规定为不超过32 32个有效 的规定,Turbo C 中规定为不超过32个有效 字符。 字符。
3.3.2
整型变量
3.整型变量的定义 3.整型变量的定义 对于变量,必须先定义,后使用。 对于变量,必须先定义,后使用。 由于在实际的应用中存在各种不同的数据类 型。在定义变量时必须指定其所代表的数据 类型。变量的定义一般放在函数(程序) 类型。变量的定义一般放在函数(程序)开 始的声明部分, 始的声明部分,如:
3.4.2
实型变量
3. 实型数据的舍入误差 语言中规定了实型数据的有效位数, c语言中规定了实型数据的有效位数,在实 际运算时,如果超出了范围,不做溢出处理, 际运算时,如果超出了范围,不做溢出处理, 有效位以外的数字将被舍去。 有效位以外的数字将被舍去。并由此产生舍 入误差。 入误差。 例如: 的结果不一定等于1 例如:计算 1.0/3*3 的结果不一定等于1, 因此,编程时应考虑数据的范围,避免出错。 因此,编程时应考虑数据的范围,避免出错。
第三章
数据类型、 数据类型、 运算符与表达式
C的数据类型 3.1 C的数据类型
基本类型 数据类型 构造类型 指针类型 空类型 整型 字符型 单精度型 实型(浮点型) 实型(浮点型) 双精度型 枚举类型 数组类型 结构体类型 共用体类型
3.2
常量与变量
3.2.1 常量和符号常量
在程序运行过程中,其值不能被改变的量称为常量 在程序运行过程中, 12、12.34、 book” 如:12、12.34、‘a’、“This is a book 、 可以用一个名字表示一个常量, 可以用一个名字表示一个常量,此时称为符号常量 #define PRICE 30 main( ) 符号常量也 { int a=10,total; 不允许改变, 不允许改变, total=a*PRICE; 但可重新定 printf(“total=%d total=%d”,total); printf( total=%d ,total); 义。 }
3.4.2
实型变量
实型数据的舍入误差。 例3.4 实型数据的舍入误差。 main() { float a,b; a=1.23456789e10; b=a+20; printf(“%f ); %f\ printf( %f\n”); }
3.4.3 实数常量的类型
实型常量自动按双精度double型处理。 实型常量自动按双精度double型处理。 double型处理 一个实型常量可以赋给一个float float型或 一个实型常量可以赋给一个float型或 double型的变量 型的变量, double型的变量,根据变量的类型截取实型 常量中有效位数字。 常量中有效位数字。
3.4
实型数据
3.4.1 实型常量
实数( number)又称浮点数 floating又称浮点数( 实数(real number)又称浮点数(floatingnumber)。有两种表示形式: )。有两种表示形式 point number)。有两种表示形式: 十进制小数形式, 十进制小数形式, 如 0.34 , 45.0 指数形式: 指数形式:123.456E0 = 123.456 * 100 12.3456E1 = 12.3456 * 101 1.23456E2 = 1.23456 * 102 规定:整数部分保留1位的形式为标准形式, 规定:整数部分保留1位的形式为标准形式, 因此: 5.678E因此:0.05678 应写成 5.678E-02
3.3.2
整型变量
main( ) { int a,b,c,d; unsinged u; long int e,f; …… } 不同类型的整数之间可以进行运算, 不同类型的整数之间可以进行运算,但不能 超出其取值范围。 超出其取值范围。
3.3.2
整型变量
4.整型数据的溢出 4.整型数据的溢出 整型(int)变量的最大允许值为32767, 变量的最大允许值为32767 整型(int)变量的最大允许值为32767,用 16位二进制表示 位二进制表示: 16位二进制表示:
3.4.3 实数常量的类型
截取实型常量中有效位数字, 截取实型常量中有效位数字,如: main( ) a,b,c; { float a,b,c; a=111111.111; b=222222.222; c=a+b; printf(“c=%f ,c); c=%f\ printf( c=%f\n”,c); }
3.3.2
整型变量
2.整型变量的分类----三种类型 2.整型变量的分类----三种类型 整型变量的分类---基本型 (int) 短整型 (short int , short) 长整型 (long int , long) 按照数的表示方法,还可以分为: 按照数的表示方法,还可以分为: 有符号型( 有符号型(signed) 无符号型(unsigned) 无符号型(unsigned)
3.3 3.3.1
整型数据 整型常量
整型常量通常称为整数, 整型常量通常称为整数,可用以下三种类型 表示: 表示: 十进制整数(D) 123, (D): 1、十进制整数(D):123,-456, 0 八进制整数(O) O123—(123)8 (O): (123)8, 2、八进制整数(O):O123 (123)8, O11—( -O11 (-11)8 十六进制(Ox) (Ox): Ox123—(123)16 3、十六进制(Ox.2 变量
应注意:不同长度的标识符, 应注意:不同长度的标识符,即使前面的部 分全相同,也应视为不同。 分全相同,也应视为不同。 例如: 例如: 为两个不同的变量。 a1 和 a12 为两个不同的变量。 是不同的变量。 a,A 是不同的变量。 为合法的变量。 sum,average,_total 为合法的变量。 均为不合法的变量。 M1.2,#b1,123a,a>b 均为不合法的变量。
3.3.2
整型变量
使用整型常量或变量一定要注意数据的范围, 使用整型常量或变量一定要注意数据的范围, 使之不要越界,造成数据的溢出。例如: 使之不要越界,造成数据的溢出。例如: main( ) 执行该程序后, 执行该程序后,变量 { int a,b,c; 的值为-32739, c的值为-32739,数 a=32767; 据溢出。 据溢出。 b=30; c=a+b; printf(“c=%d c=%d\ ,c); printf( c=%d\n”,c); }
相关文档
最新文档