宇轩网络面试题目PHP,二十道接地气的php面试题,让你直接通过面试!就此奉上~...
1、echo count(“abc”); 輸出什么?
答:"1"count
— 計(jì)算數(shù)組中的單元數(shù)目或?qū)ο笾械膶傩詡€(gè)數(shù)int count ( mixed var\[,intvar \[, intvar\[,intmode ] ), 如果 var 不是數(shù)組類(lèi)型或者實(shí)現(xiàn)了 Countable 接口的對(duì)象,將返回 1,
有一個(gè)例外,如果 var 是 NULL 則結(jié)果是 0。對(duì)于對(duì)象,如果安裝了 SPL,可以通過(guò)實(shí)現(xiàn) Countable 接口來(lái)調(diào)用 count()。該接口只有一個(gè)方法 count(),此方法返回 count() 函數(shù)的返回值。
2、用PHP寫(xiě)出顯示客戶端IP與服務(wù)器IP的代碼
答:$_SERVER[‘SERVER_ADDR’] 服務(wù)器
$_SERVER[‘REMOTE_ADDR’]客戶端
function getOnlineIP(){
if (getenv('HTTP_CLIENT_IP')) return getenv('HTTP_CLIENT_IP');
if (getenv('HTTP_X_FORWARDED_FOR')) return getenv('HTTP_X_FORWARDED_FOR');
if ($_SERVER["REMOTE_ADDR"]) return $_SERVER["REMOTE_ADDR"];
if (!empty($HTTP_SERVER_VARS['REMOTE_ADDR'])) return $HTTP_SERVER_VARS['REMOTE_ADDR'];
}
復(fù)制代碼
3、error_reporting(2047)什么作用?
答:PHP 顯示所有錯(cuò)誤 E_ALL
4、Js表單彈出對(duì)話框的函數(shù)是什么,并簡(jiǎn)要描述。
alert(); 只是提示信息 無(wú)返回值
confirm; 點(diǎn)確實(shí)返回true 否則false
5、下面的程序會(huì)輸入是否?
$num = 10;
function multiply(){
$num = $num * 10;
}
Multiply();
echo $num;
?>
復(fù)制代碼
答案:10 若要調(diào)用 函數(shù)中使用globle $num;
6、echo,print()和print_r()有什么區(qū)別?
echo是一個(gè)語(yǔ)言結(jié)構(gòu),沒(méi)有返回值。
print是一個(gè)函數(shù),返回int類(lèi)型的值。[只能打印int string]
print_r()是一個(gè)函數(shù),返回bool類(lèi)型值,按結(jié)構(gòu)輸出變量的值。打印關(guān)于變量的易于理解的信息[數(shù)組、對(duì)象等]
7、isset();empty();有什么區(qū)別?對(duì)于不同的數(shù)據(jù)的判斷的結(jié)果?
a=0;
a=0;a=’0’;
a=false;
a=false;a=null;
empty
如果 變量 是非空或非零的值,則 empty() 返回 FALSE。換句話說(shuō),""、0、“0”、NULL、FALSE、array()、var $var、未定義; 以及沒(méi)有任何屬性的對(duì)象都將被認(rèn)為是空的,如果 var 為空,則返回 TRUE。
isset
如果 變量 存在(非NULL)則返回 TRUE,否則返回 FALSE(包括未定義)。變量值設(shè)置為:null,返回也是false;unset一個(gè)變量后,變量被取消了。注意,isset對(duì)于NULL值變量,特殊處理。
8、引用和拷貝有什么區(qū)別?
拷貝是將原來(lái)的變量?jī)?nèi)容復(fù)制下來(lái),拷貝后的變量與原來(lái)的變量使用各自的內(nèi)存,互不干擾。
引用相當(dāng)于是變量的別名,其實(shí)就是用不同的名字訪問(wèn)同一個(gè)變量?jī)?nèi)容。當(dāng)改變其中一個(gè)變量的值時(shí),另一個(gè)也跟著發(fā)生變化。
9、打開(kāi)php.ini中的Safe_mode,會(huì)影響哪些函數(shù)?至少說(shuō)出6個(gè)。
答:
用戶輸入輸出函數(shù)(fopen() file() require(),只能用于調(diào)用這些函數(shù)有相同腳本的擁有者)
創(chuàng)建新文件(限制用戶只在該用戶擁有目錄下創(chuàng)建文件)
用戶調(diào)用popen() systen() exec()等腳本,只有腳本處在safe_mode_exec_dir配置指令指定的目 錄中才可能
加強(qiáng)HTTP認(rèn)證,認(rèn)證腳本擁有者的UID的劃入認(rèn)證領(lǐng)域范圍內(nèi),此外啟用安全模式下,不會(huì)設(shè)置PHP_AUTH
mysql服務(wù)器所用的用戶名必須與調(diào)用mysql_connect()的文件的擁有者用戶名相同
受影響的函數(shù)變量以及配置命令達(dá)到40個(gè)
10、寫(xiě)個(gè)函數(shù)來(lái)解決多線程同時(shí)讀寫(xiě)一個(gè)文件的問(wèn)題。
答:flock($hander,LOCK_EX); 這個(gè)可是內(nèi)置函數(shù)啊
11、請(qǐng)寫(xiě)一個(gè)函數(shù)驗(yàn)證電子郵件的格式是否正確(要求使用正則)
答:preg_match(’/^ [\w-.]+@[\w-]+(.\w+)+/’,/’,/’,email);
12、寫(xiě)出匹配URL的正則表達(dá)式。
preg_match(’/(\w+)😕/([/:]+)(:\d*)?([# ]*)/’,$url);
13、寫(xiě)出發(fā)帖數(shù)量最多的5~15個(gè)人名字的SQL語(yǔ)句,利用下表;
Members(id,username,posts,pass,email);
select username from Members order by 發(fā)帖數(shù)量 desc limit 4,10
復(fù)制代碼
14、MySQL數(shù)據(jù)庫(kù),一天5萬(wàn)條以上的增量,怎么優(yōu)化?
a. 設(shè)計(jì)良好的數(shù)據(jù)庫(kù)結(jié)構(gòu),允許部分?jǐn)?shù)據(jù)冗余,盡量避免join查詢(xún),提高效率。
b. 選擇合適的表字段數(shù)據(jù)類(lèi)型和存儲(chǔ)引擎,適當(dāng)?shù)奶砑铀饕?/p>
c. mysql庫(kù)主從讀寫(xiě)分離。
d. 找規(guī)律分表,減少單表中的數(shù)據(jù)量提高查詢(xún)速度。
e. 添加緩存機(jī)制,比如memcached,apc等。
f. 不經(jīng)常改動(dòng)的頁(yè)面,生成靜態(tài)頁(yè)面。
g. 書(shū)寫(xiě)高效率的SQL。
15、寫(xiě)出一種排序算法(要寫(xiě)出代碼),并說(shuō)出優(yōu)化它的方法。
//冒泡排序
function maopao($arr) {
$count = count($arr);
for($i=0; $i
for($j=0; $j
if($arr[$j] > $arr[$j+1]) {
$temp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1] = $temp;
}
}
}
return $arr;
}
//順序排序
function shunxu($arr) {
$count = count($arr);
for($i=0; $i
$p = $i;
for($j=$i+1; $j
$p = $arr[$p] > $arr[$j] ? $j : $p;
}
if($p != $i) {
$tvalue = $arr[$i];
$arr[$i] = $arr[$p];
$arr[$p] = $tvalue;
}
}
return $arr;
}
復(fù)制代碼
16、寫(xiě)個(gè)函數(shù)用來(lái)對(duì)二維數(shù)組排序。
function array_sort_by_any_row($array_name, $row_id, $order_type){
$array_temp=array();
foreach($array_name as $key=>$value){
$array_temp[$key]=$value[$row_id];
}
if($order_type==="ASC"){ //順序
asort($array_temp);
} else {
arsort($array_temp);
}
$result_array=array();
foreach($array_temp as $key=>$value){
$result_array[$key]=$array_name[$key];
}
return $result_array;
}
$arr = array(
array('num'=>5, 'value'=>6),
array('num'=>2, 'value'=>39),
array('num'=>36, 'value'=>29)
);
$sortarr = array_sort_by_any_row($arr, 'num', 'DESC');
print_r($sortarr);
復(fù)制代碼
17、寫(xiě)5個(gè)不同的自己的函數(shù),來(lái)截取一個(gè)全路徑的文件的擴(kuò)展名,允許封裝php庫(kù)中已有的函數(shù)。
$path = str_replace('\\', '/',__FILE__);
echo $path.'
';
function extname1($path) {
return strrchr($path, '.');
}
function extname2($path) {
$position = strrpos($path, '.');
return substr($path, $position);
}
function extname3($path) {
$arr = explode('.', $path);
return $arr[count($arr) - 1];
}
function extname4($path) {
preg_match_all('/[\w\/\:\-]+\.([\w]+)$/', $path, $out);
return $out[1][0];
}
function extname5($path) {
return preg_replace('/^[^\.]+\.([\w]+)$/', '${1}', basename($path));
}
print_r(extname5($path));
復(fù)制代碼
18、一群猴子排成一圈,按1,2,…,n依次編號(hào)。然后從第1只開(kāi)始數(shù),數(shù)到第m只,把它踢出圈,從它后面再開(kāi)始數(shù),再數(shù)到第m只,在把它踢出去…,如此不停的進(jìn)行下去,直到最后只剩下一只猴子為止,那只猴子就叫做大王。要求編程模擬此過(guò)程,輸入m、n, 輸出最后那個(gè)大王的編號(hào)。
function yuesefu($n,$m) {
$r=0;
for($i=2; $i<=$n; $i++) {
$r=($r+$m)%$i;
}
return $r+1;
}
print_r(yuesefu(3,3));
復(fù)制代碼
19、用少量代碼實(shí)現(xiàn)“Welcome to CCRF”字符串的反轉(zhuǎn)?
function rev($var) {
$i = 0;
while ($var[$i] ==='') {
$i++; //得到字符長(zhǎng)度
}
$data = '';
for ($j = $i-1 ; $j >= 0; $i-- ) {
$data .= $var[$j];
}
return $data;
}
復(fù)制代碼
20、寫(xiě)一個(gè)函數(shù),能夠便利指定目錄的文件。
/*
*定義一個(gè)函數(shù) 查看一個(gè)指定目錄的所有文件 包含子文件
*$dir 指定目錄名字
*/
function show_dir($dir) {
$files = array();
if(is_dir($dir)) {
if($dh = opendir($dir)) {
while (($file = readdir($dh)) !== false) {
if($file != "." && $file != "..") {
if(is_dir($dir."/".$file)) { //如果子文件是目錄則 遞歸調(diào)用 以該子文件的名字作為數(shù)組的索引
$files[$file] = show_dir($dir."/".$file);
} else { //不是文件則直接 存入數(shù)組
$files[] = $dir."/".$file;
}
}
}
closedir($dh);
return $files;
}
}
}
復(fù)制代碼
21、有一組數(shù),28、32、43、14、53、67、42、54、46、31寫(xiě)程序排列這組數(shù)(要求:第一個(gè)是最大的,第二個(gè)是最小的,第三個(gè)是剩下中最大的,第四個(gè)是剩下最小的,第五個(gè)是剩下中最大的,第六個(gè)是剩下中最小的,依次向下排列。
$a = array(28, 32, 43, 14, 53, 67, 42, 54, 46, 31);
$b = array(28, 32, 43, 14, 53, 67, 42, 54, 46, 31);
rsort($a); //對(duì)數(shù)組逆向排序
sort($b); //對(duì)數(shù)組順向排序
$num = sizeof($a); //計(jì)算數(shù)組中的單元數(shù)目或?qū)ο笾械膶傩詡€(gè)數(shù)
for($i=0; $i<=$num/2-1; $i++) {
$x[$i*2] = $a[$i];//把最小的放在第二位上
$x[$i*2+1] = $b[$i];//把最大的放在第一位
}
print_r($x);
//Array ( [0] => 67 [1] => 14 [2] => 54 [3] => 28 [4] => 53 [5] => 31 [6] => 46 [7] => 32 [8] => 43 [9] => 42 )
?>
復(fù)制代碼
點(diǎn)關(guān)注,不迷路
好了各位,以上就是這篇文章的全部?jī)?nèi)容了,能看到這里的人呀,都是人才。之前說(shuō)過(guò),PHP方面的技術(shù)點(diǎn)很多,也是因?yàn)樘嗔?#xff0c;實(shí)在是寫(xiě)不過(guò)來(lái),寫(xiě)過(guò)來(lái)了大家也不會(huì)看的太多,所以我這里把它整理成了PDF和文檔,如果有需要的可以
以上內(nèi)容希望幫助到大家,很多PHPer在進(jìn)階的時(shí)候總會(huì)遇到一些問(wèn)題和瓶頸,業(yè)務(wù)代碼寫(xiě)多了沒(méi)有方向感,不知道該從那里入手去提升,對(duì)此我整理了一些資料,包括但不限于:分布式架構(gòu)、高可擴(kuò)展、高性能、高并發(fā)、服務(wù)器性能調(diào)優(yōu)、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優(yōu)化、shell腳本、Docker、微服務(wù)、Nginx等多個(gè)知識(shí)點(diǎn)高級(jí)進(jìn)階干貨需要的可以免費(fèi)分享給大家,需要的可以加入我的
總結(jié)
以上是生活随笔為你收集整理的宇轩网络面试题目PHP,二十道接地气的php面试题,让你直接通过面试!就此奉上~...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python扫雷游戏课程设计小组任务计划
- 下一篇: 10年前国家征收房屋,将房子入了红线,但