第2章2014数据类型_第1页
第2章2014数据类型_第2页
第2章2014数据类型_第3页
第2章2014数据类型_第4页
第2章2014数据类型_第5页
已阅读5页,还剩29页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第2章数据类型在定义变量时必须指定变量的类型。为什么要指定变量的类型呢?定义变量时明确地说明其类型有利于内存的分配。本章将重点介绍C语言的基本数据类型和数据类型的转换。本章内容2.1数据类型的分类2.2整型数据2.3实型数据2.4字符型数据2.5数据类型转换2.6格式化输入、输出函数【学习目标】掌握C语言的基本数据类型掌握C语言中常量和变量的使用方法理解数据类型的转换掌握格式化输入、输出函数2.1.2数据类型的分类

C语言中,数据有两种表现形式:常量和变量。常量是指在程序运行过程中,其值不能被改变的量。

例如:300、2.1等。而变量在程序运行过程中其值是可以改变的。

例如:intx,y,sum等。2.2整型数据

2.2.1整型变量

整型变量是用来保存整数的变量。例如,在学生信息管理系统中,变量的定义如下:

intage; //年龄

intc; //C语言分数

intmath; //数学分数

inten; //英语分数根据变量所占存储空间的大小和取值范围的不同,整型变量可以分为基本整型、短整型和长整型三种。类型类型说明符占用字节数取值范围举例基本整型int4-231~231-1inti;短整型short[int]2-215~215-1shortinti;长整型long[int]4-231~231-1longinti;长度运算符可以用来计算某种类型的数据在内存中所占的字节数。其语法格式如下:sizeof(类型名、常量或变量名)【例2-1】分析下面程序的运行结果。#include<stdio.h>voidmain(){ doubles=1.0; printf("%3d",sizeof(int)); printf("%3d",sizeof(short)); printf("%3d\n",sizeof(s));}程序运行结果如下:428。根据整型变量的值能否取负数,将上面的每种类型又进一步分为以下两种: 有符号:signed

无符号:unsigned。对于有符号整数,关键词signed可以省略。 例如:singedintage;

等价于 intage;学生的年龄不可能为负数,因此,也可以定义为无符号类型:

例如:unsingedintage;

正、负号的表示对于有符号整型变量中保存的数据,计算机是如何表示其正、负号的呢?所有数据在计算机中都是以二进制形式存储的,对于有符号整数,最高二进制位表示符号位(0表示“正”,1表示“负”)。整型变量的取值范围有符号基本整型(singedint)变量虽然占用4个字节(32位),但只有31位用来表示数值;而无符号整型变量,由于没有符号位,所有的二进制位都用来表示数值。这样有符号整型变量和无符号整型变量的取值范围不同。例如:singedint 取值范围为 -231~231-1unsingedint 取值范围为 0~232-12.2.2整型常量

整型常量即整数,在程序中可用以下三种进制来表示:十进制整型常量(如:212、0、-25)八进制整型常量(用数字0作为前导,如:0236,042,0321)十六进制整型常量(用0x作为前导,如:0x2AF,0x42,0x3E1)缺省情况下,整型常量的数据类型是singedint型。可以在整型常量后面加上类型标识符,明确说明其所属类型。类型标识符有以下两种:(1)大写字母L或小写字母l,表示长整型。例如: longinti=-12L; longintj=0x3E1L; (2)大写字线U或小写字母u,表示无符号整型。 unsignedinti=12U; unsignedintj=0x3E1U;类型类型说明符占用字节数有效数字取值范围(绝对值)单精度型float463.4×10-38~3.4×1038双精度型double8151.7×10-308~1.7×103082.3实型数据

2.3.1实型变量实型(也称浮点型)变量用来保存具有小数点的实数。例:floatave;//平均分根据实型变量的取值范围和有效数字位数(也称精度)的不同,将实型变量分为单精度型和双精度型两种。2.3.2实型常量实型常量有两种表现形式:小数形式。例如:2.15、0.56。指数形式。例如:-7.18e1、-0.718e2。其中,小写字母e也可以采用大写形式,表示以10为底的指数。应当注意:e或E之前必须有数字,且e或E后面必须为整数。例如:e3、13e2.3都是错误的。在存储时,实数的小数点如何表示?系统将实数分成尾数和指数(也称阶码)两个部分来存储,其中,尾数部分小数点前面的数为0。例如,-71.8、-7.18e1存储时系统先将其转换成标准形式-0.718e2,再存储。尾数所占的位数决定了实数的精度,指数所占的位数决定了实数的取值范围。C标准并没有规定尾数和指数所占多少位,而是由各编译系统自定,这样,存储时实数的小数点隐含在了二进制数据中。为了保证处理精度,实型常量自动按双精度型(double)处理,除非在实数后面加上字母f或F,这样才会按单精度型(float)处理。例如:floati=2.15f;doublej=7.18e1;

字符型变量用来保存一个字符,在内存中占一个字节,以标识符char表示。例如:chara; //定义了字符型变量c。实际上字符型数据在内存中存储的是字符的ASCII码。2.4字符型数据

