ap接口 php_2018年小米高级 PHP 工程师面试题(模拟考试卷)
點擊藍字關(guān)注我們!每天獲取最新的編程小知識!
源 /?php中文網(wǎng)? ????源 /?www.php.cn
在面試之前多看看有關(guān)公司的面試資料,對之后的面試會很有幫助。今天就給大家?guī)?018年小米高級 PHP 工程師面試題(模擬考試卷),有著一定的參考價值,現(xiàn)在分享給大家,希望能幫助到大家!
(查看原文請點擊本文末尾左下角:
1、通過哪一個函數(shù),可以把錯誤轉(zhuǎn)換為異常處理?
A:set_error_handler
B:error_reporting
C:error2exception
D:catch
正確答案:A
答案分析:set_error_handler() 可指定一個回調(diào)函數(shù),錯誤發(fā)生時,會自動通過指定的回調(diào)函數(shù)處理。在回調(diào)函數(shù)中拋出新的異常即可。
2、下列哪個shell函數(shù)的描述是正確的?
A:shell函數(shù)可以先調(diào)用后定義
B:shell函數(shù)需使用關(guān)鍵字function定義
C:shell函數(shù)內(nèi)的變量可以聲明為局部變量
D:shell函數(shù)只能通過return返回值,1是成功,0是失敗
正確答案:C
答案分析:shell函數(shù)必須先定義在調(diào)用;聲明時,無需使用關(guān)鍵字;通過local可以定義函數(shù)內(nèi)的局部變量;shell函數(shù)返回值,0是成功,非0是錯誤,其他選項正確
3、下列關(guān)于全文檢索技術(shù)的說法,不對的是:
A: Solr是新一代的全文檢索組件,它比Lucene的搜索效率高很多,還能支持HTTP的訪問方式,PHP調(diào)用Solr也很方便。
B: MySQL中把一個字段建立FULLTEXT索引,就可以實現(xiàn)全文檢索,目前MyISAM和InnoDB的table都支持FULLTEXT索引。
C: Sphinx是一個基于SQL的全文檢索引擎,可以結(jié)合MySQL做全文搜索,它可以提供比數(shù)據(jù)庫本身更專業(yè)的搜索功能。
D: Lucene附帶的二元分詞分析器CJKAnalyzer切詞速度很快,能滿足一般的全文檢索需要。
正確答案:A
答案分析: Solr是新一代的全文檢索組件,它基于Lucene,所以說它比Lucene快就是胡扯 :)
4、關(guān)于單例模式的說法,錯誤的是?
A:單例模式的目的是確保在全局環(huán)境中,一個類只能有一個實例存在
B:單利模式一般要講構(gòu)造函數(shù)設(shè)置為 private
C:只需要將構(gòu)造函數(shù)設(shè)置為private 即可確保全局中只有一個實例
D:連接數(shù)據(jù)庫的功能通常用單例模式實現(xiàn)
正確答案:C
答案分析:構(gòu)造函數(shù)設(shè)置為private,僅能確保無法通過 new 創(chuàng)建新實例,但仍可以通過 clone、反序列化等方式創(chuàng)建多個實例。
5、正則的引擎表述錯誤的是?
A 正則引擎主要可以分為兩大類:一種是DFA,一種是NFA。
B 一般而論,NFA引擎則搜索更快一些。但是DFA以表達式為主導(dǎo),更容易操縱,因此一般程序員更偏愛DFA引擎!
C NFA表達式主導(dǎo),DFA文本主導(dǎo).
D 可以使用是否支持忽略優(yōu)先量詞和分組捕獲來判斷引擎類型:支持 NFA,不支持 DFA
正確答案:B
答案分析:正確的說法應(yīng)該是:一般而論,DFA引擎則搜索更快一些。但是NFA以表達式為主導(dǎo),更容易操縱,因此一般程序員更偏愛NFA引擎!
6、方框中的正則表達式能與以下哪些選項匹配?
/.*\123\d/
A. **123
B. ****1234
C. 1234
D.123
正確答案:B
答案分析:本題的要點是理解這個正則表達式的含義——從左往右,首先是零個或多個任意字符(.),跟著是一個星號(*),然后是 123,最后是一個數(shù)字。因此答案是B。
7、如下關(guān)于數(shù)據(jù)庫的說法,哪個是錯誤的?
A:為了效率數(shù)據(jù)庫可以有多個讀庫
B:數(shù)據(jù)庫可以用主從做熱備
C:數(shù)據(jù)庫不能提供多主多從架構(gòu)
D: 數(shù)據(jù)庫主從是通過日志同步的
正確答案:C
答案分析: 數(shù)據(jù)庫可以提供多主多從架構(gòu)。
8、下面哪個不是XSS漏洞的修復(fù)方式?
A:對參數(shù)進行htmlspecialchas過濾
B:對參數(shù)使用白名單過濾
C:不允許輸入的內(nèi)容顯示到瀏覽器
D:禁止在js標(biāo)簽內(nèi)輸出用戶輸入的內(nèi)容
正確答案:A
答案分析:這類過濾可以解決尖括號類型的xss,無法解決js標(biāo)簽內(nèi)的xss
9、下列哪一項不是PHP SAPI模式?
A.ISAPI
B.CGI
C.FastCGI
D.RESTFUL APi
正確答案:D
答案分析:A~C是最常用的模式,D是一種接口的組織方式。
10、對一個大文件進行逐行遍歷,如下方法性能較高的是?
A:寫一個實現(xiàn)了IteratorAggregate 接口的類,通過該類使用foreach遍歷。
B:使用file_get_contents 將文件內(nèi)容一次性載入內(nèi)存,然后逐行遍歷。
C:通過exec函數(shù),調(diào)用shell 工具遍歷
D:使用別人寫的類庫
正確答案:A
答案分析:使用 IteratorAggregate 可將文件打開后通過移動指針的方式逐行遍歷,不受文件大小影響。使用 file_get_contents 處理大文件很容易導(dǎo)致PHP內(nèi)存溢出;調(diào)用exec 會產(chǎn)生額外的進程,影響性能;其他人寫的類庫質(zhì)量不一定高。
11、如下選項,哪個不是設(shè)計模式應(yīng)該遵循的原則?
A:組合優(yōu)于繼承
B:針對接口編程
C:盡可能降低耦合
D:盡量使用高性能的語法
正確答案:D答案分析:設(shè)計模式的關(guān)注點在于代碼的可維護性和可復(fù)用性,D選項不是設(shè)計模式關(guān)注的要點。
12、下列關(guān)于回溯的表達式錯誤的是?
A ab.lmn 匹配 abcdeflmnghijklmn 中的 abcdeflmnghijklmn
B ab.?lmn 匹配 abcdeflmnghijklmn 中的 abcdeflmn
C ab??c 匹配 abcdeflmnghijklmn 中的 abc
D .*lmn 匹配 abcdeflmnghijklmn 中的 abcdeflmn
正確答案:D
答案分析:D是貪婪匹配,所以應(yīng)該匹配到的結(jié)果是abcdeflmnghijklmn
13、函數(shù)中如果使用了try catch finally 語法結(jié)構(gòu),return 應(yīng)該寫在哪兒?
A:finally 中
B:try 中
C:catch 中
D:任意位置
正確答案:A
答案分析:try 中 return 后 finally 會繼續(xù)執(zhí)行,如果 finally 中也有return,則最終返回值為 finally 中 return 的值。
14、以下關(guān)于NOSQL的說法,不對的是:
A: Redis支持字符串、哈希、列表、集合、有序集合等數(shù)據(jù)結(jié)構(gòu),目前Redis不支持事務(wù)。
B: MongoDB支持CAP定理中的AP,MySQL支持CAP中的CA,全部都支持不可能存在。
C: MongoDB不用先創(chuàng)建Collection的結(jié)構(gòu)就可以直接插入數(shù)據(jù),目前MongoDB不支持事務(wù)。
D: Memcache既支持TCP協(xié)議,也支持UDP協(xié)議,我們可以把PHP的Session存放到Memcache中。
正確答案:A
答案分析:Redis支持事務(wù)。
15、Innodb 鎖機制說法錯誤的是?
A:Innodb提供了表鎖與行鎖兩種鎖機制
B:Innodb的表鎖所會在表變更的時候觸發(fā)
C:Innodb下update時會自動給涉及到的行加上排他鎖,并創(chuàng)建出一個鏡像副本, 此時進行select 時查詢的是鏡像副本的數(shù)據(jù)
D:Innodb行鎖狀態(tài)下讀不受影響,寫會受影響(涉及到的數(shù)據(jù))
正確答案:A
16、下列哪個是創(chuàng)建一個每周三01:00~04:00每3分鐘執(zhí)行執(zhí)行一次的crontab指令?
A: 1,4 3 /bin/bash /home/sijiaomao/ok.sh
B:/3 1,4 3 /bin/bash /home/sijiaomao/ok.sh
C:/3 1-4 3 /bin/bash /home/sijiaomao/ok.sh
D:/3 1-4 ?* /bin/bash /home/sijiaomao/ok.sh
正確答案:C
答案分析:A:每周三的1時4時每分鐘執(zhí)行一次 B:每周三的1時4時每3分鐘執(zhí)行一次 C:滿足要求 D:每天的1時4時每3分鐘執(zhí)行一次
17、在拆分之前,系統(tǒng)中很多列表和詳情頁所需的數(shù)據(jù)是可以通過sql join來完成的。而拆分后,數(shù)據(jù)庫可能是分布式在不同實例和不同的主機上,join將變得非常麻煩。下面哪種方法不能有效解決這個問題?
A 全局表,系統(tǒng)中所有模塊都可能會依賴到的一些表在各個庫中都保存。
B 字段冗余,“訂單表”中保存“賣家Id”的同時,將賣家的“Name”字段也冗余,這樣查詢訂單詳情的時候就不需要再去查詢“賣家用戶表”。
C 主從復(fù)制,將數(shù)據(jù)庫的讀寫分離。
D 數(shù)據(jù)同步,定時A庫中的tbl_a表和B庫中tbl_b關(guān)聯(lián),可以定時將指定的表做主從同步。
正確答案:C
答案分析:主從復(fù)制,將數(shù)據(jù)庫的讀寫分離。只能擴容讀并發(fā),并不能緩解跨庫join的問題。
18、關(guān)于網(wǎng)絡(luò)IO模型,下列哪一項是正確的?
A.Select比Epoll更快
B.nginx使用的是select模型
C.apache支持select和epoll兩種方式的切換
D.epoll能支持更大的并發(fā)
正確答案:D
答案分析:A epoll更快一些。B nginx使用epoll模型。C apache只支持select
19、PHP執(zhí)行的時候有如下執(zhí)行過程:Scanning(Lexing) - Compilation - Execution - Parsing,其含義分別為:
A:將PHP代碼轉(zhuǎn)換為語言片段(Tokens)、將Tokens轉(zhuǎn)換成簡單而有意義的表達式、將表達式編譯成Opocdes、順次執(zhí)行Opcodes
B:將PHP代碼轉(zhuǎn)換為語言片段(Tokens)、將Tokens轉(zhuǎn)換成簡單而有意義的表達式、順次執(zhí)行Opcodes、將表達式編譯成Opocdes
C:將PHP代碼轉(zhuǎn)換為語言片段(Tokens)、將表達式編譯成Opocdes、順次執(zhí)行Opcodes、將Tokens轉(zhuǎn)換成簡單而有意義的表達式
D:將PHP代碼轉(zhuǎn)換為語言片段(Tokens)、將表達式編譯成Opocdes、將Tokens轉(zhuǎn)換成簡單而有意義的表達式、順次執(zhí)行Opcodes
正確答案:C
答案分析:正確答案為C,正確的順序為:Scanning(Lexing)、Parsing、Compilation、Execution
-END-
聲明:本文選自「?php中文網(wǎng)?」,搜索「 phpcnnew 」即可關(guān)注!
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅持創(chuàng)作打卡瓜分現(xiàn)金大獎總結(jié)
以上是生活随笔為你收集整理的ap接口 php_2018年小米高级 PHP 工程师面试题(模拟考试卷)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Windows SDK编程 API入门系
- 下一篇: Windows API入门系列之五 -一