1、通過哪一個函數,可以把錯誤轉換為異常處理?
A:set_error_handler
B:error_reporting
C:error2exception
D:catch
正確答案:A
答案分析:set_error_handler() 可指定一個回調函數,錯誤發生時,會自動通過指定的回調函數處理。在回調函數中拋出新的異常即可。
2、下列哪個shell函數的描述是正確的?
A:shell函數可以先調用后定義
B:shell函數需使用關鍵字function定義
C:shell函數內的變量可以聲明為局部變量
D:shell函數只能通過return返回值,1是成功,0是失敗
正確答案:C
答案分析:shell函數必須先定義在調用;聲明時,無需使用關鍵字;通過local可以定義函數內的局部變量;shell函數返回值,0是成功,非0是錯誤,其他選項正確
3、下列關于全文檢索技術的說法,不對的是:
A: Solr是新一代的全文檢索組件,它比Lucene的搜索效率高很多,還能支持HTTP的訪問方式,PHP調用Solr也很方便。
B: html' target='_blank'>MySQL中把一個字段建立FULLTEXT索引,就可以實現全文檢索,目前MyISAM和InnoDB的table都支持FULLTEXT索引。
C: Sphinx是一個基于SQL的全文檢索引擎,可以結合MySQL做全文搜索,它可以提供比數據庫本身更專業的搜索功能。
D: Lucene附帶的二元分詞分析器CJKAnalyzer切詞速度很快,能滿足一般的全文檢索需要。
正確答案:A
答案分析: Solr是新一代的全文檢索組件,它基于Lucene,所以說它比Lucene快就是胡扯 :)
4、關于單例模式的說法,錯誤的是?
A:單例模式的目的是確保在全局環境中,一個類只能有一個實例存在
B:單利模式一般要講構造函數設置為 private
C:只需要將構造函數設置為private 即可確保全局中只有一個實例
D:連接數據庫的功能通常用單例模式實現
正確答案:C
答案分析:構造函數設置為private,僅能確保無法通過 new 創建新實例,但仍可以通過 clone、反序列化等方式創建多個實例。
5、正則的引擎表述錯誤的是?
A 正則引擎主要可以分為兩大類:一種是DFA,一種是NFA。
B 一般而論,NFA引擎則搜索更快一些。但是DFA以表達式為主導,更容易操縱,因此一般程序員更偏愛DFA引擎!
C NFA表達式主導,DFA文本主導.
D 可以使用是否支持忽略優先量詞和分組捕獲來判斷引擎類型:支持 NFA,不支持 DFA
正確答案:B
答案分析:正確的說法應該是:一般而論,DFA引擎則搜索更快一些。但是NFA以表達式為主導,更容易操縱,因此一般程序員更偏愛NFA引擎!
6、方框中的正則表達式能與以下哪些選項匹配?
/./123/d/
A. **123
B. ****1234
C. 1234
D.123
正確答案:B
答案分析:本題的要點是理解這個正則表達式的含義——從左往右,首先是零個或多個任意字符(.),跟著是一個星號(),然后是 123,最后是一個數字。因此答案是B。
7、如下關于數據庫的說法,哪個是錯誤的?
A:為了效率數據庫可以有多個讀庫
B:數據庫可以用主從做熱備
C:數據庫不能提供多主多從架構
D: 數據庫主從是通過日志同步的
正確答案:C
答案分析: 數據庫可以提供多主多從架構。
8、下面哪個不是XSS漏洞的修復方式?
A:對參數進行htmlspecialchas過濾
B:對參數使用白名單過濾
C:不允許輸入的內容顯示到瀏覽器
D:禁止在js標簽內輸出用戶輸入的內容
正確答案:A
答案分析:這類過濾可以解決尖括號類型的xss,無法解決js標簽內的xss
9、下列哪一項不是PHP SAPI模式?
A.ISAPI
B.CGI
C.FastCGI
D.RESTFUL APi
正確答案:D
答案分析:A~C是最常用的模式,D是一種接口的組織方式。
10、對一個大文件進行逐行遍歷,如下方法性能較高的是?
A:寫一個實現了IteratorAggregate 接口的類,通過該類使用foreach遍歷。
B:使用file_get_contents 將文件內容一次性載入內存,然后逐行遍歷。
C:通過exec函數,調用shell 工具遍歷
D:使用別人寫的類庫
正確答案:A
答案分析:使用 IteratorAggregate 可將文件打開后通過移動指針的方式逐行遍歷,不受文件大小影響。使用 file_get_contents 處理大文件很容易導致PHP內存溢出;調用exec 會產生額外的進程,影響性能;其他人寫的類庫質量不一定高。
11、如下選項,哪個不是設計模式應該遵循的原則?
A:組合優于繼承
B:針對接口編程
C:盡可能降低耦合
D:盡量使用高性能的語法
正確答案:D
答案分析:設計模式的關注點在于代碼的可維護性和可復用性,D選項不是設計模式關注的要點。
12、下列關于回溯的表達式錯誤的是?
A ab.lmn 匹配 abcdeflmnghijklmn 中的 abcdeflmnghijklmn
B ab.?lmn 匹配 abcdeflmnghijklmn 中的 abcdeflmn
C ab??c 匹配 abcdeflmnghijklmn 中的 abc
D .*lmn 匹配 abcdeflmnghijklmn 中的 abcdeflmn
正確答案:D
答案分析:D是貪婪匹配,所以應該匹配到的結果是abcdeflmnghijklmn
13、函數中如果使用了try catch finally 語法結構,return 應該寫在哪兒?
A:finally 中
B:try 中
C:catch 中
D:任意位置
正確答案:A
答案分析:try 中 return 后 finally 會繼續執行,如果 finally 中也有return,則最終返回值為 finally 中 return 的值。
14、以下關于NOSQL的說法,不對的是:
A: Redis支持字符串、哈希、列表、集合、有序集合等數據結構,目前Redis不支持事務。
B: MongoDB支持CAP定理中的AP,MySQL支持CAP中的CA,全部都支持不可能存在。
C: MongoDB不用先創建Collection的結構就可以直接插入數據,目前MongoDB不支持事務。
D: Memcache既支持TCP協議,也支持UDP協議,我們可以把PHP的Session存放到Memcache中。
正確答案:A
答案分析:Redis支持事務。
15、Innodb 鎖機制說法錯誤的是?
A:Innodb提供了表鎖與行鎖兩種鎖機制
B:Innodb的表鎖所會在表變更的時候觸發
C:Innodb下update時會自動給涉及到的行加上排他鎖,并創建出一個鏡像副本, 此時進行select 時查詢的是鏡像副本的數據
D:Innodb行鎖狀態下讀不受影響,寫會受影響(涉及到的數據)
正確答案:A
16、下列哪個是創建一個每周三01:00~04:00每3分鐘執行執行一次的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時每分鐘執行一次 B:每周三的1時4時每3分鐘執行一次 C:滿足要求 D:每天的1時4時每3分鐘執行一次
17、在拆分之前,系統中很多列表和詳情頁所需的數據是可以通過sql join來完成的。而拆分后,數據庫可能是分布式在不同實例和不同的主機上,join將變得非常麻煩。下面哪種方法不能有效解決這個問題?
A 全局表,系統中所有模塊都可能會依賴到的一些表在各個庫中都保存。
B 字段冗余,“訂單表”中保存“賣家Id”的同時,將賣家的“Name”字段也冗余,這樣查詢訂單詳情的時候就不需要再去查詢“賣家用戶表”。
C 主從復制,將數據庫的讀寫分離。
D 數據同步,定時A庫中的tbl_a表和B庫中tbl_b關聯,可以定時將指定的表做主從同步。
正確答案:C
答案分析:主從復制,將數據庫的讀寫分離。只能擴容讀并發,并不能緩解跨庫join的問題。
18、關于網絡IO模型,下列哪一項是正確的?
A.Select比Epoll更快
B.nginx使用的是select模型
C.apache支持select和epoll兩種方式的切換
D.epoll能支持更大的并發
正確答案:D
答案分析:A epoll更快一些。B nginx使用epoll模型。C apache只支持select
19、PHP執行的時候有如下執行過程:Scanning(Lexing) - Compilation - Execution - Parsing,其含義分別為:
A:將PHP代碼轉換為語言片段(Tokens)、將Tokens轉換成簡單而有意義的表達式、將表達式編譯成Opocdes、順次執行Opcodes
B:將PHP代碼轉換為語言片段(Tokens)、將Tokens轉換成簡單而有意義的表達式、順次執行Opcodes、將表達式編譯成Opocdes
C:將PHP代碼轉換為語言片段(Tokens)、將表達式編譯成Opocdes、順次執行Opcodes、將Tokens轉換成簡單而有意義的表達式
D:將PHP代碼轉換為語言片段(Tokens)、將表達式編譯成Opocdes、將Tokens轉換成簡單而有意義的表達式、順次執行Opcodes
正確答案:C
答案分析:正確答案為C,正確的順序為:Scanning(Lexing)、Parsing、Compilation、Execution
相關推薦:
1、2018 – 2019 年前端 JavaScript 面試題(收藏)
2、前端面試江湖
以上就是本篇文章的全部內容,希望能對大家的學習有所幫助。更多精彩內容大家可以關注 相關教程欄目!??!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答