国产精品色无码视频,国产av毛片影院精品资源,亚洲人成网站77777·c0m,囯产av无码片毛片一级,夜夜操www99视频,美女白嫩胸交在线观看,亚洲a毛片性生活

薈聚奇文、博采眾長、見賢思齊
當前位置:公文素材庫 > 公文素材 > 范文素材 > PHP程序員突破成長瓶頸

PHP程序員突破成長瓶頸

網站:公文素材庫 | 時間:2019-05-29 11:42:50 | 移動端:PHP程序員突破成長瓶頸

PHP程序員突破成長瓶頸

PHP程序員突破成長瓶頸-附學習建議

身邊有幾個做PHP開發(fā)的朋友,因為面試,也接觸到不少的PHP工程師,他們常疑慮自己將來在技術上的成長與發(fā)展,我常給他們一些建議,希望他們能破突自己,有更好的發(fā)展。

PHP工程師面臨成長瓶頸

先明確我所指的PHP工程題,是指畢業(yè)工作后,主要以PHP進行WEB系統(tǒng)的開發(fā),沒有使用其他語言工作過。工作經驗大概在3~4年,普通的WEB系統(tǒng)(百萬級訪問,千成級數據以內或業(yè)務邏輯不是特別復雜)開發(fā)起基本得心應手,沒有什么問題。但他們會這樣的物點:

除了PHP不使用其它的語言,可能會點shell腳本。

對PHP的掌握不精(很多PHP手冊都沒有看完,庫除外)

知識面比較窄(面對需求,除開使用PHP和mysql,不知道其它的解決辦法)

PHP代碼以過程為主,認為面向對象的實現太繞,看不懂

這些PHPer在遇到需要高性能,處理高并發(fā),大量數據的項目或業(yè)務邏輯比較復雜(系統(tǒng)需要解決多領域業(yè)務的問題)時,缺少思路。不能分析問題的本質,技術判斷力比較差,對于問題較快能找出臨時的解決辦法,但常常在不斷臨時性的解決辦法中,系統(tǒng)和自己一步步走向崩潰。那怎么提高自己呢?怎么可以挑戰(zhàn)難度更高的系統(tǒng)?

更高的挑戰(zhàn)在那里?

結合我自己的經驗,我列出一些具體挑戰(zhàn),讓大家先有個感性的認識。

高性能系統(tǒng)的挑戰(zhàn)在哪里?

如何選擇WEB服務器?要不要使用fast-cgi模式

要不要使用反向代理服務?選擇全內存緩存還是硬盤緩存?

是否需要負載均衡?是基于應用層,還是網絡層?如何保證高可靠性?你的PHP代碼性能如何,使用優(yōu)化工具后怎么樣?性能瓶頸在那里?是否需要寫成C的擴展?

用戶訪問有什么特點,是讀多還是寫多?是否需要讀寫分離?

數據如何存儲?寫入速度和讀出速度如何?數據增漲訪問速讀如何變化?

如何使用緩存?怎么樣考慮失效?數據的一致性怎么保證?

高復雜性系統(tǒng)的挑戰(zhàn)在哪里?

能否識別業(yè)務所對應的領域?是一個還是多個?

能否合理對業(yè)務進行抽象,在業(yè)務規(guī)則變化能以很小的代價實現?數據的一致性、安全性可否保證?

是否撐握了面向對象的分析和設計的方法

當我所列出的問題,你都能肯定的回答,我想在技術上你基本已經可能成為架構師了。如何你還不能回答,你需要在以下幾個方向加強。

怎么樣提高,突破瓶頸

如何你還不能回答,你需要在以下幾個方向加強:

分析你所使用的技術其原理和背后運行的機制,這樣可以提高你的技術判斷力,提高你技術方案選擇的正確性;

學習大學期間重要的知識,操作系統(tǒng)原理,數據結構和算法。知道你以前學習都是為了考試,但現在你需要為自己學習,讓自己知其所以然。

