国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

高級php面試題及php面試題部分答案

2024-05-04 23:24:13
字體:
供稿:網(wǎng)友
在網(wǎng)上看到一些高級php 的面試題目。。

閑來無事,搞了一些答案。。。可能不是很全面,留這以后備用吧。

一. 基本知識點
1.1 HTTP協(xié)議中幾個狀態(tài)碼的含義:503 500 401 403 404 200 301 302。。。
200 : 請求成功,請求的數(shù)據(jù)隨之返回。
301 : 永久性重定向。
302 : 暫時行重定向。
401 : 當前請求需要用戶驗證。
403 : 服務(wù)器拒絕執(zhí)行請求,即沒有權(quán)限。
404 : 請求失敗,請求的數(shù)據(jù)在服務(wù)器上未發(fā)現(xiàn)。
500 : 服務(wù)器錯誤。一般服務(wù)器端程序執(zhí)行錯誤。
503 : 服務(wù)器臨時維護或過載。這個狀態(tài)時臨時性的。

1.2 Include require include_once require_once 的區(qū)別.
處理失敗方式不同:
require 失敗時會產(chǎn)生一個致命級別錯誤,并停止程序運行。
include 失敗時只產(chǎn)生一個警告級別錯誤,程序繼續(xù)運行。

include_once/require_once和include/require 處理錯誤方式一樣,
唯一區(qū)別在于當所包含的文件代碼已經(jīng)存在時候,不在包含。

1.3 PHP/Mysql中幾個版本的進化史,比如mysql4.0到4.1,PHP 4.x到5.1的重大改進等等。


1.4 HEREDOC介紹
一種定義字符串的方法。
結(jié)構(gòu):
<<<。在該提示符后面,要定義個標識符(單獨一行),
然后是一個新行。接下來是字符串 本身,
最后要用前面定義的標識符作為結(jié)束標志(單獨一行)
注意:
標識符的命名也要像其它標簽一樣遵守PHP的規(guī)則:
只能包含字母、數(shù)字和下劃線,并且必須以字母和下劃線作為開頭


1.5 寫出一些php魔幻(術(shù))方法;
__construct() 實例化類時自動調(diào)用。
__destruct() 類對象使用結(jié)束時自動調(diào)用。
__set() 在給未定義的屬性賦值的時候調(diào)用。
__get() 調(diào)用未定義的屬性時候調(diào)用。
__isset() 使用isset()或empty()函數(shù)時候會調(diào)用。
__unset() 使用unset()時候會調(diào)用。
__sleep() 使用serialize序列化時候調(diào)用。
__wakeup() 使用unserialize反序列化的時候調(diào)用。
__call() 調(diào)用一個不存在的方法的時候調(diào)用。
__callStatic()調(diào)用一個不存在的靜態(tài)方法是調(diào)用。
__toString() 把對象轉(zhuǎn)換成字符串的時候會調(diào)用。比如 echo。
__invoke() 當嘗試把對象當方法調(diào)用時調(diào)用。
__set_state() 當使用var_export()函數(shù)時候調(diào)用。接受一個數(shù)組參數(shù)。
__clone() 當使用clone復(fù)制一個對象時候調(diào)用。

1.6 一些編譯php時的configure 參數(shù)
–prefix=/usr/local/php    php安裝目錄
–with-config-file-path=/usr/local/php/etc 指定php.ini位置
–with-mysql=/usr/local/mysql mysql安裝目錄,對mysql的支持
–with-mysqli=/usr/local/mysql/bin/mysql_config mysqli文件目錄,優(yōu)化支持
–enable-safe-mode 打開安全模式
–enable-ftp 打開ftp的支持
–enable-zip 打開對zip的支持
–with-bz2 打開對bz2文件的支持
–with-jpeg-dir 打開對jpeg圖片的支持
–with-png-dir 打開對png圖片的支持
–with-freetype-dir 打開對freetype字體庫的支持
–without-iconv關(guān)閉iconv函數(shù),種字符集間的轉(zhuǎn)換
–with-libxml-dir 打開libxml2庫的支持
–with-xmlrpc 打開xml-rpc的c語言
–with-zlib-dir 打開zlib庫的支持
–with-gd 打開gd庫的支持

更多可以使用 ./configure help 查看



1.7 向php傳入?yún)?shù)的三種方法。

/*
     * 方法一 使用$argc $argv
     *  在命令行下運行 /usr/local/php/bin/php ./getopt.php -f 123 -g 456
     */
//    if ($argc > 1){
//        print_r($argv);
//    }


    /**
     * 運行結(jié)果
     *
     sync@MySUSE11:~/web_app/channel3/interface> /usr/local/php/bin/php ./getopt.php -f 123 -g 456
        Array
        (
            [0] => ./getopt.php
            [1] => -f
            [2] => 123
            [3] => -g
            [4] => 456
        )
     */










     /*
     * 方法二 使用getopt函數(shù)()
     *  在命令行下運行 /usr/local/php/bin/php ./getopt.php -f 123 -g 456
     */


