1. echo和print的區別 echo沒有返回值,print有返回值1,執行失敗時返回false;echo輸出的速度比print快,因為沒有返回值;echo可以輸出一個或多個字元串,print只允許輸出一個字元串;print可以用於複雜的表達式,echo不行。 另問:echo是個函數嗎? ech ...
1. echo和print的區別
echo沒有返回值,print有返回值1,執行失敗時返回false;echo輸出的速度比print快,因為沒有返回值;echo可以輸出一個或多個字元串,print只允許輸出一個字元串;print可以用於複雜的表達式,echo不行。
另問:echo是個函數嗎? echo不是函數,是語言結構。具體的解釋可參見http://www.cnblogs.com/m1001m/archive/2013/03/24/2978219.html
2. 說幾組數組有關函數
實在太多了,這裡寫幾個好了,完整版參見http://www.runoob.com/php/php-ref-array.html
array() 創建數組。
array_diff() 比較數組,返回差集(只比較鍵值)。
array_pop() 刪除數組的最後一個元素(出棧)。
array_rand() 返回數組中一個或多個隨機的鍵。
array_replace() 使用後面數組的值替換第一個數組的值。
array_reverce() 以相反的順序返回數組。
array_shift() 刪除數組中首個元素,並返回被刪除元素的值。
array_slice() 返回數組中被選定的部分。
array_splice() 刪除並替換數組中指定的元素。
arsort() 對關聯數組按照鍵值進行降序排序。
end()將數組的內部指針指向最後一個元素。
in_array() 檢查數組中是否存在指定的值。
krsort() 對數組按照鍵名逆向排序。
next() 將數組中的內部指針向前移動一位。
reset() 將數組的內部指針指向第一個元素。
3. php中的魔術函數舉例 哎呦,我腦子一抽就說出來了魔術變數,醉了。
關於魔術函數呢,各方資料解釋都不盡相同,大家多翻一翻,看看哪種說法你自己更容易理解。
__construct() 允許在實例化一個類之前先執行構造方法。
__destruct() 析構方法允許在銷毀一個類之前執行的一些操作或完成一些功能。
__get(string $name) 用於獲取私有屬性值。讀取一個對象的屬性時, 若屬性存在,則直接返回屬性值;若不存在,則會調用__get函數。
__set(string $name,mixed $value) 用於設置私有屬性。設置一個對象的屬性時, 若屬性存在,則直接賦值;若不存在,則會調用__set函數。
__call(string $name,array $arguments) 用於監視錯誤的方法調用。對象調用某個方法,若方法存在,則直接調用; 若不存在,則會去調用__call函數。靜態方法中調用不存在或者不可訪問的方法時,會調用__callStatic(string $name, array $arguments) 方法。
__tostring() 當列印對象時會被直接調用。如echo $obj;或print $obj。
__clone() 當對象被拷貝時直接調用。如$t=new Test();$t1=clone $t。
__sleep() serialize之前被調用。若對象比較大,想刪減一點再序列化,可考慮一下此函數。
__wakeup() unserialize() 會檢查是否存在一個 __wakeup() 方法。如果存在,則會先調用__wakeup 方法,預先準備對象需要的資源。
__isset() 檢測一個對象的屬性是否存在時被調用。如:isset($c->name)。
__unset() unset一個對象的屬性時被調用。如:unset($c->name)。
__set_state() 調用var_export時,被調用。用__set_state的返回值做為var_export的返回值。
__autoload() 實例化一個對象時,如果對應的類不存在,則該方法被調用。
__invoke() 當嘗試以調用函數的方式調用一個對象時,__invoke 方法會被自動調用。
4. 往資料庫里插入欄位的MySQL語句
假設我們的表名是users:
ALTER TABLE 'users' ADD 'uName' VARCHAR(200) NOT NULL AFTER 'uId'; //在uId欄位後面加uName欄位,中間的varchar 200 notnull都是屬性
※那麼問題來了,刪除和修改語句都是什麼呢?
ALTER TABLE 'users' DROP 'uName'; // 刪除uName欄位
ALTER TABLE 'users' CHANGE 'uName' 'uId' INT(6) NOT NULL; //將欄位uName改為uId
5. LAMP和LNMP的區別
LAMP==Linux+Apache+Mysql+PHP
LNMP==Linux+Nginx+Mysql+PHP
感謝博主——啄木鳥http://blog.sina.com.cn/s/blog_626998030102wofn.html
6. HTTP請求錯誤返回碼都有哪些?
3xx : 重定向
301: 已移動 — 請求的數據具有新的位置且更改是永久的。 302: 已找到 — 請求的數據臨時具有不同 URI。
303: 請參閱其它 — 可在另一 URI 下找到對請求的響應,且應使用 GET 方法檢索此 應。
304: 未修改 — 未按預期修改文檔。
305: 使用代理 — 必須通過位置欄位中提供的代理來訪問請求的資源。 306: 未使用 — 不再使用;保留此代碼以便將來使用。 4xx: 客戶機中出現的錯誤
400: 錯誤請求 — 請求中有語法問題,或不能滿足請求。 401: 未授權 — 未授權客戶機訪問數據。 402: 需要付款 — 表示計費系統已有效。 403: 禁止 — 即使有授權也不需要訪問。
404: 找不到 — 伺服器找不到給定的資源;文檔不存在。 407: 代理認證請求 — 客戶機首先必須使用代理認證自身。
415: 介質類型不受支持 — 伺服器拒絕服務請求,因為不支持請求實體的格式。 5xx: 伺服器中出現的錯誤
500: 內部錯誤 — 因為意外情況,伺服器不能完成請求。 501: 未執行 — 伺服器不支持請求的工具。
502: 錯誤網關 — 伺服器接收到來自上游伺服器的無效響應。
503: 無法獲得服務 — 由於臨時過載或維護,伺服器無法處理請求。 900:內部錯誤(由程式運行時拋出異常終止請求,而生成的結果) 901:連接超時 902:響應超時 903:IO異常
904:數據用盡(參數化時數據取盡) 905:未知主機異常
906:URL協議異常(url格式錯誤)
907:證書錯誤(https請求時使用本地證書,由證書問題導致的異常) 908:socket連接錯誤 910:IO異常中斷 911:非法狀態 912:不支持的操作 913:連接關閉
914:沒有http響應 915:請求中止
※問題又來了,請求成功返回什麼呢?
2xx: 成功
200: 正常;請求已完成。 201: 正常;緊接 POST 命令。
202: 正常;已接受用於處理,但處理尚未完成。 203: 正常;部分信息 — 返回的信息只是一部分。
204: 正常;無響應 — 已接收請求,但不存在要回送的信息。
7. php版本之間的差異瞭解多少?
8. 用JS代碼書寫非同步數據傳輸?
9. 欄位為什麼要加索引,哪些欄位需要加索引?
10. 因為我個人有一些Linux系統開發經驗,面試官問我熟悉的linux命令有哪些?
命令多的一拼,具體參見:http://www.runoob.com/linux/linux-command-manual.html。
這裡列舉幾個常用的吧:
改變文件的許可權:chmod
切換目錄:cd
顯示當前所在目錄:pwd
建立新目錄:mkdir
刪除空的目錄:rmdir
列出目前工作目錄所含之文件及子目錄:ls
複製檔案或目錄:cp
返迴路徑中的文件名:basename
返迴路徑中的目錄:dirname
尋找特定檔案:whereis locate find
未完待續……