php常見(jiàn)面試題及答案
PHP面試者在面試前的準(zhǔn)備很重要,以下是小編幫你們整理的php常見(jiàn)面試題及答案,一起來(lái)學(xué)習(xí)啦。
php常見(jiàn)面試題及答案(一)
1、表單提交get和post有何區(qū)別?
答:get的方式是把數(shù)據(jù)在地址欄中發(fā)送,get傳送的數(shù)據(jù)量較小,不能大于2KB。post傳送的數(shù)據(jù)量較大,一般被默認(rèn)為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB。
2、用PHP打印出前一天的時(shí)間格式是2006-5-10 22:21:21
echo date("Y-m-d H:i:s",time()-(3600*24));或echo date("Y-m-d H:i:s",strtotime("-1 day"));
3、php中include和require的區(qū)別?
這兩種結(jié)構(gòu)除了在如何處理失敗之外完全一樣。include() 產(chǎn)生一個(gè)警告而 require() 則導(dǎo)致一個(gè)致命錯(cuò)誤。換句話說(shuō),如果你想在遇到丟失文件時(shí)停止處理頁(yè)面就用 require()。include() 就不是這樣,腳本會(huì)繼續(xù)運(yùn)行。
4、echo(),print(),print_r()的區(qū)別
echo可以接多個(gè)參數(shù),print只能接一個(gè)參數(shù),它們都是PHP的語(yǔ)言結(jié)構(gòu),print_r是遞規(guī)打印,用來(lái)打印數(shù)組或?qū)ο?/p>
5、能夠使HTML和PHP分離開(kāi)使用的模板smarty,phplib,SmartTemplate 6你如何理解MVC模式?
首先說(shuō)一下框架,框架:就是別人把一些底層,常用操作.比如數(shù)據(jù)操作(增,刪,改,查)寫(xiě)好.你來(lái)直接用.其它的功能要自己來(lái)做。
MVC:設(shè)計(jì)模式,M模型,V顯示,C控制.現(xiàn)在許多框架都是基于MVC來(lái)做的把邏輯和顯示分開(kāi).比如你要換頁(yè)面,只需要改V里面的東西并不需要再去變動(dòng)程序(詳細(xì)的東西可以上網(wǎng)上查一下)
6、apache+mysql+php實(shí)現(xiàn)最大負(fù)載的方法
1) 問(wèn)的太籠統(tǒng),生成靜態(tài)html頁(yè)面,squid反向代理,apache,mysql的負(fù)載均衡。
2) 可以采取數(shù)據(jù)緩存的方法,我們通常在統(tǒng)計(jì)數(shù)據(jù)的時(shí)候,需要在原始數(shù)據(jù)的基礎(chǔ)上經(jīng)過(guò)計(jì)算等一系列操作,才會(huì)得到最終的結(jié)果,如果每做一個(gè)查詢都需要這樣一系列操作,當(dāng)數(shù)據(jù)量大時(shí),勢(shì)必會(huì)帶來(lái)很多問(wèn)題??梢越⒁粋€(gè)結(jié)果表,寫(xiě)一個(gè)腳本,用crontab定時(shí)觸發(fā)腳本去原始表取數(shù)據(jù),計(jì)算,寫(xiě)入到結(jié)果表,前端查詢從結(jié)果表取數(shù)據(jù),這也是比較常用的一種做法。
3) 采用分布式,多個(gè)apache,多個(gè)mysql,其實(shí)就是dns負(fù)載均衡,dns根據(jù)當(dāng)前用戶解析幾個(gè)ip的ping值,將用戶轉(zhuǎn)移到某一臺(tái)最快的服務(wù)器,或者平均分配。
4 )money不是問(wèn)題的話,可以考慮F5硬件負(fù)載均衡!
5)可以使用Microsoft Windows Server系統(tǒng)的負(fù)載均衡設(shè)置
php常見(jiàn)面試題及答案(二)
1、如何實(shí)現(xiàn)PHP、JSP交互?
PHP提供了支持JAVA的類庫(kù)文件,或者通過(guò)HTTP協(xié)議來(lái)交互數(shù)據(jù)
2、使用哪些工具進(jìn)行版本控制?
VSS,CVS,SVN
3、如何實(shí)現(xiàn)字符串翻轉(zhuǎn)?
不考慮中英文混合,不是最優(yōu)算法,不用php庫(kù)函數(shù)翻轉(zhuǎn)字符串:
function str_to_reverse( $str ){
for($length=0;$str[$length]!=null;$length++){;}
$strlength = $length-1;
unset($length);
for($start=0,$end=$strlength;$start<$end;$start++,$end--){
$temp = $str[$start];
$str[$start] = $str[$end];
$str[$end] = $temp;
}
unset($temp,$start,$end,$strlength);
return $str;
}
4、優(yōu)化MYSQL數(shù)據(jù)庫(kù)的方法。
1) 將where中用的比較頻繁的字段建立索引,聯(lián)合索引。
2) 保證單表數(shù)據(jù)不超過(guò)200W,適時(shí)分割表。
3) 避免使用長(zhǎng)連接。
4) 修改my.cnf里面的各項(xiàng)參數(shù),比如最大連接數(shù),查詢緩存等。根據(jù)你的服務(wù)器內(nèi)存來(lái)最大化調(diào)節(jié)那些配置參數(shù)。
5) 針對(duì)需求,使用正確的表引擎,是myisam或是innodb。
5.用PHP寫(xiě)出顯示客戶端IP與服務(wù)器IP的代碼:
echo $_SERVER['REMOTE_ADDR'] //客戶端ip
echo $_SERVER['SERVER_ADDR'] //服務(wù)器端ip
php常見(jiàn)面試題及答案(三)
1、用PHP打印出前一天的時(shí)間格式是2006-5-10 22:21:21
2、echo(),print(),print_r()的區(qū)別
3、能夠使HTML和PHP分離開(kāi)使用的模板
4、如何實(shí)現(xiàn)PHP、JSP交互?
5、使用哪些工具進(jìn)行版本控制?
6、如何實(shí)現(xiàn)字符串翻轉(zhuǎn)?
7、優(yōu)化MYSQL數(shù)據(jù)庫(kù)的方法。
8、談?wù)勈聞?wù)處理
9、apache+mysql+php實(shí)現(xiàn)最大負(fù)載的方法
10、實(shí)現(xiàn)中文字串截取無(wú)亂碼的方法。
答案:
1.echo date('Y-m-d H:i:s', strtotime('-1 day'));
2.echo是語(yǔ)言結(jié)構(gòu),無(wú)返回值;print功能和echo基本相同,不同的是print是函數(shù),有返回值;print_r是遞歸打印,用于輸出數(shù)組對(duì)象
3.so much,其實(shí)PHP本身就是一種模版引擎,我用過(guò)的是smarty,常見(jiàn)的還有PHPLib,FastTemplate,Savant這里有個(gè)模板引擎列表
4. 題目有點(diǎn)含糊不清,SOAP,XML_RPC,Socket ,CURL都可以實(shí)現(xiàn)這些,如果是考PHP和Java的整合,PHP內(nèi)置了這種機(jī)制(如果考PHP和.NET的整合,也可以這么回答),例如$foo = new Java('java.lang.System');
5.CVS 和SVN,SVN號(hào)稱下一代CVS,功能強(qiáng)大,不過(guò)CVS是老牌,市占率很高.我一直用SVN,題目是問(wèn)用什么工具,呃,這個(gè)可能需要這么回答:CVS Server on Apache作服務(wù)端,WinCVS作客戶端;Subversion on Apache/DAV 做服務(wù)端,TortoiseSVN做客戶端,或者Subclipse做客戶端.
6.用strrev函數(shù)唄,不準(zhǔn)用PHP內(nèi)置的就自己寫(xiě):
strrev($str)
{
$len=strlen($str);
$newstr = '';
for($i=$len;$i>=0;$i--)
{
$newstr .= $str{$i};
}
return $newstr;
}
7.高考政治題,把你知道的知識(shí)點(diǎn)都寫(xiě)上吧.我的答案:
(1).數(shù)據(jù)庫(kù)設(shè)計(jì)方面,這是DBA和Architect的責(zé)任,設(shè)計(jì)結(jié)構(gòu)良好的數(shù)據(jù)庫(kù),必要的時(shí)候,去正規(guī)化(英文是這個(gè):denormalize,中文翻譯成啥我不知道),允許部分?jǐn)?shù)據(jù)冗余,避免JOIN操作,以提高查詢效率
(2).系統(tǒng)架構(gòu)設(shè)計(jì)方面,表散列,把海量數(shù)據(jù)散列到幾個(gè)不同的表里面.快慢表,快表只留最新數(shù)據(jù),慢表是歷史存檔.集群,主服務(wù)器Read & write,從服務(wù)器read only,或者N臺(tái)服務(wù)器,各機(jī)器互為Master
(3).(1)和(2)超越PHP Programmer的要求了,會(huì)更好,不會(huì)沒(méi)關(guān)系.檢查有沒(méi)有少加索引
(4).寫(xiě)高效的SQL語(yǔ)句,看看有沒(méi)有寫(xiě)低效的SQL語(yǔ)句,比如生成笛卡爾積的全連接啊,大量的Group By和order by,沒(méi)有l(wèi)imit等等.必要的時(shí)候,把數(shù)據(jù)庫(kù)邏輯封裝到DBMS端的存儲(chǔ)過(guò)程里面.緩存查詢結(jié)果,explain每一個(gè)sql語(yǔ)句
(5). 所得皆必須,只從數(shù)據(jù)庫(kù)取必需的數(shù)據(jù),比如查詢某篇文章的評(píng)論數(shù),select count(*) ... where article_id = ? 就可以了,不要先select * ... where article_id = ?然后msql_num_rows.只傳送必須的SQL語(yǔ)句,比如修改文章的時(shí)候,如果用戶只修改了標(biāo)題,那就update ... set title = ? where article_id = ?不要set content = ?(大文本)
(6).必要的時(shí)候用不同的存儲(chǔ)引擎.比如InnoDB可以減少死鎖.HEAP可以提高一個(gè)數(shù)量級(jí)的查詢速度.
8.如同是個(gè)編程語(yǔ)言都會(huì)有答應(yīng)Hello World的例子一樣,是本數(shù)據(jù)庫(kù)的教材都會(huì)講A給B的賬戶轉(zhuǎn)賬50美元的例子,回答這個(gè)就好了.不過(guò)據(jù)我所知,用MySQL的企業(yè),很少用MySQL來(lái)實(shí)現(xiàn)事務(wù)處理.何況現(xiàn)在Oracle收購(gòu)了InnoDB的公司.
9.參見(jiàn)第七題的答案,那個(gè)地方搞好了這個(gè)問(wèn)題就迎刃而解了.
10.哈哈哈,我猜出題的人是不是被substr的中文處理問(wèn)題煩惱很久了,是不是還用了網(wǎng)上流傳的用正則匹配