java

public class Solution {
    public int StrToInt(String str) {
        if(str.equals("") || str == null){
            return 0;
        }
        int sum = 0;  // 返回结果
        boolean flag = true;  // 正负数标志位
        char first = str.charAt(0); // 第一位
        if( Character.isDigit(first) ){
            sum += first - '0';
        }else if( first == '-' ){
            flag = false;
        }else if( first != '+' ){
            return 0;
        }
        for(int i=1; i<str.length(); i++){
            char temp = str.charAt(i); //当前char
            int tempInt;
            if( Character.isDigit(temp) ){   //判断是否是数字
                tempInt = temp - '0';// 取出当前char的int值
            }else{
                return 0;
            }
            // 溢出判断start    ps:最大(int) 2^31-1 = 2,147,483,647  最小(int) -2^31 = -2,147,483,648

            // 判断此时sum大于2,147,483,64时则必然溢出  直接返回0 
            if(sum > 214748364){
                return 0;
            }
            // 正数判断最末位是否大于7 负数判断是否大于8
            if(flag){
                // 判断此时sum等于2,147,483,64时判断下一位如果大于7则溢出  直接返回0
                if(sum == 214748364 && tempInt > 7){
                    return 0;
                }
            }else{
                // 判断此时sum等于2,147,483,64时判断下一位如果大于7则溢出  直接返回0
                if(sum == 214748364 && tempInt > 8){
                    return 0;
                }
            }// 溢出判断end

            sum = sum*10 + tempInt;
        }
        return flag ? sum : -sum;


    }
}