一个简单的问题:怎样使代码优化的更好

 今天在公司,一同事问了我一个问题,我想写一个方法,当接收到任意长度整型数值的时候,我如何只保留首位,其他位全部置为0呢。我思考了几秒钟:你可以先把整型参数用String强类型转换,看看字符串的长度,这样你就能根据长度得到首位的数字,后面再根据长度补零就行了。这时他问道,可不可以不通过字符串转换,直接用整型来处理呢?于是我们开始研究:

第一种做法: 

function encoder(num:int):int{ 
    var sNum:int = num;
    var count:int = 0;
    while(true){
        count++;
        sNum /= 10;
        if (sNum < 10){
            sNum = Math.floor(sNum);
            break;
        }
    }
    return decoder(sNum,count);
}
 
function decoder(num:int,step:int):int{
    var _num:int = num;
    for (var i:int = 0;i<step;i++){
        _num *= 10;
    }
    return _num;
}
经过测试,这种做法是没有问题的,但是这是不是最好的方法呢,当然不是,因为Math.floor()的原因肯定会导致
效率下降一部分,有办法替换么,其实很简单,直接用int()转换一下就行了。这样是最优做法么,当然还不是,看看下面这段代码:

第二种做法:

function encoder(num:int):int{ 
    var i:int=num;
    var j:int=1;
    while(i>10)
    {
        j*=10;
        i=num/j;
    }
    return i*j;
}

这段代码相信大家都能看懂,它的优化在哪呢?比之前少了一个循环,当然效率会大幅提升了。我们只需再添加一个变量作为被乘数,这样就减少了一个循环。这段代码基本已经是效率很高了,但其实如果你够细心的话,仍然可以再进行优化,就是这句:i=num/j;我们把它替换成i *= .1;为什么呢?因为在计算机内部,乘运算比除运算要快。让我们看一下测试结果吧:

(左边是乘运算,右边是除运算,单位:毫秒) 
当循环100万次时:
1028  1070
1049  1065
1045  1063
1024  1074
当循环1000万次时:
10319  10784
10467  10625