美文网首页
floatValue 失真

floatValue 失真

作者: 3a169b0787bc | 来源:发表于2018-08-25 12:58 被阅读29次

    开发遇到的一个坑。在与后台交互的时候,协议规定的数据类型是浮点型,这就要求我们将用户输入的字符串转化为float类型。但是在转化过程中会出现失真的情况。
    其实float与str互转会出现失真的情况,原因很简单。这是因为浮点数的存储方式的缘故。

        NSLog(@"%f",[@"20.5" floatValue]);
        NSLog(@"%f",[@"20.7" floatValue]);
        NSLog(@"%f",[@"20.75" floatValue]);
        NSLog(@"%f",[@"20.76" floatValue]);
        NSLog(@"%f",[@"20.875" floatValue]);
        NSLog(@"%f",[@"20.878" floatValue]);
        NSLog(@"%f",[@"20.09375" floatValue]);
        NSLog(@"%f",[@"20.09335" floatValue]);
        NSLog(@"%f",[@"20.546875" floatValue]);
        NSLog(@"%f",[@"20.546878" floatValue]);
    
    2018-08-25 11:21:58.833098+0800 floatValueDistortion[3523:408253] 20.500000
    2018-08-25 11:21:58.833285+0800 floatValueDistortion[3523:408253] 20.700001
    2018-08-25 11:21:58.833401+0800 floatValueDistortion[3523:408253] 20.750000
    2018-08-25 11:21:58.833520+0800 floatValueDistortion[3523:408253] 20.760000
    2018-08-25 11:21:58.833623+0800 floatValueDistortion[3523:408253] 20.875000
    2018-08-25 11:21:58.834162+0800 floatValueDistortion[3523:408253] 20.878000
    2018-08-25 11:21:58.834477+0800 floatValueDistortion[3523:408253] 20.093750
    2018-08-25 11:21:58.834636+0800 floatValueDistortion[3523:408253] 20.093349
    2018-08-25 11:21:58.834784+0800 floatValueDistortion[3523:408253] 20.546875
    2018-08-25 11:21:58.834978+0800 floatValueDistortion[3523:408253] 20.546879
    

    在回顾了浮点数的存储方式之后,和后台商议使用更改数据类型为字符串进行传输,问题就解决了。但是如果要用输入的类型进行计算呢?这个时候问题就避不开了。
    其实苹果已有线程的API是可以支持的。NSDecimalNumber看定义就可以发现,不同于浮点数的存储,他是十进制的。同时也可以定制精度的取正类型:向上取正、向下去正、四舍五入等。相对与浮点类型的计算,NSDecimalNumber提供了更加精准的计算。

    NSDecimalNumber
    An object for representing and performing arithmetic on base-10 numbers.
    
    - (void)caculateTest
    {
        NSString * floatStr1 =@"14.326";
        NSString * floatStr2 =@"7.54";
        
        NSDecimalNumber * num1 = [NSDecimalNumber decimalNumberWithString:floatStr1];
        NSDecimalNumber * num2 = [NSDecimalNumber decimalNumberWithString:floatStr2];
    
        NSDecimalNumber *num3 = [num1 decimalNumberByAdding:num2];
        CGFloat float3 = [floatStr1 floatValue] + [floatStr2 floatValue];
        NSLog(@"%@,%f",num3,float3);
        
        NSDecimalNumber *num4 = [num1 decimalNumberBySubtracting:num2];
        CGFloat float4 = [floatStr1 floatValue] - [floatStr2 floatValue];
        NSLog(@"%@,%f",num4,float4);
    
        NSDecimalNumber *num5 = [num1 decimalNumberByMultiplyingBy:num2];
        CGFloat float5 = [floatStr1 floatValue] * [floatStr2 floatValue];
        NSLog(@"%@,%f",num5,float5);
    
        NSDecimalNumber *num6 = [num1 decimalNumberByDividingBy:num2];
        CGFloat float6 = [floatStr1 floatValue] / [floatStr2 floatValue];
        NSLog(@"%@,%f",num6,float6);
    }
    
    floatValueDistortion[3897:448522] 21.866,21.866001
    2018-08-25 12:31:09.503985+0800 floatValueDistortion[3897:448522] 6.786,6.786000
    2018-08-25 12:31:09.504800+0800 floatValueDistortion[3897:448522] 108.01804,108.018044
    2018-08-25 12:31:09.504993+0800 floatValueDistortion[3897:448522] 1.9,1.900000
    

    Demo地址

    浮点数在计算机中存储方式
    iOS开发笔记之四十二——一个double精度导致的bug

    相关文章

      网友评论

          本文标题:floatValue 失真

          本文链接:https://www.haomeiwen.com/subject/hpolvftx.html