//    $options = "f:g:";
//    $opts = getopt( $options );
//    print_r($opts);


    /**
     * 運行結(jié)果
     *
     sync@MySUSE11:~/web_app/channel3/interface> /usr/local/php/bin/php ./getopt.php -f 123 -g 456
        Array
        (
            [f] => 123
            [g] => 456
        )
     */






    /*
     * 方法三 提示用戶輸入,然后獲取輸入的參數(shù)。有點像C語言
     *  在命令行下運行 /usr/local/php/bin/php ./getopt.php
     */
    fwrite(STDOUT, "Enter your name: ");
    $name = trim(fgets(STDIN));
    fwrite(STDOUT, "Hello, $name!");
    /**
     * 運行結(jié)果
     *
     sync@MySUSE11:~/web_app/channel3/interface> /usr/local/php/bin/php ./getopt.php
     Enter your name: francis
     Hello, francis!
     */




1.8 (mysql)請寫出數(shù)據(jù)類型(int char varchar datetime text)的意思; 請問varchar和char有什么區(qū)別;
int : 數(shù)值類型
char : 固定長度字符串類型
varchar : 可變長度字符串類型
datetime : 時期時間類型
text : 文本類型

varchar和char有什么區(qū)別:
a. char 長度是固定的,不管你存儲的數(shù)據(jù)是多少他都會都固定的長度。
而varchar則處可變長度但他要在總長度上加1字符,這個用來存儲位置。

b. char 固定長度,所以在處理速度上要比varchar快速很多,但是浪費存儲空間,
所以對存儲不大,但在速度上有要求的可以使用char類型,反之可以用varchar類型來實例。


1.9 error_reporting 等調(diào)試函數(shù)使用
error_reporting() 函數(shù)能夠在運行時設(shè)置php.ini中 error_reporting 指令。
所以可以再程序中隨時調(diào)節(jié)顯示的錯誤級別。
使用此函數(shù)時 display_errors必須是打開狀態(tài)。

1.10 您是否用過版本控制軟件? 如果有您用的版本控制軟件的名字是?




1.11 posix和perl標準的正則表達式區(qū)別;



1.12 Safe_mode 打開后哪些地方受限.
啟動safe_mode,會對許多PHP函數(shù)進行限制,特別是和系統(tǒng)相關(guān)的文件打開、命令執(zhí)行等函數(shù).
所有操作文件的函數(shù)將只能操作與腳本UID相同的文件.


1.13 寫代碼來解決多進程/線程同時讀寫一個文件的問題。
PHP是不支持多線程的,可以使用php的flock加鎖函數(shù)實現(xiàn)。
$fp = fopen("/tmp/lock.txt", "w+");
if (flock($fp, LOCK_EX)) { // 進行排它型鎖定
fwrite($fp, "Write something here/n");
flock($fp, LOCK_UN); // 釋放鎖定
} else {
echo "Couldn't lock the file !";
}
fclose($fp);


1.14 寫一段上傳文件的代碼。
upload.html
<form enctype="multipart/form-data" method="POST" action="upload.php">
Send this file: <input name="name" type="file" />
<input type="submit" value="Send File" />
</form>

upload.php
$uploads_dir = '/uploads';
foreach ($_FILES["error"] as $key => $error) {
if ($error == UPLOAD_ERR_OK) {
$tmp_name = $_FILES["tmp_name"][$key];
$name = $_FILES["name"][$key];
move_uploaded_file($tmp_name, "$uploads_dir/$name");
}
}




1.15 Mysql 的存儲引擎,myisam和innodb的區(qū)別。
a. MyISAM類型不支持事務(wù)處理等高級處理,而InnoDB類型支持.
b. MyISAM類型的表強調(diào)的是性能,其執(zhí)行數(shù)度比InnoDB類型更快.
c. InnoDB不支持FULLTEXT類型的索引.
d. InnoDB 中不保存表的具體行數(shù),也就是說,
執(zhí)行select count(*) from table時,InnoDB要掃描一遍整個表來計算有多少行,
但是MyISAM只要簡單的讀出保存好的行數(shù)即可.
e. 對于AUTO_INCREMENT類型的字段,InnoDB中必須包含只有該字段的索引,但是在MyISAM表中,可以和其他字段一起建立聯(lián)合索引。
f. DELETE FROM table時,InnoDB不會重新建立表,而是一行一行的刪除。
g. LOAD TABLE FROM MASTER操作對InnoDB是不起作用的,解決方法是首先把InnoDB表改成MyISAM表,導(dǎo)入數(shù)據(jù)后再改成InnoDB表,
但是對于使用的額外的InnoDB特性(例如外鍵)的表不適用.
h. MyISAM支持表鎖,InnoDB支持行鎖。



二. web 架構(gòu),安全,項目經(jīng)驗
2.1 介紹xdebug,apc,eAccelerator,Xcache,Zend opt的使用經(jīng)驗。


