Finding absolute value of a number without using Math.abs()

后端 未结 10 1560
轮回少年
轮回少年 2021-02-02 11:16

Is there any way to find the absolute value of a number without using the Math.abs() method in java.

10条回答
  •  小鲜肉
    小鲜肉 (楼主)
    2021-02-02 12:12

    Since Java is a statically typed language, I would expect that a abs-method which takes an int returns an int, if it expects a float returns a float, for a Double, return a Double. Maybe it could return always the boxed or unboxed type for doubles and Doubles and so on.

    So you need one method per type, but now you have a new problem: For byte, short, int, long the range for negative values is 1 bigger than for positive values.

    So what should be returned for the method

    byte abs (byte in) {
       // @todo
    }
    

    If the user calls abs on -128? You could always return the next bigger type so that the range is guaranteed to fit to all possible input values. This will lead to problems for long, where no normal bigger type exists, and make the user always cast the value down after testing - maybe a hassle.

    The second option is to throw an arithmetic exception. This will prevent casting and checking the return type for situations where the input is known to be limited, such that X.MIN_VALUE can't happen. Think of MONTH, represented as int.

    byte abs (byte in) throws ArithmeticException {
       if (in == Byte.MIN_VALUE) throw new ArithmeticException ("abs called on Byte.MIN_VALUE"); 
       return (in < 0) ? (byte) -in : in; 
    }
    

    The "let's ignore the rare cases of MIN_VALUE" habit is not an option. First make the code work - then make it fast. If the user needs a faster, but buggy solution, he should write it himself. The simplest solution that might work means: simple, but not too simple.

    Since the code doesn't rely on state, the method can and should be made static. This allows for a quick test:

    public static void main (String args []) {
        System.out.println (abs(new Byte ( "7")));
        System.out.println (abs(new Byte ("-7")));
        System.out.println (abs((byte)  7));
        System.out.println (abs((byte) -7));
        System.out.println (abs(new Byte ( "127")));
        try
        {
            System.out.println (abs(new Byte ("-128")));
        }
        catch (ArithmeticException ae)
        {
            System.out.println ("Integer: " + Math.abs (new Integer ("-128")));
        }
        System.out.println (abs((byte)  127));
        System.out.println (abs((byte) -128));
    }
    

    I catch the first exception and let it run into the second, just for demonstration.

    There is a bad habit in programming, which is that programmers care much more for fast than for correct code. What a pity!


    If you're curious why there is one more negative than positive value, I have a diagram for you.

提交回复
热议问题