问题描述
- Objective-c 关于 double 的一个简单的问题
-
刚刚接触计算机编程语言,所以问出的问题有些简单,幼稚,望大家体谅
以下是我的代码,在 Xcode 开发环境中编写的double f; printf("请输入您的分数:"); scanf("%le",&f); if (f == 0) { NSLog(@"无分数"); }else if (f < 60){ NSLog(@"不及格"); }else if (f < 80){ NSLog(@"及格"); }else if (f <= 100){ NSLog(@"优秀"); }else{ NSLog(@"超出分数范围"); }
这是一个简单的测试,但是让我疑惑的是为什么第三行代码中
一定要用 %le 函数呢?换成 %e 或者 %d 都不行!
请教大家原因是什么?
解决方案
Obejctive-C 中数据类型可以在 int 、 float 、 double 和 char 类型前面加上限定词,限定词有: long 、 long long 、 short 、 unsigned 和 signed ,这些限定词从而增强了基本类型 int, float, double, char 。
· long int ,在大部分计算机中代表 32 位整数,在整数后面加 L (或 l )表示,例如: long int numberOfPoints = 131071100L , NSLog 函数中格式化字符串使用 %li 表示;
· long long int 可以指定更加宽泛的整数类型,保证变量至少 64 位宽度。 NSLog 函数中格式化字符串使用 %lli 表示;
· long double ,可以指定更加宽泛的 double 类型,要显示这个可以在尾部使用 L (大小写)表示, 1.234e+7L 。 NSLog 函数中格式化字符串使用 %Lf 、 %Le 和 %Lg 表示;
· short int 用来指定存放相对小的整数,一般是占用 int 类型的一半。大部分计算机是 16 位;
· unsigned int ,告诉编译器只是接受整数,在数值之后放字母 u (或 U )表示,例如: 0x00ffU ;编写整数时候,可以将字母 u (或 U )和 l (或 L )组合起来,例如: 20000UL ;
而其实就是NSlog 的一种格式化输出。
解决方案二:
L是long的意思
解决方案三:
因为double会导致微量失真,0.01会变成0.00999999……