色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

沒事兒別優(yōu)化!

  本文是從 Don’t optimize! 這篇文章翻譯而來。

  事實(shí)上你應(yīng)該優(yōu)化,但要在正確的地方,有足夠的理由。我待會兒再聊這個(gè)。

  我最近和在 Badgerpunch Games 的幾位朋友一起發(fā)布了一個(gè)小的以XNA為基礎(chǔ)的游戲,而且通過論壇和Twitter與這個(gè)獨(dú)立的游戲開發(fā)組織保持密切的聯(lián)系。游戲開發(fā)者十分在意性能問題,而且這很必要。沒有人想要一個(gè)運(yùn)行不暢的游戲。因?yàn)檫@些對性能的擔(dān)憂,出現(xiàn)了很多關(guān)于優(yōu)化技巧的提示和論文,都圍繞著如何能實(shí)際有效的緩解性能問題。大多數(shù)的技巧提示和文章都提供了有價(jià)值的信息、有相應(yīng)的用處,但你會發(fā)現(xiàn)很少有文章能觸碰到性能優(yōu)化上的主要問題:什么時(shí)候不該優(yōu)化,為什么。

  優(yōu)化就是這樣的事:你的程序可以一直優(yōu)化下去,但工時(shí)上的開銷和取得的效果的對比會很快讓你陷入困境。我記起了九十年代早期在 Amiga Demo 公司的一幕。我大概花了半年的時(shí)間去優(yōu)化那個(gè)3D旋轉(zhuǎn)的匯編程序片段。最終我覺得該優(yōu)化的幾乎都優(yōu)化了。起初幾周我努力減少CPU的指令循環(huán),獲得了驚人的減幅!但隨后的數(shù)月里,我?guī)缀鯖]法再進(jìn)一步的壓縮,最終只得放棄…我這段程序超級的快,可是,其他程序員的3D圖形跑的比我還要快,我無法理解,這怎么可能?

  直到數(shù)年后我在大學(xué)里學(xué)了矩陣后我才明白其中的奧秘。我的程序里每個(gè)3D坐標(biāo)用9次乘法,這是一個(gè)沒有優(yōu)化的矩陣算法,它可以被壓縮成6次乘和兩個(gè)加法,這樣每個(gè)坐標(biāo)點(diǎn)可以節(jié)省數(shù)百次的CPU指令循環(huán)…太郁悶了!

  這個(gè)故事的寓意?你可以優(yōu)化你的程序,讓它像星星一樣閃亮,但如果有人有更好的算法,讓同樣的程序跑的更快,你還是很失敗。

  你很失敗嗎?只是在有意義的時(shí)候才能這樣說。在上面的性能優(yōu)化的故事里,3D旋轉(zhuǎn)效果是被限制在一個(gè)16位的機(jī)器上的,這種情況下最快的程序證明了最出色的程序員,這時(shí)它的意義就很大了。 

  這讓我們回到了最初的那個(gè)問題。不要優(yōu)化——如果優(yōu)化是無關(guān)緊要的。重要的是讓你的代碼簡單易懂,容易修改!當(dāng)你的程序具有這三個(gè)特征時(shí),它是否被優(yōu)化已經(jīng)無關(guān)緊要了。

  如果程序太慢,使用一個(gè)分析工具,找到什么地方需要優(yōu)化。有時(shí)你并不需要一個(gè)分析工具,你只需要根據(jù)你的實(shí)際數(shù)據(jù)進(jìn)行優(yōu)化。當(dāng)你找到了問題的區(qū)域,盡可能的用最簡單的方式修改它們,看看修改后有什么效果。最終讓你的程序達(dá)到到可以接受的性能程度。如果還不行,你需要根據(jù)你的代碼做算法上的修改。這就是為什么要保持代碼簡潔、易于修改的原因了。

  讓代碼保持簡單易讀、易于修改的主要原因是為了尋找bug,這是一個(gè)閱讀和修改代碼的過程。程序越易懂,問題越容易修改。這是毫無疑問的…可是仍然有人堅(jiān)持把事情能的盡可能的復(fù)雜,只是為了滿足個(gè)人的野心!我曾經(jīng)看到一段Java代碼里有多層遞歸調(diào)用的if語句。這是一個(gè)最糟糕的無意識里做出的損毀程序的事。必然的,到處都是bug …看的我想哭。

  另外一個(gè)保持代碼簡潔的原因是以最簡單的方式告訴編譯器你的程序的意圖。編譯器對簡單的代碼有更好的優(yōu)化能力。如果你是一個(gè)虛擬機(jī)上使用JIT編譯器,這更顯的重要。虛擬機(jī)和按需編譯可以使你的程序能在不同的VM版本上運(yùn)行。基本上虛擬機(jī)版本越新,你的代碼越簡單,當(dāng)程序運(yùn)行時(shí),你就能獲得更好的優(yōu)化結(jié)果。

  早期版本的Java虛擬機(jī)做很少的編譯優(yōu)化,所以像for循環(huán)、反向計(jì)數(shù)等技巧可以節(jié)省一些循環(huán)。但是最新版的編譯器和按需優(yōu)化處理針對最常見的for循環(huán)形式進(jìn)行了優(yōu)化。性能問題從代碼轉(zhuǎn)移到了虛擬機(jī)上,長時(shí)間運(yùn)行的程序在代碼上的優(yōu)化技巧不再具有很重的份量。

  所有的論述濃縮成這個(gè):除非你知道優(yōu)化什么,否則別去優(yōu)化。這并不是說你不需要去考慮性能問題。你始終應(yīng)該把性能問題放在心上。它有可能是你算法選擇上的問題,設(shè)計(jì)、實(shí)現(xiàn)上的問題,但你的主要精力應(yīng)該放在保持代碼簡潔易讀,易于修改上。

it知識庫沒事兒別優(yōu)化!,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 古丈县| 长寿区| 新乡市| 师宗县| 安岳县| 房山区| 榆中县| 常宁市| 吴忠市| 河源市| 怀集县| 清涧县| 林甸县| 西乌| 陕西省| 丰县| 晋宁县| 密云县| 临湘市| 铁岭县| 尚义县| 台湾省| 丰都县| 沙坪坝区| 海原县| 县级市| 西平县| 隆回县| 祁门县| 壶关县| 杭锦后旗| 冀州市| 台北县| 吉首市| 繁昌县| 晋城| 武城县| 滦南县| 澄江县| 平潭县| 丽水市|