2.2 使用mod_rewrite,在服務(wù)器上沒有/archivers/567.html這個物理文件時,重定向到index.php?id=567 ,請先打開mod_rewrite.
首先,打開mod_rewrite模塊。

其次,http.conf找到以下代碼段:
<Directory />
Options FollowSymLinks
AllowOverride None
</Directory>
將其中的:AllowOverride None 改為 AllowOverride All ,重啟httpd服務(wù)即可。

然后,在項目根目錄下簡歷 .htaccess 文件,填寫規(guī)則。
 

2.3 MySQL數(shù)據(jù)庫作發(fā)布系統(tǒng)的存儲,一天五萬條以上的增量,預(yù)計運維三年,怎么優(yōu)化?
a. 設(shè)計良好的數(shù)據(jù)庫結(jié)構(gòu),允許部分數(shù)據(jù)冗余,盡量避免join查詢,提高效率。
b. 選擇合適的表字段數(shù)據(jù)類型和存儲引擎,適當?shù)奶砑铀饕?br />c. mysql庫主從讀寫分離。
d. 找規(guī)律分表,減少單表中的數(shù)據(jù)量提高查詢速度。
e。添加緩存機制,比如memcached,apc等。
f. 不經(jīng)常改動的頁面,生成靜態(tài)頁面。
g. 書寫高效率的SQL。比如 SELECT * FROM TABEL 改為 SELECT field_1, field_2, field_3 FROM TABLE.


2.4 寫出一種排序算法(原理),并說出優(yōu)化它的方法。


2.5 請簡單闡述您最得意的開發(fā)之作


2.6 對于大流量的網(wǎng)站,您采用什么樣的方法來解決各頁面訪問量統(tǒng)計問題
a. 確認服務(wù)器是否能支撐當前訪問量。
b. 優(yōu)化數(shù)據(jù)庫訪問。參考2.3
c. 禁止外部訪問鏈接(盜鏈), 比如圖片盜鏈。
d. 控制文件下載。
e. 使用不同主機分流。
f. 使用瀏覽統(tǒng)計軟件,了解訪問量,有針對性的進行優(yōu)化。


2.7 您是否用過模板引擎? 如果有您用的模板引擎的名字是?
Smarty

2.8 請介紹Session的原理,大型網(wǎng)站中Session方面應(yīng)注意什么?




2.9 測試php性能和mysql數(shù)據(jù)庫性能的工具,和找出瓶頸的方法。


2.10 正則提出一個網(wǎng)頁中的所有鏈接.


2.11 介紹一下常見的SSO(單點登陸)方案(比如dedecms整合discuz的passport)的原理。


2.12 您寫過的PHP框架的特點,主要解決什么問題,與其他框架的不同點。


2.13 大型的論壇/新聞文章系統(tǒng)/SNS網(wǎng)站在性能優(yōu)化上有什么區(qū)別?


2.14 相冊類應(yīng)用:要求在瀏覽器中能同時選中并上傳多個文件,圖片要求能剪裁,壓縮包在服務(wù)器端解壓。能上傳單個達50M的文件。上傳過程中有進度條顯示。每個圖片能生成四種大小縮略圖,視頻文件要轉(zhuǎn)成flv供flash播放。敘述要涉及的各類開源軟件和簡單用途。
一群猴子排成一圈,按1,2,…,n依次編號。然后從第1只開始數(shù),數(shù)到第m只,把它踢出圈,從它后面再開始數(shù),再數(shù)到第m只,在把它踢出去…,如此不停的進行下去,直到最后只剩下一只猴子為止,那只猴子就叫做大王。要求編程模擬此過程,輸入m、n, 輸出最后那個大王的編號。用程序模擬該過程。


三. unix/linux 基本使用
3.1 linux下查看當前系統(tǒng)負載信息的一些方法。


3.2 vim的基本快捷鍵。


3.3 ssh 安全增強方法;密碼方式和rsa key 方式的配置。


3.4 rpm/apt/yum/ports 裝包,查詢,刪除的基本命令。


3.5 Makefile的基本格式,gcc 編譯,連接的命令,-O0 和-O3區(qū)別。


3.6 gdb,strace,valgrind的基本使用.


四. 前端,HTML,JS
css盒模型。
javascript中的prototype。
javascript中this對象的作用域。
IE和firefox事件冒泡的不同。
什么是怪異模式,標準模式,近標準模式。
DTD的定義
IE/firefox常用hack.
firefox,IE下的前端js/css調(diào)試工具。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 民县| 买车| 盈江县| 敦煌市| 胶州市| 夏邑县| 阳高县| 合阳县| 金山区| 东安县| 罗江县| 襄汾县| 东海县| 壤塘县| 贵州省| 天门市| 河池市| 平遥县| 天水市| 扎鲁特旗| 长垣县| 遂川县| 赤峰市| 城市| 营山县| 延津县| 田东县| 称多县| 苏尼特右旗| 紫金县| 乡宁县| 屏边| 桐庐县| 绩溪县| 桃源县| 江阴市| 临沧市| 开阳县| 永和县| 东城区| 东城区|