重新開始學習C語言,雖然你在大學已經學過。這不僅是因為你可能需要寫PHP擴展,而且還因為,在做C的應用中,有一個時刻關心性能、內存控制、變量生命周期、數據結構和算法的環(huán)境。

學習面向對象的分析與設計,它是解決復雜問題的有效的方法。學習抽象,它是解決復雜問題的唯一之道。

“這么多的東西怎么學,這得學多久呀”?

如果你努力的話,有較好的規(guī)劃,估計需要1~2年的時間,怎么學習的問題,我們后續(xù)再談。

(注:下面是原文作者左文建分享的學習方法)

學習建議

如何有效的學習是一個大問題。自己有些實踐但很零散,不好總結。昨天晚上睡覺前,突然想到了RUP的核心,“以架構為中心,用例驅動,迭代開發(fā)”,借用這個思想,關于有效的學習的方法,可以這樣來表述:

以原理、模型或機制為中心,任務驅動,迭代學習

有點抽象,舉個例子來說明如何學習。

目的:學習如何提高處理性能。

可迭代驅動的任務:通過IP找到所在地域。

這是WEB應用常見的任務,IP數據庫是10左右萬行的記錄。

第一次迭代:不考慮性能的情況下實現功能(通過PHP來實現)

因為無法直接通過KEY(IP)進行查找地域,所以直接放到數據或通過關聯(lián)數組這種簡單的方法都是不行的。思路還是先把數據進行排序,然后再進行查找1.如何通過IP查找?已序的數據,二分查找是最快的。2.如何排序?用庫函數sort當然是可以,但是即然是學習,那還是自己實現快速排序吧。

學習目標:排序算法,查找算法

PHPer數據結構和算法基礎比較差,平時也沒有這方面的任務,自己也不學習,因此這方面的知識很缺乏。但是,編程解決的問題,最終都會歸結到數據結構和對這種數據結構操作的算法。如果數據結構算法常在心中,那遇到問題就能清晰認識到它內在的結構,解決方法就會自然產生。

第二次迭代:優(yōu)化數據的加載與排序

如果做到第一步,那基本上還是不可用,因為數據每次都需要的加載和排序,這樣太耗時間。解決的思路是,數據一次加載排序后,放到每個PHP進程能訪問到的地方。

放到memcache這是大家容易想到問題。其實放到共享內存(EA等加速器都支持)中是更快的方式,因為memcache還多了網絡操作。數據是整體放入到共享內存,還是分塊放入,如何測試性能?如何分析瓶頸所在(xdebug)?在這些問題的驅動下你會學習到

學習目標:檢測、定位、優(yōu)化PHP性能的方法;PHP實現結構對性能的影響。

第三次迭代:編寫PHP的擴展

性能還是上不去,不得不進入C/C++的世界了,不過從此你將不只是PHPer而服務端的全能型工程師,當然這對沒有做過C/C++的同學挑戰(zhàn)是巨大的。我這里無法再簡單來說如何學習C/C++,可以參看《PHP程序員學習C++》

學習目標:C/C++的學習,PHP擴展的編寫

怎么確定需要學習的機制和原理呢?怎么找到驅動學習任務呢?

我對需要學習的東西,都沒有什么概念,怎么回答以上的兩個問題?

從這個技術的定位來找出需要學習的重點,即它怎么做到(機制)的和它為什么能這樣做到(模型或原理)

列出這個技術最常見的應用,做為學習的任務,從簡到難進行實踐。

假如我需要學習j,我對于HTML,CSS有點感性認識

首要我了解到,JS是WEB領域的動態(tài)語言,主要解決網頁的動態(tài)交互的。

那我要學習的要點如下:

JS如何與HTML進行交互(機制)

JS的動態(tài)特性在那里,與其它動態(tài)語言有何區(qū)別?(語言模型)

如果完全自學,找到需要學習的要點(機制、模型、原理)設定學習任務的確不是那么容易把握。如果找到一個有經驗的人來指導你或加一個學習型的團隊,那學習的速度的確會大大提高。

最后,我想說的是:PHP因為簡單而使用,但不能因為它的簡單而限制我們成長!

