PHP的面試題集,附我的答案和分析(一)
更新時間:2006年11月19日 00:00:00 作者:
面試題1
1、用PHP打印出前一天的時間格式是2006-5-10 22:21:21
2、echo(),print(),print_r()的區(qū)別
3、能夠使HTML和PHP分離開使用的模板
4、如何實現(xiàn)PHP、JSP交互?
5、使用哪些工具進行版本控制?
6、如何實現(xiàn)字符串翻轉?
7、優(yōu)化MYSQL數(shù)據(jù)庫的方法。
8、談談事務處理
9、apache+mysql+php實現(xiàn)最大負載的方法
10、實現(xiàn)中文字串截取無亂碼的方法。
答案:
1.echo date('Y-m-d H:i:s', strtotime('-1 day'));
2.echo是語言結構,無返回值;print功能和echo基本相同,不同的是print是函數(shù),有返回值;print_r是遞歸打印,用于輸出數(shù)組對象
3.so much,其實PHP本身就是一種模版引擎,我用過的是smarty,常見的還有PHPLib,FastTemplate,Savant這里有個模板引擎列表:http://www.sitepoint.com/forums/showthread.php?t=123769
4.題目有點含糊不清,SOAP,XML_RPC,Socket function,CURL都可以實現(xiàn)這些,如果是考PHP和Java的整合,PHP內置了這種機制(如果考PHP和.NET的整合,也可以這么回答),例如$foo = new Java('java.lang.System');
5.CVS和SVN,SVN號稱下一代CVS,功能強大,不過CVS是老牌,市占率很高.我一直用SVN,題目是問用什么工具,呃,這個可能需要這么回答:CVS Server on Apache作服務端,WinCVS作客戶端;Subversion on Apache/DAV 做服務端,TortoiseSVN做客戶端,或者Subclipse做客戶端.
6.用strrev函數(shù)唄,不準用PHP內置的就自己寫:
function strrev($str)
{
$len=strlen($str);
$newstr = '';
for($i=$len;$i>=0;$i--)
{
$newstr .= $str{$i};
}
return $newstr;
}
7.高考政治題,把你知道的知識點都寫上吧.我的答案:
(1).數(shù)據(jù)庫設計方面,這是DBA和Architect的責任,設計結構良好的數(shù)據(jù)庫,必要的時候,去正規(guī)化(英文是這個:denormalize,中文翻譯成啥我不知道),允許部分數(shù)據(jù)冗余,避免JOIN操作,以提高查詢效率
(2).系統(tǒng)架構設計方面,表散列,把海量數(shù)據(jù)散列到幾個不同的表里面.快慢表,快表只留最新數(shù)據(jù),慢表是歷史存檔.集群,主服務器Read & write,從服務器read only,或者N臺服務器,各機器互為Master
(3).(1)和(2)超越PHP Programmer的要求了,會更好,不會沒關系.檢查有沒有少加索引
(4).寫高效的SQL語句,看看有沒有寫低效的SQL語句,比如生成笛卡爾積的全連接啊,大量的Group By和order by,沒有l(wèi)imit等等.必要的時候,把數(shù)據(jù)庫邏輯封裝到DBMS端的存儲過程里面.緩存查詢結果,explain每一個sql語句
(5).所得皆必須,只從數(shù)據(jù)庫取必需的數(shù)據(jù),比如查詢某篇文章的評論數(shù),select count(*) ... where article_id = ? 就可以了,不要先select * ... where article_id = ?然后msql_num_rows.
只傳送必須的SQL語句,比如修改文章的時候,如果用戶只修改了標題,那就update ... set title = ? where article_id = ?不要set content = ?(大文本)
(6).必要的時候用不同的存儲引擎.比如InnoDB可以減少死鎖.HEAP可以提高一個數(shù)量級的查詢速度.
8.如同是個編程語言都會有答應Hello World的例子一樣,是本數(shù)據(jù)庫的教材都會講A給B的賬戶轉賬50美元的例子,回答這個就好了.不過據(jù)我所知,用MySQL的企業(yè),很少用MySQL來實現(xiàn)事務處理.何況現(xiàn)在Oracle收購了InnoDB的公司.
9.參見第七題的答案,那個地方搞好了這個問題就迎刃而解了.
10.哈哈哈,我猜出題的人是不是被substr的中文處理問題煩惱很久了,是不是還用了網(wǎng)上流傳的用正則匹配中文字符然后截取的函數(shù),其實,有非常簡單的解決方法:mb_substr()
面試題2
var $empty = '';
var $null = NULL;
var $bool = FALSE;
var $notSet;
var $array = array();
1.
$a = "hello";
$b = &$a;
unset($b);
$b = "world";
what is $a?
2.
$a = 1;
$x = &$a;
$b = $a++;
what is $b?
3.
$x = empty($array);
what is $x? true or false
4.您是否用過版本控制軟件? 如果有您用的版本控制軟件的名字是?
5.您是否用過模板引擎? 如果有您用的模板引擎的名字是?
6.請簡單闡述您最得意的開發(fā)之作.
7.對于大流量的網(wǎng)站,您采用什么樣的方法來解決訪問量問題?
8.用PHP寫出顯示客戶端IP與服務器IP的代碼:
答案一次更新blog的時候再寫.
1、用PHP打印出前一天的時間格式是2006-5-10 22:21:21
2、echo(),print(),print_r()的區(qū)別
3、能夠使HTML和PHP分離開使用的模板
4、如何實現(xiàn)PHP、JSP交互?
5、使用哪些工具進行版本控制?
6、如何實現(xiàn)字符串翻轉?
7、優(yōu)化MYSQL數(shù)據(jù)庫的方法。
8、談談事務處理
9、apache+mysql+php實現(xiàn)最大負載的方法
10、實現(xiàn)中文字串截取無亂碼的方法。
答案:
1.echo date('Y-m-d H:i:s', strtotime('-1 day'));
2.echo是語言結構,無返回值;print功能和echo基本相同,不同的是print是函數(shù),有返回值;print_r是遞歸打印,用于輸出數(shù)組對象
3.so much,其實PHP本身就是一種模版引擎,我用過的是smarty,常見的還有PHPLib,FastTemplate,Savant這里有個模板引擎列表:http://www.sitepoint.com/forums/showthread.php?t=123769
4.題目有點含糊不清,SOAP,XML_RPC,Socket function,CURL都可以實現(xiàn)這些,如果是考PHP和Java的整合,PHP內置了這種機制(如果考PHP和.NET的整合,也可以這么回答),例如$foo = new Java('java.lang.System');
5.CVS和SVN,SVN號稱下一代CVS,功能強大,不過CVS是老牌,市占率很高.我一直用SVN,題目是問用什么工具,呃,這個可能需要這么回答:CVS Server on Apache作服務端,WinCVS作客戶端;Subversion on Apache/DAV 做服務端,TortoiseSVN做客戶端,或者Subclipse做客戶端.
6.用strrev函數(shù)唄,不準用PHP內置的就自己寫:
function strrev($str)
{
$len=strlen($str);
$newstr = '';
for($i=$len;$i>=0;$i--)
{
$newstr .= $str{$i};
}
return $newstr;
}
7.高考政治題,把你知道的知識點都寫上吧.我的答案:
(1).數(shù)據(jù)庫設計方面,這是DBA和Architect的責任,設計結構良好的數(shù)據(jù)庫,必要的時候,去正規(guī)化(英文是這個:denormalize,中文翻譯成啥我不知道),允許部分數(shù)據(jù)冗余,避免JOIN操作,以提高查詢效率
(2).系統(tǒng)架構設計方面,表散列,把海量數(shù)據(jù)散列到幾個不同的表里面.快慢表,快表只留最新數(shù)據(jù),慢表是歷史存檔.集群,主服務器Read & write,從服務器read only,或者N臺服務器,各機器互為Master
(3).(1)和(2)超越PHP Programmer的要求了,會更好,不會沒關系.檢查有沒有少加索引
(4).寫高效的SQL語句,看看有沒有寫低效的SQL語句,比如生成笛卡爾積的全連接啊,大量的Group By和order by,沒有l(wèi)imit等等.必要的時候,把數(shù)據(jù)庫邏輯封裝到DBMS端的存儲過程里面.緩存查詢結果,explain每一個sql語句
(5).所得皆必須,只從數(shù)據(jù)庫取必需的數(shù)據(jù),比如查詢某篇文章的評論數(shù),select count(*) ... where article_id = ? 就可以了,不要先select * ... where article_id = ?然后msql_num_rows.
只傳送必須的SQL語句,比如修改文章的時候,如果用戶只修改了標題,那就update ... set title = ? where article_id = ?不要set content = ?(大文本)
(6).必要的時候用不同的存儲引擎.比如InnoDB可以減少死鎖.HEAP可以提高一個數(shù)量級的查詢速度.
8.如同是個編程語言都會有答應Hello World的例子一樣,是本數(shù)據(jù)庫的教材都會講A給B的賬戶轉賬50美元的例子,回答這個就好了.不過據(jù)我所知,用MySQL的企業(yè),很少用MySQL來實現(xiàn)事務處理.何況現(xiàn)在Oracle收購了InnoDB的公司.
9.參見第七題的答案,那個地方搞好了這個問題就迎刃而解了.
10.哈哈哈,我猜出題的人是不是被substr的中文處理問題煩惱很久了,是不是還用了網(wǎng)上流傳的用正則匹配中文字符然后截取的函數(shù),其實,有非常簡單的解決方法:mb_substr()
面試題2
var $empty = '';
var $null = NULL;
var $bool = FALSE;
var $notSet;
var $array = array();
1.
$a = "hello";
$b = &$a;
unset($b);
$b = "world";
what is $a?
2.
$a = 1;
$x = &$a;
$b = $a++;
what is $b?
3.
$x = empty($array);
what is $x? true or false
4.您是否用過版本控制軟件? 如果有您用的版本控制軟件的名字是?
5.您是否用過模板引擎? 如果有您用的模板引擎的名字是?
6.請簡單闡述您最得意的開發(fā)之作.
7.對于大流量的網(wǎng)站,您采用什么樣的方法來解決訪問量問題?
8.用PHP寫出顯示客戶端IP與服務器IP的代碼:
答案一次更新blog的時候再寫.
相關文章
php指定長度分割字符串str_split函數(shù)用法示例
這篇文章主要介紹了php指定長度分割字符串str_split函數(shù)用法,結合實例形式分析了str_split函數(shù)分割字符串的具體操作技巧,需要的朋友可以參考下2017-01-01PHP實現(xiàn)數(shù)組和對象的相互轉換操作示例
這篇文章主要介紹了PHP實現(xiàn)數(shù)組和對象的相互轉換操作,結合實例形式分析了php使用get_object_vars以數(shù)組形式訪問對象的方法,以及對象與數(shù)組相互轉換操作技巧,需要的朋友可以參考下2019-03-03php 快速判斷一個數(shù)字屬于什么范圍的實現(xiàn)方法
這篇文章主要介紹了php 快速判斷一個數(shù)字屬于什么范圍的實現(xiàn)方法,需要的朋友可以參考下2018-07-07php curl獲取網(wǎng)頁內容(IPV6下超時)的解決辦法
如果開啟了IPv6,curl默認會優(yōu)先解析 IPv6,在對應域名沒有 IPv6 的情況下,會等待 IPv6 dns解析失敗 timeout 之后才按以前的正常流程去找 IPv42013-07-07