Easiest way to truncate float to 2 decimal places?

前端 未结 2 601
滥情空心
滥情空心 2021-01-18 02:03

In Swift, is there a way to truncate a float to 2 decimals, such that you can perform further calculations with it? All of the threads I\'ve seen deal with casting to a str

相关标签:
2条回答
  • 2021-01-18 02:42

    If you need to work with true precision (for currency-related applications, for example), you will probably want to use NSDecimalNumber instead of floating point.

    The above approach can be applied to NSDecimalNumbers as shown below. In this example, the "step" that you are rounding to can be anything you choose, just set "increment" accordingly.

    let number: NSDecimalNumber = 100.52
    let increment: NSDecimalNumber = 0.25
    
    let handler = NSDecimalNumberHandler(roundingMode: NSRoundingMode.RoundBankers, scale: 0, raiseOnExactness: false, raiseOnOverflow: false, raiseOnUnderflow: false, raiseOnDivideByZero: false)     // Rounds to the nearest whole number
    let result = number.decimalNumberByDividingBy(increment).decimalNumberByRoundingAccordingToBehavior(handler).decimalNumberByMultiplyingBy(increment)
    

    For more on rounding with NSDecimalNumber see here: How to round an NSDecimalNumber in swift?

    And yes, working with NSDecimalNumber is a terribly verbose way to do math, but it's not complicated. If you find yourself doing a project involving them frequently, I recommend you consider setting up Swift operator extensions so you can manipulate them in a more elegant way. Check out here for a nice example: https://gist.github.com/mattt/1ed12090d7c89f36fd28

    0 讨论(0)
  • 2021-01-18 02:54

    You cannot round a Float or Double to 2 decimal digits exactly. The reason is that these data types use a binary floating point representation, and cannot represent numbers like 0.1 or 0.01 exactly. See for example

    • Why Are Floating Point Numbers Inaccurate?
    • What Every Computer Scientist Should Know About Floating-Point Arithmetic

    But you said:

    I need my return value to be in quarter steps (i.e. 6.50, 6.75, 5.25, etc),

    and that is exactly possible because 0.25 = 2-2 can be represented exactly as a floating point number.

    The round() function rounds a floating point number to the nearest integral value. To round to the nearest quarter, you just have to "scale" the calculation with the factor 4:

    func roundToNearestQuarter(num : Float) -> Float {
        return round(num * 4.0)/4.0
    }
    
    roundToNearestQuarter(6.71) // 6.75
    roundToNearestQuarter(6.6)  // 6.5
    
    0 讨论(0)
提交回复
热议问题