擴展閱讀:PHP程序員突破成長瓶頸

PHP程序員突破成長瓶頸-附學習建議

身邊有幾個做PHP開發(fā)的朋友,因為面試,也接觸到不少的PHP工程師,他們常疑慮自己將來在技術上的成長與發(fā)展,我常給他們一些建議,希望他們能破突自己,有更好的發(fā)展。PHP工程師面臨成長瓶頸

先明確我所指的PHP工程題,是指畢業(yè)工作后,主要以PHP進行WEB系統(tǒng)的開發(fā),沒有使用其他語言工作過。工作經驗大概在3~4年,普通的WEB系統(tǒng)(百萬級訪問,千成級數據以內或業(yè)務邏輯不是特別復雜)開發(fā)起基本得心應手,沒有什么問題。但他們會這樣的物點:除了PHP不使用其它的語言,可能會點shell腳本。對PHP的掌握不精(很多PHP手冊都沒有看完,庫除外)

知識面比較窄(面對需求,除開使用PHP和mysql,不知道其它的解決辦法)PHP代碼以過程為主,認為面向對象的實現太繞,看不懂

這些PHPer在遇到需要高性能,處理高并發(fā),大量數據的項目或業(yè)務邏輯比較復雜(系統(tǒng)需要解決多領域業(yè)務的問題)時,缺少思路。不能分析問題的本質,技術判斷力比較差,對于問題較快能找出臨時的解決辦法,但常常在不斷臨時性的解決辦法中,系統(tǒng)和自己一步步走向崩潰。那怎么提高自己呢?怎么可以挑戰(zhàn)難度更高的系統(tǒng)?更高的挑戰(zhàn)在那里?

結合我自己的經驗,我列出一些具體挑戰(zhàn),讓大家先有個感性的認識。高性能系統(tǒng)的挑戰(zhàn)在哪里?

如何選擇WEB服務器?要不要使用fast-cgi模式

要不要使用反向代理服務?選擇全內存緩存還是硬盤緩存?

是否需要負載均衡?是基于應用層,還是網絡層?如何保證高可靠性?你的PHP代碼性能如何,使用優(yōu)化工具后怎么樣?性能瓶頸在那里?是否需要寫成C的擴展?

用戶訪問有什么特點,是讀多還是寫多?是否需要讀寫分離?

數據如何存儲?寫入速度和讀出速度如何?數據增漲訪問速讀如何變化?如何使用緩存?怎么樣考慮失效?數據的一致性怎么保證?高復雜性系統(tǒng)的挑戰(zhàn)在哪里?

能否識別業(yè)務所對應的領域?是一個還是多個?

能否合理對業(yè)務進行抽象,在業(yè)務規(guī)則變化能以很小的代價實現?數據的一致性、安全性可否保證?是否撐握了面向對象的分析和設計的方法

當我所列出的問題,你都能肯定的回答,我想在技術上你基本已經可能成為架構師了。如何你還不能回答,你需要在以下幾個方向加強。

怎么樣提高,突破瓶頸

如何你還不能回答,你需要在以下幾個方向加強:

分析你所使用的技術其原理和背后運行的機制,這樣可以提高你的技術判斷力,提高你技術方案選擇的正確性;

學習大學期間重要的知識,操作系統(tǒng)原理,數據結構和算法。知道你以前學習都是為了考試,但現在你需要為自己學習,讓自己知其所以然。

重新開始學習C語言,雖然你在大學已經學過。這不僅是因為你可能需要寫PHP擴展,而且還因為,在做C的應用中,有一個時刻關心性能、內存控制、變量生命周期、數據結構和算法的環(huán)境。

學習面向對象的分析與設計,它是解決復雜問題的有效的方法。學習抽象,它是解決復雜問題的唯一之道。

“這么多的東西怎么學,這得學多久呀”?

如果你努力的話,有較好的規(guī)劃,估計需要1~2年的時間,怎么學習的問題,我們后續(xù)再談。

(注:下面是原文作者左文建分享的學習方法)學習建議

