2 u013745784 u013745784 于 2014.02.23 11:28 提问

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 都不行!
请教大家原因是什么?

3个回答

u013630453
u013630453   2014.03.21 00:22

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 的一种格式化输出。

u011988082
u011988082   2015.06.12 08:41

L是long的意思

Leexianke
Leexianke   2015.09.11 16:13

因为double会导致微量失真,0.01会变成0.00999999……

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!