How does Integer.parseInt(string) actually work?

后端 未结 7 1717
南笙
南笙 2020-12-02 20:43

Was asked this question recently and did not know the answer. From a high level can someone explain how Java takes a character / String and convert it into an int.

M

相关标签:
7条回答
  • 2020-12-02 21:04
    public class StringToInt {
    
        public int ConvertStringToInt(String s) throws NumberFormatException
        {
            int num =0;
            for(int i =0; i<s.length();i++)
            {
                if(((int)s.charAt(i)>=48)&&((int)s.charAt(i)<=59))
                {
                    num = num*10+ ((int)s.charAt(i)-48);
                }
                else
                {
                    throw new NumberFormatException();
                }
    
            }
            return num; 
        }
    
        public static void main(String[]args)
        {
            StringToInt obj = new StringToInt();
            int i = obj.ConvertStringToInt("1234123");
            System.out.println(i);
        }
    
    }
    
    0 讨论(0)
  • 2020-12-02 21:06

    I'm not sure what you're looking for, as "high level". I'll give it a try:

    • take the String, parse all characters one by one
    • start with a total of 0
    • if it is between 0 and 9, total = (total x 10) + current
    • when done, the total is the result
    0 讨论(0)
  • 2020-12-02 21:07

    this is my simple implementation of parse int

    public static int parseInteger(String stringNumber) {
        int sum=0;
        int position=1;
        for (int i = stringNumber.length()-1; i >= 0 ; i--) {
           int number=stringNumber.charAt(i) - '0';
           sum+=number*position;
           position=position*10;
    
        }
        return sum;
    }
    
    0 讨论(0)
  • 2020-12-02 21:11

    Here is what I came up with (Note: No checks are done for alphabets)

    int convertStringtoInt(String number){
    
        int total =0;
        double multiplier = Math.pow(10, number.length()-1);
            for(int i=0;i<number.length();i++){
    
                total = total + (int)multiplier*((int)number.charAt(i) -48);
                multiplier/=10;
    
            }
    
            return total;
        }
    
    0 讨论(0)
  • 2020-12-02 21:13
    • Find the length of the String (s) (say maxSize )
    • Initialize result = 0
    • begin loop ( int j=maxSize, i =0 ; j > 0; j--, i++)
    • int digit = Character.digit(s.charAt(i))
    • result= result + digit * (10 power j-1)
    • end loop
    • return result
    0 讨论(0)
  • 2020-12-02 21:17

    The source code of the Java API is freely available. Here's the parseInt() method. It's rather long because it has to handle a lot of exceptional and corner cases.

    public static int parseInt(String s, int radix)
        throws NumberFormatException
    {
        if (s == null) {
            throw new NumberFormatException("null");
        }
    
    if (radix < Character.MIN_RADIX) {
        throw new NumberFormatException("radix " + radix +
                        " less than Character.MIN_RADIX");
    }
    
    if (radix > Character.MAX_RADIX) {
        throw new NumberFormatException("radix " + radix +
                        " greater than Character.MAX_RADIX");
    }
    
    int result = 0;
    boolean negative = false;
    int i = 0, max = s.length();
    int limit;
    int multmin;
    int digit;
    
    if (max > 0) {
        if (s.charAt(0) == '-') {
        negative = true;
        limit = Integer.MIN_VALUE;
        i++;
        } else {
        limit = -Integer.MAX_VALUE;
        }
        multmin = limit / radix;
        if (i < max) {
        digit = Character.digit(s.charAt(i++),radix);
        if (digit < 0) {
            throw NumberFormatException.forInputString(s);
        } else {
            result = -digit;
        }
        }
        while (i < max) {
        // Accumulating negatively avoids surprises near MAX_VALUE
        digit = Character.digit(s.charAt(i++),radix);
        if (digit < 0) {
            throw NumberFormatException.forInputString(s);
        }
        if (result < multmin) {
            throw NumberFormatException.forInputString(s);
        }
        result *= radix;
        if (result < limit + digit) {
            throw NumberFormatException.forInputString(s);
        }
        result -= digit;
        }
    } else {
        throw NumberFormatException.forInputString(s);
    }
    if (negative) {
        if (i > 1) {
        return result;
        } else {    /* Only got "-" */
        throw NumberFormatException.forInputString(s);
        }
    } else {
        return -result;
    }
    }
    
    0 讨论(0)
提交回复
热议问题