2.4.1字符型变量#include<stdio.h>voidmain(){ chara,b; scanf("%c",&a); printf("%c的ASCII码是%d\n",a,a); b=a+32; printf("%c\n",b);}【例2-2】从键盘输入一个大写字母,输出其ASCII码和对应的小写字母。程序运行结果如下:D↙D的ASCII码是68d#include<stdio.h>voidmain(){ chara,b; getchar(a); printf("%c的ASCII码是%d\n",a,a); b=a+32; putchar(b);}C语言还提供了专门用于字符输入/输出的库函数getchar()和putchar()。getchar()函数用于从键盘输入一个字符,而putchar()函数用于将一个字符输出到屏幕上。2.4.2字符型常量在程序中有以下二种形式的字符型常量:(1)普通字符常量 用一对单撇号将一个字符括起来。 例如:charc2=’A’;(2)转义字符 以反斜杠(\)开头的字符序列,是一种特殊形式的字符常量。转义字符转义字符有以下两种形式:①

反斜杠后面跟一个字符,表示特定的功能。例如:printf("%d\n",c1);\n表示“换行”。②反斜杠后面跟一个字符的ASCII码,表示其所对应的字符。ASCII码可以是1~3位的八进制数字或字母x后面跟1~2位的十六进制数字。例如:'\101'(3位八进制数字),即'A'。'\x41'(2位十六进制数字),即'A'。转义字符及其含义<转义字符含义\n\v\r\a\‘\ddd\t\b\f\\\“\xhh转义字符含义换行垂直制表回车响铃单引号3位8进制数代表的字符水平制表退格换页反斜线双引号2位16进制数代表的字符例,要在屏幕输出 Isay:"Howareyou?"转义字符举例#include"stdio.h"void

main(){ printf("Isay:\"Howareyou?\"\n"); printf("\101\x42C\n");}

在C语言程序设计中,有时需要将数据的类型转换成另一种类型,才能得到正确的计算结果。2.5数据类型转换

【例2-3】分析下面程序的运行结果。#include<stdio.h>voidmain(){ doublea; intb=2; a=1/b; printf("%lf\n",a);}

两个整数相除,结果为整数。

针对这一问题,有两种解决方法:

1.自动转换

在表达式中,当不同类型的数据混合在一起进行运算时,系统会自动将运算符两侧的操作数转换成同一种类型,然后再进行计算。

为了保证运算结果的正确和运算精度,转换方向是由低类型向高类型进行转换。

例如:C=1.0/b;2.强制类型转换

强制类型转换是将一个常量、变量或表达式的值强制转换成用户指定的类型。例如: (double)a (int)(a+b)对于例2-3,也可以采用以下方法加以解决:将语句a=1/b;改为a=(double)1/b;2.6格式化输入、输出函数

2.6.1格式化输入函数按指定的格式从键盘输入数据给变量。格式:scanf("格式控制字符串",变量地址列表);例:inta,b; floatb; scanf("%d,%f",&a,&b);格式控制字符串中的普通字符原样输入。格式说明符含义举例输入数据%d输入有符号十进制整数inta;scanf("%d",&a);162%o输入无符号八进制整数inta;scanf("%o",&a);103%x或%X输入无符号十六进制整数inta;scanf("%x",&a);ff%u输入无符号十进制整数inta;scanf("%u",&a);162%c输入字符chara;scanf("%c",&a);B%s输入字符串chara[10];scanf("%s",a);ABC%f(或%e)以小数形式(或指数形式)输入单精度实数floata;scanf("%f",&a);162.789%lf(或%le)以小数形式(或指数形式)输入双精度实数doublea;scanf("%lf",&a);1.62%ld、%lo、%lx、%lu输入long型整数longa;scanf("%ld",&a);162将数据按指定的格式显示在屏幕上。格式如下:

printf("格式控制字符串",输出列表);

例:inta,b; floatb; printf("%d,%f\n",a,b);格式控制字符串由普通字符、控制字符和格式说明符组成,其中,普通字符原样输出。2.6.2格式化输出函数格式说明符含义举例输出结果%d输出有符号十进制整数inta=162;printf("%d",a);162%o输出无符号八进制整数inta=67;printf("%o",a);103%x或%X输出无符号十六进制整数inta=255;printf("%x",a);ff%u输出无符号十进制整数inta=162;printf("%u",a);162%c输出字符chara='B';printf("%c",a);B%s输出字符串printf("%s","ABC");ABC%f以小数形式输出单精度实数,默认6位小数floata=162.789;printf("%f",a);162.789000%e或%E以指数形式输出单精度实数floata=162.789;printf("%e",a);1.627890e+002%g自动选取e和f中输出宽度较短的一种floata=162.789;printf("%g",a);162.789%%输出百分号%printf("%%");%附加格式说明符格式说明符含义举例输出结果m设置输出数据的宽度,当数据宽度小于m时,左端补空格,否则按实际输出inta=-32;printf("%6d",a);-32(表示空格).n对于实数,指定输出n位小数;对按%s输出的字符串表示从字符串左侧截取n个字符intfloat=35.124;

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论