浮点型 + 类型转换.ppt

浮点型 + 类型转换.ppt

ID:48154585

大小:235.50 KB

页数:16页

时间:2020-01-17

浮点型 + 类型转换.ppt_第1页
浮点型 + 类型转换.ppt_第2页
浮点型 + 类型转换.ppt_第3页
浮点型 + 类型转换.ppt_第4页
浮点型 + 类型转换.ppt_第5页
资源描述:

《浮点型 + 类型转换.ppt》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、浮点型+类型转换数据之间的相互转换也是重点浮点型C语言中除了整型外,另外一种数据类型就是浮点型,浮点型可以表示有小数部分的数据。浮点型包含三种数据类型,分别是单精度的float类型,双精度的double类型,和长双精度longdouble类型。浮点型(图表)浮点型floatdoublelongdouble类型位数有效数字取值范围float326~7-1.4e-45~3.4e38double6415~16-4.9e-324~1.8e308longdouble12818~19——浮点型参与运算的表达式中存在double类型,或者说,参与运算的表达式不是完全由整型组成的,在没有明确的类型转换标识

2、的情况下(将在下一小节中讲解),表达式的数据类型就是double类型。例如:1+1.5+1.23456789/*表达式运算结果是double类型*/1+1.5/*表达式运算结果是double类型*/1+2.0/*表达式运算结果是double类型*/1+2/*表达式运算结果是int类型*/例子当的1.5,编译器默认它为双精度的double类型,精度高占据存储空间大,如果只希望以单精度float类型运行,可以在常量后添加字符‘f’或者‘F’都可以,比如1.5F,2.38F。同样的,如果希望数据是以精度更高的longdouble参与运算,可以在常量后添加字符‘l’或者‘L’都可以,比如1.512

3、45L,2.38000L。建议使用大写‘L’,因为小写‘l‘容易和数字1混淆。浮点型再举几个运算的表达式的例子,如下所示:inti,j;floatm;doublex;i+j/*表达式运算结果是int类型*/i+m/*表达式运算结果是float类型*/i+m+x/*表达式运算结果是double类型*/浮点型指数形式如下所示(‘e’或者‘E’都可以)2.0e3表示2000.01.23e-2表示0.0123.123e2表示12.31.e-3表示0.001对于指数形式,有以下两点要求:⑴字母e前面必须要有数字⑵字母e的后面必须是整数浮点型小数形式指数形式类型转换1隐式转换2显式转换类型转换计算过程

4、中,如果遇到不同的数据类型参与运算该怎么办,是终止程序还是转换类型后继续运算。编译器采取第二种方式,如果能够转换成功,程序继续运算,如果转换失败,程序报错同时终止运行。数据类型有两种转换方式,分别隐式转换和显式转换。隐式转换C语言中设定了不同数据参与运算时的转换规则,编译器会在悄无声息中进行数据类型的转换,进而计算出最终结果,这就是隐式转换。隐式转换inti;i=2+'A';先计算“=”号右边的表达式,字符型和整型混合运算,按照数据类型转换先后顺序,把字符型转换为int类型65,然后求和得67,最后把67赋值给变量i。doubled;d=2+'A'+1.5F;先计算“=”号右边的表达式,字

5、符型、整型和单精度float类型混合运算,因为有浮点型参与运算,“=”右边表达式的结果一定是double类型,按照数据类型转换顺序,把字符型转换为类型65.0,2转换为2.0,1.5F转换为1.5,最后把双精度浮点数68.5赋值给变量d。隐式转换上述情况都是有低精度类型向高精度类型的转换,如果逆向转换,可能会出现丢失数据的危险,编译器会以警告的形式给出提示。例如:inti;i=1.2;浮点数1.2舍弃小数位后,把整数部分1赋值给变量i。如果i=1.9,运算后变量i的值依然是1,而不是2。注意:把浮点数转换为整数,直接舍弃小数位。隐式转换【范例-1】整型和浮点型数据类型间的隐式类型转换。01

6、#include02intmain(void)03{04inti;05i=1+2.0*3+1.234+'c'-'A';/*混合运算*/06printf("%d",i);/*输出i*/07return0;08}显式转换隐式类型转换编译器是会产生警告的,提示程序存在潜在的隐患。如果非常明确的希望转换数据类型,这就需要用到显式类型转换了。显式转换格式如下所示:(类型名称)变量或者常量或者(类型名称)(表达式)显式转换例如,需要把一浮点数,以整数的形式使用printf()函数输出,怎么办?就可以调用显示类型转换。floatf=1.23;printf("%d",(int)f

7、);可以得到输出结果1,没有因为调用的printf()函数格式控制列表和输出列表前后类型不统一导致程序报错。继续分析上例,显示类型转换只是把f小数位直接舍弃,输出了整数部分,变量f的值和数据类型都没有改变,依然是float类型1.23,可以再次输出结果进行查看。printf("%f",f);输出结果是:1.230000显式转换再看下面的例子,分析结果是否相同。例如floatf1,f2;f1=(int)1.2+3.4;

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。