色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

PHP的面試題集,附我的答案和分析(一)

面試題1
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è)模板引擎列表:http://www.sitepoint.com/forums/showthread.php?t=123769

4.題目有點(diǎn)含糊不清,SOAP,XML_RPC,Socket function,CURL都可以實(shí)現(xiàn)這些,如果是考phpJava的整合,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ě):
function 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)上流傳的用正則匹配中文字符然后截取的函數(shù),其實(shí),有非常簡(jiǎn)單的解決方法: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.您是否用過(guò)版本控制軟件? 如果有您用的版本控制軟件的名字是?

5.您是否用過(guò)模板引擎? 如果有您用的模板引擎的名字是?

6.請(qǐng)簡(jiǎn)單闡述您最得意的開(kāi)發(fā)之作.

7.對(duì)于大流量的網(wǎng)站,您采用什么樣的方法來(lái)解決訪問(wèn)量問(wèn)題?

8.用php寫(xiě)出顯示客戶端IP與服務(wù)器IP的代碼:

答案一次更新blog的時(shí)候再寫(xiě).

php技術(shù)PHP的面試題集,附我的答案和分析(一),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 泗阳县| 白水县| 昭苏县| 嵩明县| 兴化市| 桃源县| 巴中市| 榆中县| 洪雅县| 三明市| 应用必备| 南部县| 长春市| 江西省| 临沭县| 乌鲁木齐市| 志丹县| 湘阴县| 伊宁县| 新建县| 古田县| 梁山县| 青神县| 中方县| 县级市| 麻城市| 上饶县| 天柱县| 梅州市| 古田县| 灵丘县| 界首市| 松桃| 中方县| 涞源县| 广昌县| 剑阁县| 邢台市| 静乐县| 凤台县| 定安县|