日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

宇轩网络面试题目PHP,二十道接地气的php面试题,让你直接通过面试!就此奉上~...

發布時間:2025/3/8 php 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 宇轩网络面试题目PHP,二十道接地气的php面试题,让你直接通过面试!就此奉上~... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、echo count(“abc”); 輸出什么?

答:"1"count

— 計算數組中的單元數目或對象中的屬性個數int count ( mixed var\[,intvar \[, intvar\[,intmode ] ), 如果 var 不是數組類型或者實現了 Countable 接口的對象,將返回 1,

有一個例外,如果 var 是 NULL 則結果是 0。對于對象,如果安裝了 SPL,可以通過實現 Countable 接口來調用 count()。該接口只有一個方法 count(),此方法返回 count() 函數的返回值。

2、用PHP寫出顯示客戶端IP與服務器IP的代碼

答:$_SERVER[‘SERVER_ADDR’] 服務器

$_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'];

}

復制代碼

3、error_reporting(2047)什么作用?

答:PHP 顯示所有錯誤 E_ALL

4、Js表單彈出對話框的函數是什么,并簡要描述。

alert(); 只是提示信息 無返回值

confirm; 點確實返回true 否則false

5、下面的程序會輸入是否?

$num = 10;

function multiply(){

$num = $num * 10;

}

Multiply();

echo $num;

?>

復制代碼

答案:10 若要調用 函數中使用globle $num;

6、echo,print()和print_r()有什么區別?

echo是一個語言結構,沒有返回值。

print是一個函數,返回int類型的值。[只能打印int string]

print_r()是一個函數,返回bool類型值,按結構輸出變量的值。打印關于變量的易于理解的信息[數組、對象等]

7、isset();empty();有什么區別?對于不同的數據的判斷的結果?

a=0;

a=0;a=’0’;

a=false;

a=false;a=null;

empty

如果 變量 是非空或非零的值,則 empty() 返回 FALSE。換句話說,""、0、“0”、NULL、FALSE、array()、var $var、未定義; 以及沒有任何屬性的對象都將被認為是空的,如果 var 為空,則返回 TRUE。

isset

如果 變量 存在(非NULL)則返回 TRUE,否則返回 FALSE(包括未定義)。變量值設置為:null,返回也是false;unset一個變量后,變量被取消了。注意,isset對于NULL值變量,特殊處理。

8、引用和拷貝有什么區別?

拷貝是將原來的變量內容復制下來,拷貝后的變量與原來的變量使用各自的內存,互不干擾。

引用相當于是變量的別名,其實就是用不同的名字訪問同一個變量內容。當改變其中一個變量的值時,另一個也跟著發生變化。

9、打開php.ini中的Safe_mode,會影響哪些函數?至少說出6個。

答:

用戶輸入輸出函數(fopen() file() require(),只能用于調用這些函數有相同腳本的擁有者)

創建新文件(限制用戶只在該用戶擁有目錄下創建文件)

用戶調用popen() systen() exec()等腳本,只有腳本處在safe_mode_exec_dir配置指令指定的目 錄中才可能

加強HTTP認證,認證腳本擁有者的UID的劃入認證領域范圍內,此外啟用安全模式下,不會設置PHP_AUTH

mysql服務器所用的用戶名必須與調用mysql_connect()的文件的擁有者用戶名相同

受影響的函數變量以及配置命令達到40個

10、寫個函數來解決多線程同時讀寫一個文件的問題。

答:flock($hander,LOCK_EX); 這個可是內置函數啊

11、請寫一個函數驗證電子郵件的格式是否正確(要求使用正則)

答:preg_match(’/^ [\w-.]+@[\w-]+(.\w+)+/’,/’,/’,email);

12、寫出匹配URL的正則表達式。

preg_match(’/(\w+)😕/([/:]+)(:\d*)?([# ]*)/’,$url);

13、寫出發帖數量最多的5~15個人名字的SQL語句,利用下表;

Members(id,username,posts,pass,email);

select username from Members order by 發帖數量 desc limit 4,10

復制代碼

14、MySQL數據庫,一天5萬條以上的增量,怎么優化?

a. 設計良好的數據庫結構,允許部分數據冗余,盡量避免join查詢,提高效率。

b. 選擇合適的表字段數據類型和存儲引擎,適當的添加索引。

c. mysql庫主從讀寫分離。

d. 找規律分表,減少單表中的數據量提高查詢速度。

e. 添加緩存機制,比如memcached,apc等。

f. 不經常改動的頁面,生成靜態頁面。

g. 書寫高效率的SQL。

15、寫出一種排序算法(要寫出代碼),并說出優化它的方法。

//冒泡排序

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;

}

復制代碼

16、寫個函數用來對二維數組排序。

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);

復制代碼

17、寫5個不同的自己的函數,來截取一個全路徑的文件的擴展名,允許封裝php庫中已有的函數。

$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));

復制代碼

18、一群猴子排成一圈,按1,2,…,n依次編號。然后從第1只開始數,數到第m只,把它踢出圈,從它后面再開始數,再數到第m只,在把它踢出去…,如此不停的進行下去,直到最后只剩下一只猴子為止,那只猴子就叫做大王。要求編程模擬此過程,輸入m、n, 輸出最后那個大王的編號。

function yuesefu($n,$m) {

$r=0;

for($i=2; $i<=$n; $i++) {

$r=($r+$m)%$i;

}

return $r+1;

}

print_r(yuesefu(3,3));

復制代碼

19、用少量代碼實現“Welcome to CCRF”字符串的反轉?

function rev($var) {

$i = 0;

while ($var[$i] ==='') {

$i++; //得到字符長度

}

$data = '';

for ($j = $i-1 ; $j >= 0; $i-- ) {

$data .= $var[$j];

}

return $data;

}

復制代碼

20、寫一個函數,能夠便利指定目錄的文件。

/*

*定義一個函數 查看一個指定目錄的所有文件 包含子文件

*$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)) { //如果子文件是目錄則 遞歸調用 以該子文件的名字作為數組的索引

$files[$file] = show_dir($dir."/".$file);

} else { //不是文件則直接 存入數組

$files[] = $dir."/".$file;

}

}

}

closedir($dh);

return $files;

}

}

}

復制代碼

21、有一組數,28、32、43、14、53、67、42、54、46、31寫程序排列這組數(要求:第一個是最大的,第二個是最小的,第三個是剩下中最大的,第四個是剩下最小的,第五個是剩下中最大的,第六個是剩下中最小的,依次向下排列。

$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); //對數組逆向排序

sort($b); //對數組順向排序

$num = sizeof($a); //計算數組中的單元數目或對象中的屬性個數

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 )

?>

復制代碼

點關注,不迷路

好了各位,以上就是這篇文章的全部內容了,能看到這里的人呀,都是人才。之前說過,PHP方面的技術點很多,也是因為太多了,實在是寫不過來,寫過來了大家也不會看的太多,所以我這里把它整理成了PDF和文檔,如果有需要的可以

以上內容希望幫助到大家,很多PHPer在進階的時候總會遇到一些問題和瓶頸,業務代碼寫多了沒有方向感,不知道該從那里入手去提升,對此我整理了一些資料,包括但不限于:分布式架構、高可擴展、高性能、高并發、服務器性能調優、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優化、shell腳本、Docker、微服務、Nginx等多個知識點高級進階干貨需要的可以免費分享給大家,需要的可以加入我的

總結

以上是生活随笔為你收集整理的宇轩网络面试题目PHP,二十道接地气的php面试题,让你直接通过面试!就此奉上~...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。