[数学]C语言_ch03_2_数据类型及运算符表达式.ppt

[数学]C语言_ch03_2_数据类型及运算符表达式.ppt

  1. 1、本文档共39页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[数学]C语言_ch03_2_数据类型及运算符表达式

* * 类型转换 将取值范围小的类型转为取值范围大的类型是安全的 反之是不安全的 如果大类型的值在小类型能容纳的范围之内,则平安无事。但是,浮点数转为整数,会丢失小数部分(非四舍五入) 反之,转换后的结果必然是错误的,具体结果与机器和实现方式有关。避免如此使用 * * 自动类型转换 两个不同种数据类型的运算结果,是两种类型中取值范围更大的那种 long double double float long (int short char) char、short自动转为int 只要两者中有一个是unsigned,就都转为unsigned再计算 把数据赋值给另外一种类型变量也会发生自动类型转换 从小到大,顺利转换 从大到小,发出警告(好的编译器会给出) * * * * 自动类型转换举例 int i = 3; float f = 2.5f; double d = 7.5; 分析10 + a + i*f - d/3 编译时,从左至右扫描。 1. 先计算10 + a(97),结果为107 2. 先计算优先级高的i*f,将i和f转换为float型,结果为7.5,float型 3. 107+7.5=114.5,float型 4.先计算优先级高的d/3,将d和3转换为double型,结果为2.5,double型 5. 114.5-2.5 = 112.0, double型 * * 例3.3 给定一个大写字母,要求用小写字母输出。 // 3_3.c -- 给定一个大写字母,要求用小写字母输出 #include stdio.h int main(void) { char cUpper, cLower; cUpper = A; cLower = cUpper + 32; printf(%c\n, cLower); printf(%d\n, cLower); return 0; } * * 类型强转 可以通过(类型)表达式的方式把表达式的值转为任意类型 (double)a (将a转换成double类型) (int) (x + y) (将x+y的值转换成int型) (float)(5 % 3)(将5%3的值转换成float型) 注意 强转时,你必须知道你在做什么 强转与指针,并称C语言两大神器,用好了可以呼风唤雨,用坏了就损兵折将 * * 这一节我们学到了 数据类型 char,short,int,long,float,double,long double signed,unsigned 算术运算、自增/自减运算 类型转换 * * 作业 P55 用户从键盘输入一个小写字母,要求用对应的大写字母输出。 P83 习题3 一种解决办法是用一个8字节长的变量来计数,可以保证5亿年以内不出问题(有计算机可以运行5亿年吗?) 对于一个32位的操作系统,拿一个DWORD(doubleword 双字32位)类型来存储计数再合适不过了,但32位是一个很尴尬的数字,如果以ms来计数,49.7天就会转一轮,如果以秒来计数则可以撑68年,这是一个可以接受的大循环,对于只是看看几点几分的用户来讲,精确到秒仍然是可以接受的。 但Windows是以100ns为计数单位的,而且采用64位来存储(这个估计可以用到人类灭亡了)。 不是 * * FLT_MIN在float.h中定义: #define FLT_MIN 1.1754594351e-38F Q:1.18 * 10^-38 的值是怎么来的? A:通常,单精度浮点格式中可以表示的最小规格化的正或负二进制数为: 换算成 10 进制就是:1.175494351e-38,也就是约等于 1.18 * 10^-38 浮点数与零的比较: 等于0关系: fabs(i)=1e-6 大于0关系: i1e-6 小于0关系: i1e-6 在程序设计中,效率和易读性是一对主要矛盾。为了提高程序的效率,需要用技巧把程序写得尽可能简洁一些,但这样有可能降低程序的可读性和可理解性。可读性差的程序容易隐藏错误且难于纠正,不易维护,降低了程序的可靠性。鉴于软件危机的教训,人们在程序设计时遵守的基本规范是:可靠性第一,效率第二。为了保证可靠性,程序必须清晰易读,而表达式的清晰易读是十分重要的方面。因此,在C程序设计中,要慎重使用自增、自减运算符,特别是在一个表达式中不要多处出现变量的自增、自减等运算。 If either is ? ? ?long ? ? ? ? ?double the other is promoted to ? ? ?long ? ? ? ? ?double If either is ? ? ?

文档评论(0)

qiwqpu54 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档