第一篇:中高級PHP程序員測試題
中高級PHP工程師筆試題
1.寫出php的魔術方法,并做簡單描述
2.MySQL的存儲引擎MyISAM和innoDB的區別
3.大數據量怎么解決,如何避免單點故障
4.后端負載均衡實現方法:
5.PHP靜態變量作用域和內部實現原理。
6.HTTP協議狀態碼分類及簡述
7.Linux常用命令及功能
8.寫出代碼輸出結果,并給出原因(c語言)
int main(void)
{
printf(“%d”);
return 0;
}
9.以下代碼做了什么工作(javascript)
Array.prototype.strip=function(){
if(this.length<2)
return [this[0]]||[];
var arr=[];
for(var i=0;i arr.push(this.splice(i--,1)); for(var j=0;j if(this[j]==arr[arr.length-1]){ this.splice(j--,1); } } } return arr; } var arr=[“abc”,85,“abc”,85,8,8,1,2,5,4,7,8];alert(arr.strip()); 答題人:答題時間: 初級PHP工程師筆試題 1.2.3.4.請解釋一下什么oop,具有哪些特征,基本原則是什么 請說一下接口和類的區別 請列舉一下常見的設計模式及特點 請問session怎么實現,結合項目談談都是怎么使用的5.請列舉常見的sql優化方式并重點闡述 6.寫出提取網頁中url的正則表達式 7.請講下代理和反向代理的區別 8.版本控制用過什么工具 9.實際開發中用過什么開發框架,實現了哪些功能 答題人:答題日期: 網站建設定制專家www.tmdps.cn 中高級PHP程序員應該掌握哪些技術? 中級PHP程序員 1.Linux 能夠流暢的使用Shell腳本來完成很多自動化的工作;awk/sed/perl 也操作的不錯,能夠完成很多文本處理和數據統計等工作;基本能夠安裝大 部分非特殊的Linux程序(包括各種庫、包、第三方依賴等等,比如MongoDB/Redis/Sphinx/Luncene/SVN之類的);了解基 本的Linux服務,知道如何查看Linux的性能指標數據,知道基本的Linux下面的問題跟蹤等 2.Nginx: 在第一階段的基礎上面,了解復雜一些的Nginx配置;包括多核配置、events、proxy_pass,sendfile/tcp_*配置,知道超 時等相關配置和性能影響;知道nginx除了web server,還能夠承擔代理服務器、反向靜態服務器等配置;知道基本的nginx配置調優;知道如 何配置權限、編譯一個nginx擴展到nginx;知道基本的nginx運行原理(master/worker機制,epoll),知道為什么nginx 性能比apache性能好等知識; 3.MySQL/MongoDB: 在第一階段的基礎上面,在MySQL開發方面,掌握很多小技巧,包括常規SQL優化(group by/order by/rand優化等);除了能夠搭 建MySQL,還能夠冷熱備份MySQL數據,還知道影響innodb/myisam性能的配置選項(比如key_buffer/query_cache /sort_buffer/innodb_buffer_pool_size/innodb_flush_log_at_trx_commit等),也知 道這些選項配置成為多少值合適;另外也了解一些特殊的配置選項,比如 知道如何搭建mysql主從同步的環境,知道各個binlog_format的區 別;知道MySQL的性能追查,包括slow_log/explain等,還能夠知道基本的索引建立處理等知識;原理方面了解基本的MySQL的架構(Server+存儲引擎),知道基本的InnoDB/MyISAM索引存儲結構和不同(聚簇索引,B樹);知道基本的InnoDB事務處理機制;了解大 部分MySQL異常情況的處理方案(或者知道哪兒找到處理方案)。條件允許的情況,建議了解一下NoSQL的代表MongoDB數據庫,順便對比跟 MySQL的差別,同事能夠在合適的應用場景安全謹慎的使用MongoDB,知道基本的PHP與MongoDB的結合開發。 4.Redis/Memcached: 在大部分中型系統里面一定會涉及到緩存處理,所以一定要了解基本的緩存;知道Memcached和Redis的異同和應用場景,能夠獨立安 裝 Redis/Memcached,了解Memcahed的一些基本特性和限制,比如最大的value值,知道PHP跟他們的使用結合;Redis了解 基本工作原理和使用,了解常規的數據類型,知道什么場景應用什么類型,了解Redis的事務等等。原理部分,能夠大概了解Memcached的內存結構(slab機制),redis就了解常用數據類型底層實現存儲結構(SDS/鏈表/SkipList/HashTable)等等,順便了解一下Redis 的事務、RDB、AOF等機制更好 網站建設定制專家www.tmdps.cn 5.PHP: 除了第一階段的能力,安裝配置方面能夠隨意安裝PHP和各種第三方擴展的編譯安裝配置;了解php-fpm的大部分配置選項和含義(如 max_requests/max_children/request_terminate_timeout之類的影響性能的配置),知道mod_php /fastcgi的區別;在PHP方面已經能夠熟練各種基礎技術,還包括各種深入些的PHP,包括對PHP面向對象的深入理解/SPL/語法層面的特殊特 性比如反射之類的;在框架方面已經閱讀過最少一個以上常規PHP MVC框架的代碼了,知道基本PHP框架內部實現機制和設計思想;在PHP開發中已經能 夠熟練使用常規的設計模式來應用開發(抽象工廠/單例/觀察者/命令鏈/策略/適配器 等模式);建議開發自己的PHP MVC框架來充分讓開發自由化,讓自己深入理解MVC模式,也讓自己能夠在業務項目開發里快速升級;熟悉PHP的各種代碼優化方法,熟悉大部分PHP安全方面問題的解決處理;熟悉基本的 PHP執行的機制原理(Zend引擎/擴展基本工作機制); 6.系統設計: 能夠設計大部分中型系統的網站架構、數據庫、基本PHP框架選型;性能測試排查處理等;能夠完成類似:瀏覽 器-> CDN(Squid)-> Nginx+PHP-> 緩存-> 數據庫 結構網站的基本設計開發維護;能夠支撐 每天數百萬到千萬流量基本網站的開發維護工作; 高級PHP程序員 重點:除了基本的LNMP程序,還能夠在某個方向或領域有深入學習。(縱深維度發展) 目標:除了能夠完成基本的PHP業務開發,還能夠解決大部分深入復雜的技術問題,并且可以獨立設計完成中大型的系統設計和開發工作;自己能夠獨立hold深入某個技術方向,在這塊比較專業。(比如在MySQL、Nginx、PHP、Redis等等任一方向深入研究) 1.Linux: 除了第二階段的能力,在Linux下面除了常規的操作和性能監控跟蹤,還能夠使用很多高級復雜的命令完成工作(watch/tcpdump/starce /ldd/ar等);在shell腳本方面,已經能夠編寫比較復雜的shell腳本(超過500行)來協助完成很多包括備份、自動化處理、監控等工作的 shell;對awk/sed/perl 等應用已經如火純青,能夠隨意操作控制處理文本統計分析各種復雜格式的數據;對Linux內部機制有一些了解,對內核模塊加載,啟動錯誤處理等等有個基本的處理;同時對一些其他相關的東西也了解,比如NFS、磁盤管理等等; 2.Nginx: 在第二階段的基礎上面,已經能夠把Nginx操作的很熟練,能夠對Nginx進行更深入的運維工作,比如監控、性能優化,復雜問題處理等等;看個人興趣,更多方面可以考慮側重在關于Nginx工作原理部分的深入學習,主要表現在閱讀源碼開始,比如具體的master/worker工作機制,Nginx內部 的事件處理,內存管理等等;同時可以學習Nginx擴展的開發,可以定制一些自己私有的擴展;同時可以對Nginx+Lua有一定程度的了解,看看網站建設定制專家www.tmdps.cn 是否可 以結合應用出更好模式;這個階段的要求是對Nginx原理的深入理解,可以考慮成為Nginx方向的深入專業者。 3.MySQL/MongoDB: 在第二階段的基礎上面,在MySQL應用方面,除了之前的基本SQL優化,還能夠在完成一些復雜操作,比如大批量數據的導入導出,線上大批量數據的更改表 結構或者增刪索引字段等等高危操作;除了安裝配置,已經能夠處理更多復雜的MySQL的問題,比如各種問題的追查,主從同步延遲問題的解決、跨機房同步數 據方案、MySQL高可用架構等都有涉及了解;對MySQL應用層面,對MySQL的核心關鍵技術比較熟悉,比如事務機制(隔離級別、鎖等)、對觸發器、分區等技術有一定了解和應用;對MySQL性能方面,有包括磁盤優化(SAS遷移到SSD)、服務器優化(內存、服務器本身配置)、除了二階段的其他核心 性能優化選項(innodb_log_buffer_size/back_log/table_open_cache /thread_cache_size/innodb_lock_wait_timeout等)、連接池軟件選擇應用,對show *(show status/show profile)類的操作語句有深入了解,能夠完成大部分的性能問題追查;MySQL備份技術的深入熟悉,包括災備 還原、對Binlog的深入理解,冷熱備份,多IDC備份等;在MySQL原理方面,有更多了解,比如對MySQL的工作機制開始閱讀部分源碼,比如對主 從同步(復制)技術的源碼學習,或者對某個存儲引擎(MyISAM/Innodb/TokuDB)等等的源碼學習理解,如果條件允許,可以參考CSV引擎 開發自己簡單的存儲引擎來保存一些數據,增強對MySQL的理解;在這個過程,如果自己有興趣,也可以考慮往DBA方向發展。MongoDB層面,可以考 慮比如說在寫少讀多的情況開始在線上應用MongoDB,或者是做一些線上的數據分析處理的操作,具體場景可以按照工作來,不過核心是要更好的深入理解 RMDBS和NoSQL的不同場景下面的應用,如果條件或者興趣允許,可以開始深入學習一下MongoDB的工作機制。 4.Redis/Memcached: 在第二階段的基礎上面,能夠更深入的應用和學習。因為Memcached不是特別復雜,建議可以把源碼進行閱讀,特別是內存管理部分,方便深入理 解;Redis部分,可以多做一些復雜的數據結構的應用(zset來做排行榜排序操作/事務處理用來保證原子性在秒殺類場景應用之類的使用操作);多涉及 aof等同步機制的學習應用,設計一個高可用的Redis應用架構和集群;建議可以深入的學習一下Redis的源碼,把在第二階段積累的知識都可以應用 上,特別可以閱讀一下包括核心事件管理、內存管理、內部核心數據結構等充分學習了解一下。如果興趣允許,可以成為一個Redis方面非常專業的使用者。 5.PHP: 作為基礎核心技能,我們在第二階段的基礎上面,需要有更深入的學習和應用。從基本代碼應用上面來說,能夠解決在PHP開發中遇到95%的問題,了解大部分 PHP的技巧;對大部分的PHP框架能夠迅速在一天內上手使用,并且了解各個主流PHP框架的優缺點,能夠迅速方便項目開發中做技術選型;在配置方面,除 了常規第二階段會的知識,會了解一些比較偏門的配置選項(php auto_prepend_file/auto_append_file),包括擴展中 的一些復雜高級配置和原理(比如memcached擴展配置中的memcache.hash_strategy、apc擴展配置中的 apc.mmap_file_mask/apc.slam_defense/apc.file_update_protection之類的);對php的 工網站建設定制專家www.tmdps.cn 作機制比較了解,包括php-fpm工作機制(比如php-fpm在不同配置機器下面開啟進程數量計算以及原理),對zend引擎有基本熟悉(vm/gc/stream處理),閱讀過基本的PHP內核源碼(或者閱讀過相關文章),對PHP內部機制的大部分核心數據結構(基礎類型/Array /Object)實現有了解,對于核心基礎結構(zval/hashtable/gc)有深入學習了解;能夠進行基本的PHP擴展開發,了解一些擴展開發 的中高級知識(minit/rinit等),熟悉php跟apache/nginx不同的通信交互方式細節(mod_php/fastcgi);除了開發 PHP擴展,可以考慮學習開發Zend擴展,從更底層去了解PHP。 6.C/C++: 在第二階段基礎上面,能夠在C/C++語言方面有更深入的學習了解,能夠完成中小型C/C++系統的開發工作;除了基本第二階段的基礎C/C++語法和數 據結構,也能夠學習一些特殊數據結構(b-tree/rb-tree/skiplist/lsm-tree/trie-tree等)方便在特殊工作中需 求;在系統編程方面,熟悉多進程、多線程編程;多進程情況下面了解大部分多進程之間的通信方式,能夠靈活選擇通信方式(共享內存/信號量/管道等);多線 程編程能夠良好的解決鎖沖突問題,并且能夠進行多線程程序的開發調試工作;同時對網絡編程比較熟悉,了解多進程模型/多線程模型/異步網絡IO模型的差別 和選型,熟悉不同異步網絡IO模型的原理和差異(select/poll/epoll/iocp等),并且熟悉常見的異步框架(ACE/ICE /libev/libevent/libuv/Boost.ASIO等)和使用,如果閑暇也可以看看一些國產自己開發的庫(比如muduo);同時能夠設 計好的高并發程序架構(leader-follow/master-worker等);了解大部分C/C++后端Server開發中的問題(內存管理、日 志打印、高并發、前后端通信協議、服務監控),知道各個后端服務RPC通信問題(struct/http/thirft/protobuf等);能夠更熟 絡的使用GCC和GDB來開發編譯調試程序,在線上程序core掉后能夠迅速追查跟蹤解決問題;通用模塊開發方面,可以積累或者開發一些通用的工具或庫(比如異步網絡框架、日志庫、內存池、線程池等),不過開發后是否應用要謹慎,省的埋坑去追bug; 7.前端: 深入了解HTTP協議(包括各個細致協議特殊協議代碼和背后原因,比如302靜態文件緩存了,502是nginx后面php掛了之類的);除了之前的前端 方面的各種框架應用整合能力,前端方面的學習如果有興趣可以更深入,表現形式是,可以自己開發一些類似jQuery的前端框架,或者開發一個富文本編輯器 之類的比較瑣碎考驗JavaScript功力; 8.其他領域語言學習: 在基礎的PHP/C/C++語言方面有基本積累,建議在當前階段可以嘗試學習不同的編程語言,看個人興趣愛好,腳本類語言可以學學 Python /Ruby 之類的,函數式編程語言可以試試 Lisp/Haskell/Scala/Erlang 之類的,靜態語言可以試試 Java /Golang,數據統計分析可以了解了解R語言,如果想換個視角做后端業務,可以試試 Node.js還有前面提到的跟Nginx結合的 Nginx_Lua等。學習不同的語言主要是提升自己的視野和解決問題手段的差異,比如會了解除了進程/線程,還有輕量級協程;比如在跨機器通信場景下 面,Erlang的解決方案簡單的驚人;比如在不想選擇C/C++的情況下,還有類似高效的Erlang/Golang可用等等;主要是提升視野。網站建設定制專家www.tmdps.cn 9.其他專業方向學習: 在本階段里面,會除了基本的LNMP技能之外,會考慮一些其他領域知識的學習,這些都是可以的,看個人興趣和長期的目標方向。目前情況能夠選擇的領域比較 多,比如、云計算(分布式存儲、分布式計算、虛擬機等),機器學習(數據挖掘、模式識別等,應用到統計、個性化推薦),自然語言處理(中文分詞等),搜索 引擎技術、圖形圖像、語音識別等等。除了這些高大上的,也有很多偏工程方面可以學習的地方,比如高性能系統、移動開發(Android/IOS)、計算機 安全、嵌入式系統、硬件等方向。 10.系統設計: 系統設計在第二階段的基礎之上,能夠應用掌握的經驗技能,設計出比較復雜的中大型系統,能夠解決大部分線上的各種復雜系統的問題,完成類似 瀏覽 器-> CDN-> 負載均衡->接入層-> Nginx+PHP-> 業務緩存-> 數據 庫-> 各路復雜后端RPC交互(存儲后端、邏輯后端、反作弊后端、外部服務)-> 更多后端 醬紫的復雜業務;能夠支撐每天數千萬到數 億流量網站的正常開發維護工作。 **的個人簡歷 個人資料 姓名: **電子郵件: ******@qq.com 名族: 漢出生日期: 1991/1/3 學歷: 本科居住地址: 深圳福田 性別: 男手機號碼: 186***7739 4求職意向 到崗時間:即時 期望職位:php程序員 工作性質:全職 專業技能 1、熟練掌握PHP,HTML,DIV+CSS,Javascript,Ajax,jQuery等Web開發技術。 2、熟練使用PDO、MySQL方式操作MySQL數據庫系統,熟悉MySQL事物及存儲過程。 3、熟悉HTML,DIV+CSS前臺頁面技術和XML的使用。 4、熟悉網頁靜態化、Smarty緩存,thinkPHP緩存,掌握Web防SQL注入。 5、孰悉MVC架構開發思想模式,熟練使用Smarty模板,ThinkPHP框架,ZendFramework框架。 6、熟練掌握Zend Studio, Dreamweaver,Notepad++, EclipsePHP等常用Web開發工具; 7、了解Linux基本操作。 項目經驗? 項目一 項目名稱:地球新聞網 軟件環境: 開發工具: 項目描述: linux+apache+mysql+php Zend Studio 1.該項目是一個集各種新聞的網站。2.前臺采用div+css,javascript等 技術進行頁面布局,Javascript和Jquery技術制作下拉菜單、表單驗證、復選框等效果。3.后臺采用全面向對象開發,良好的運用了MVC三層架 構模式。 責任描述:獨立開發 項目體會:通過開發這次項目,使我對制作一個網站有了一個全面的了解,也同時增 加了我的技術能力;通過該網站使我了解只有想不到,沒有做不到。同時 也想到在這個發展迅速的社會,我們只有不斷努力學習新的技術才能滿足 客戶的要求。 ? 項目二 項目名稱:聚焦購物商城 軟件環境: 開發工具: 項目描述: windows+apache+mysql+php Zend Studio 8.0 該項目是一個大型的網站商城,采用thinkPHP主流框架開發。 前臺包括:商品列表、搜索、商品詳細頁、注冊、登錄、購物車、會員 中心、評論等。后臺有:商品管理、訂單管理、會員管理、商家管理等。 滿足用戶購物流程的各種需求 責任描述: 負責完成了MySQL數據表、字段、索引的分析與創建,主頁的圖片輪換,商品詳細 頁,購物車模塊,登錄注冊等功能,以及后臺商品管理模塊。 項目體會:通過此次項目的實戰,讓我對thinkPHP的掌握更加深刻,同時給我感覺的是使用模板的開發速度之快,更實現的HTML的代碼與PHP代碼的分 離,使得擁有更好的擴展以及維護。 工作經驗 2012/8—2013/4業聚醫療器械(深圳)有限公司技術員 工作感想 之前的公司主要是生產和研發介入性醫療器械的一家公司,我的工作任務主要從事公司導管支架的研發,研發多種不同尺寸型號的球囊擴張導管。在我的工作中,使我學到了很多東西,讓我變得更加細心,做事情更加注重細節,更有時間觀念等等。 教育經歷 ? 2013/4—2013/8達內PHP培訓php程序員主要學習了:linux系統常用操作命令,HTML/CSS,Javascript/Jquery/Ajax的前臺技術,學習了用Linux系統和Windows系統開發項目,學習了Smarty模板,Zendframework,thinkPHP框架的使用,學習了DEDECMS二次開發。 在學習的過程中,自己獨立完成了一個小項目《地球新聞網》,和同學合作完 成了一個商城網站《聚焦購物》,通過這兩個項目的實戰,為我以后的工作打 下了堅實的基礎。 ? 2008/9—2012/7湖北信息工程專修學院電子商務本科主要學習了:計算機應用基礎,管理學,電子商務概論,網頁設計與制作,電子商務法,商務溝通與談判及商業職業道德專業課程,安全教育等課程。 通過這些課程的學習,使我對電子商務系統建設與管理打下了良好的基礎,同時也使我擁有較強的溝通能力和職業道德水準。 個人評價 1.本人細心,樂觀積極心態,吃苦耐勞,勇于挑戰自我,熱愛學習,喜歡總結; 2.具備良好的團隊精神,能很好的與團隊協作開發,有良好的溝通能力,喜歡交朋友; 3.性格開朗,陽光,喜歡籃球,游泳,羽毛球等體育運動。 北京融入網絡科技有限公司 PHP工程師面試題 1、請寫一個實現中文字串截取無亂碼的方法。(超出部分用’…..’替換)。 2、ThinkPHP框架中,下列定義有什么不同? $userModel = M(“User”); $userMode l= D(“User”); 3、如果讓你模擬登陸微信公眾平臺并設置微信的開發模式中的URL和Token,你會如何去做?(思路或代碼皆可)。 4、談談對你對PHP的認識或你擅長的技術。 5、假設有一個博客系統,數據庫存儲采用mysql,用戶數量為1000萬,預計文章總數為10億,每天有至少10萬的更新量,每天訪問量為5000萬,對數據庫的讀寫操作的比例超過10:1,你如何設計該系統,以確保其系統高效,穩定的運行? 提示:可以從數據庫設計,系統框架,及網絡架構方面進行描述,可以自由發揮。 6、你經常去那些網站?有沒有自己的博客或git 開源項目。 / 1第二篇:初級PHP程序員測試題
第三篇:中高級PHP程序員應該掌握哪些技術[最終版]
第四篇:PHP程序員
第五篇:PHP程序員面試題