如何理解性能問題

學(xué)習(xí)理解運(yùn)行的程序的性能問題與學(xué)習(xí)debug是一樣不可避免的。很多人完成了需求以及功能趋箩,但是這個(gè)功能的耗時(shí)與占用內(nèi)存全然不管赃额,導(dǎo)致了所寫的代碼很難受到他人的認(rèn)可。所以說理解性能問題叫确,能幫助你升華你的代碼以及編程水平跳芳。

有可能你的客戶認(rèn)為你的一個(gè)系統(tǒng)或子系統(tǒng)運(yùn)行太慢了,或者一跑你的程序就瞬間把cpu的核擠爆了竹勉。你要想辦法去優(yōu)化它飞盆,去提升它的性能,或者更貼切的說去優(yōu)化你的邏輯以及算法次乓。

你可能需要去構(gòu)建一個(gè)它為什么慢的思維模型吓歇,你可以用一個(gè)圖表工具或者打印運(yùn)行時(shí)間戳,去發(fā)現(xiàn)時(shí)間或資源真正被損耗的地方票腰。有可能大部分時(shí)間是以某種形式華為費(fèi)在I/O上城看。發(fā)現(xiàn)昂貴的I/O和昂貴的10%代碼是構(gòu)建思維模型的一個(gè)好的開始。打開你windows的任務(wù)管理器杏慰,可以清晰的看到各個(gè)數(shù)據(jù)以及圖表测柠。

計(jì)算機(jī)系統(tǒng)的性能優(yōu)很多個(gè)維度,很多資源會(huì)被消耗缘滥。第一種資源是“掛鐘時(shí)間”轰胁,即執(zhí)行程序的所有時(shí)間。記錄“掛鐘時(shí)間”是一件特別有價(jià)值的事情完域。有時(shí)候有些東西只是稍微多花費(fèi)了一點(diǎn)點(diǎn)時(shí)間软吐,并且不會(huì)引爆什么問題瘩将,只有在特定的場景下才會(huì)引發(fā)crash吟税,所以在你真實(shí)要處理的計(jì)算機(jī)環(huán)境中,多一些處理器時(shí)間可能會(huì)是更好的選擇姿现。相似的內(nèi)存肠仪,網(wǎng)絡(luò)帶寬,數(shù)據(jù)庫或其他服務(wù)器訪問备典,可能最后都比處理器時(shí)間要更加昂貴异旧。

競爭共享的資源被同步使用,一切都到后面都會(huì)是資源的爭奪提佣,可能導(dǎo)致司索和互斥吮蛹。死鎖是由于不恰當(dāng)?shù)耐胶驼?qǐng)求資源導(dǎo)致線程執(zhí)行能力的喪失荤崇。互斥是對(duì)于資源訪問的不恰當(dāng)安排潮针。尤其是在多線程高并發(fā)的場合术荤,忽略一些東西就會(huì)引來很大的麻煩。如果你可以預(yù)料到問題可能爆發(fā)的點(diǎn)每篷,最好在你的項(xiàng)目開始前就采取措施來衡量線程爭搶瓣戚。及時(shí)線程爭搶不發(fā)發(fā)生,對(duì)于優(yōu)先維護(hù)他們也是很有幫助的焦读。

比如說對(duì)于循環(huán)的優(yōu)化子库,我相信大都數(shù)人循環(huán)寫完實(shí)現(xiàn)功能,一般不會(huì)再去思考如何提高他執(zhí)行循環(huán)的效率以及性能矗晃。我們總在寫循環(huán)仑嗅,總在理所當(dāng)然的感覺循環(huán)不會(huì)出問題,但是卻并沒有以一種高尚的上帝視角來優(yōu)化张症,很多時(shí)候循環(huán)耗時(shí)是可怕的无畔,跟遞歸一般。以下是一段中值濾波的代碼吠冤,有4個(gè)循環(huán)浑彰,在前面適當(dāng)?shù)奶砑雍甓x#pragma omp parallel for能夠多線程的去執(zhí)行這個(gè)循環(huán),雖然只是一個(gè)細(xì)微的步驟拯辙,但是我覺得這個(gè)代碼已經(jīng)往優(yōu)雅處走郭变。

同時(shí)建立合理的預(yù)警火災(zāi)機(jī)制,你可以視情況的嚴(yán)重性添加火災(zāi)等級(jí)水平涯保,通過郵件或者app及時(shí)的抄送給相關(guān)的負(fù)責(zé)人诉濒,類似余監(jiān)視器,把這個(gè)監(jiān)視器打開夕春,你就可以完全可控的掌管大局未荒。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市及志,隨后出現(xiàn)的幾起案子片排,更是在濱河造成了極大的恐慌,老刑警劉巖速侈,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吼具,死亡現(xiàn)場離奇詭異饺著,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門广匙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事〖衣簦” “怎么了?”我有些...
    開封第一講書人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵庙楚,是天一觀的道長篡九。 經(jīng)常有香客問我,道長醋奠,這世上最難降的妖魔是什么榛臼? 我笑而不...
    開封第一講書人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮窜司,結(jié)果婚禮上沛善,老公的妹妹穿的比我還像新娘。我一直安慰自己塞祈,他們只是感情好金刁,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著议薪,像睡著了一般尤蛮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上斯议,一...
    開封第一講書人閱讀 52,475評(píng)論 1 312
  • 那天产捞,我揣著相機(jī)與錄音,去河邊找鬼哼御。 笑死坯临,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的恋昼。 我是一名探鬼主播看靠,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼液肌!你這毒婦竟也來了挟炬?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤嗦哆,失蹤者是張志新(化名)和其女友劉穎谤祖,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吝秕,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡泊脐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了烁峭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖约郁,靈堂內(nèi)的尸體忽然破棺而出缩挑,到底是詐尸還是另有隱情,我是刑警寧澤鬓梅,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布供置,位于F島的核電站,受9級(jí)特大地震影響绽快,放射性物質(zhì)發(fā)生泄漏芥丧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一坊罢、第九天 我趴在偏房一處隱蔽的房頂上張望续担。 院中可真熱鬧,春花似錦活孩、人聲如沸物遇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽询兴。三九已至,卻和暖如春起趾,著一層夾襖步出監(jiān)牢的瞬間诗舰,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來泰國打工训裆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留始衅,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓缭保,卻偏偏與公主長得像汛闸,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子艺骂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容