<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    ivaneeo's blog

    自由的力量,自由的生活。

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      669 Posts :: 0 Stories :: 64 Comments :: 0 Trackbacks
    范例(Examples)
    下面范例中我要計算一個蘇格蘭布丁(haggis)運動的距離。在起點處,靜止的蘇格蘭布丁會受到一個初始力的作用而開始運動。一段時機后,第二個力作用于布丁,讓它再次加速。根據牛頓第二定律,我可以這樣計算布丁運動的距離:

    double getDistanceTravelled(int time) {
        double result;
        double acc = _primaryForce / _mass;
        int primaryTime = Math.min(time, _delay);
        result = 0.5 * acc * primaryTime * primaryTime;
        int secondaryTime = time - _delay;
        if(secondaryTime > 0) {
           double primaryVel = acc * _delay;
           acc = (_primaryForce + _secondaryForce) / _mass;
           result += primaryvel * secondaryTime + 0.5 * acc * secondaryTime * secondaryTime;
        }
        return result;
    }

    acc變量有兩個責任:第一是保存第一個力造成的初始加速度;第二是保存兩個力共同造成的加速度。這就是我想要剖解的東西。

    首先,我在函數開始處修改這個臨時變量的名稱,并將新的臨時變量聲明為final。接下來我把第二次賦值之前對acc變量的所有引用點,全部改用新的臨時變量。最后,我在第二次賦值處重新聲明acc變量:

    double getDistanceTravelled(int time) {
        double result;
        final double primaryAcc = _primaryForce / _mass;
        int primaryTime = Math.min(time, _delay);
        result = 0.5 * primaryAcc * primaryTime * primaryTime;
        int secondaryTime = time - _delay;
        if(secondaryTime > 0) {
           double primaryVel = primaryAcc * _delay;
           double acc = (_primaryForce + _secondaryForce) / _mass;
           result += primaryvel * secondaryTime + 0.5 * acc * secondaryTime * secondaryTime;
        }
        return result;
    }

    新的臨時變量的名稱指出,它只承擔原先acc變量的第一責任。我將它聲明為final,確保它只被賦值一次。然后,我在原先acc變量第二次被賦值處重新聲明acc?,F在,重新編譯并測試,一切都應該沒有問題。

    然后,我繼續處理acc臨時變量的第二次賦值。這次我把原先的臨時變量完全刪掉,代之以一個新的臨時變量。新變量的名稱指出,它只承擔原先acc變量的第二個責任:

    double getDistanceTravelled(int time) {
        double result;
        final double primaryAcc = _primaryForce / _mass;
        int primaryTime = Math.min(time, _delay);
        result = 0.5 * primaryAcc * primaryTime * primaryTime;
        int secondaryTime = time - _delay;
        if(secondaryTime > 0) {
           double primaryVel = primaryAcc * _delay;
           final double secondaryAcc = (_primaryForce + _secondaryForce) / _mass;
           result += primaryvel * secondaryTime + 0.5 * secondaryAcc * secondaryTime * secondaryTime;
        }
        return result;
    }
    posted on 2005-08-29 14:56 ivaneeo 閱讀(184) 評論(0)  編輯  收藏 所屬分類: refactoring-從地獄中重生
    主站蜘蛛池模板: xxxxx做受大片在线观看免费| 亚洲第一页在线播放| 四虎成人免费影院网址| 免费在线观看视频网站| 99久热只有精品视频免费看| 精品国产一区二区三区免费| 中文字幕在线免费播放| 中文字幕免费在线看线人动作大片 | 春意影院午夜爽爽爽免费| 西西人体大胆免费视频| 欧洲美女大片免费播放器视频| 老司机免费午夜精品视频| 特级毛片全部免费播放| 伊人久久国产免费观看视频| 一级毛片**免费看试看20分钟| 国产成人无码免费网站| a在线免费观看视频| 亚洲精品免费视频| 国产h肉在线视频免费观看| 成人女人A级毛片免费软件| 最新中文字幕电影免费观看| 韩国日本好看电影免费看| 四虎影院永久免费观看| 亚洲伦乱亚洲h视频| 精品国产_亚洲人成在线高清| 亚洲成人动漫在线| 亚洲一卡2卡4卡5卡6卡在线99| 久久亚洲精品国产亚洲老地址 | 国产亚洲午夜高清国产拍精品| 精品亚洲永久免费精品| 91亚洲国产成人精品下载| 亚洲欧洲日韩极速播放| 无码天堂亚洲国产AV| 国产一区二区三区免费观在线| 96免费精品视频在线观看| 免费99精品国产自在现线| 日韩在线视频免费看| 亚洲中文字幕无码一区| 亚洲欧洲在线播放| 真人无码作爱免费视频| 一个人免费视频在线观看www|