如何有效的學習是一個大問題。自己有些實踐但很零散,不好總結。昨天晚上睡覺前,突然想到了RUP的核心,“以架構為中心,用例驅動,迭代開發(fā)”,借用這個思想,關于有效的學習的方法,可以這樣來表述:以原理、模型或機制為中心,任務驅動,迭代學習有點抽象,舉個例子來說明如何學習。目的:學習如何提高處理性能。

可迭代驅動的任務:通過IP找到所在地域。

這是WEB應用常見的任務,IP數據庫是10左右萬行的記錄。第一次迭代:不考慮性能的情況下實現功能(通過PHP來實現)因為無法直接通過KEY(IP)進行查找地域,所以直接放到數據或通過關聯(lián)數組這種簡單的方法都是不行的。思路還是先把數據進行排序,然后再進行查找

1.如何通過IP查找?已序的數據,二分查找是最快的。

2.如何排序?用庫函數sort當然是可以,但是即然是學習,那還是自己實現快速排序吧。

學習目標:排序算法,查找算法

PHPer數據結構和算法基礎比較差,平時也沒有這方面的任務,自己也不學習,因此這方面的知識很缺乏。但是,編程解決的問題,最終都會歸結到數據結構和對這種數據結構操作的算法。如果數據結構算法常在心中,那遇到問題就能清晰認識到它內在的結構,解決方法就會自然產生。第二次迭代:優(yōu)化數據的加載與排序

如果做到第一步,那基本上還是不可用,因為數據每次都需要的加載和排序,這樣太耗時間。解決的思路是,數據一次加載排序后,放到每個PHP進程能訪問到的地方。

放到memcache這是大家容易想到問題。其實放到共享內存(EA等加速器都支持)中是更快的方式,因為memcache還多了網絡操作。數據是整體放入到共享內存,還是分塊放入,如何測試性能?如何分析瓶頸所在(xdebug)?在這些問題的驅動下你會學習到

學習目標:檢測、定位、優(yōu)化PHP性能的方法;PHP實現結構對性能的影響。

第三次迭代:編寫PHP的擴展

性能還是上不去,不得不進入C/C++的世界了,不過從此你將不只是PHPer而服務端的全能型工程師,當然這對沒有做過C/C++的同學挑戰(zhàn)是巨大的。我這里無法再簡單來說如何學習C/C++,可以參看《PHP程序員學習C++》

學習目標:C/C++的學習,PHP擴展的編寫

怎么確定需要學習的機制和原理呢?怎么找到驅動學習任務呢?我對需要學習的東西,都沒有什么概念,怎么回答以上的兩個問題?

從這個技術的定位來找出需要學習的重點,即它怎么做到(機制)的和它為什么能這樣做到(模型或原理)

列出這個技術最常見的應用,做為學習的任務,從簡到難進行實踐。假如我需要學習Javascript,我對于HTML,CSS有點感性認識

首要我了解到,JS是WEB領域的動態(tài)語言,主要解決網頁的動態(tài)交互的。那我要學習的要點如下:JS如何與HTML進行交互(機制)

JS的動態(tài)特性在那里,與其它動態(tài)語言有何區(qū)別?(語言模型)

如果完全自學,找到需要學習的要點(機制、模型、原理)設定學習任務的確不是那么容易把握。如果找到一個有經驗的人來指導你或加一個學習型的團隊,那學習的速度的確會大大提高。

最后,我想說的是:PHP因為簡單而使用,但不能因為它的簡單而限制我們成長!

友情提示:本文中關于《PHP程序員突破成長瓶頸》給出的范例僅供您參考拓展思維使用,PHP程序員突破成長瓶頸:該篇文章建議您自主創(chuàng)作。

來源:網絡整理 免責聲明:本文僅限學習分享,如產生版權問題,請聯(lián)系我們及時刪除。


PHP程序員突破成長瓶頸》由互聯(lián)網用戶整理提供,轉載分享請保留原作者信息,謝謝!
鏈接地址:http://m.hmlawpc.com/gongwen/695394.html
相關文章