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等多個知識點高級進階干貨需要的可以免費分享給大家,需要的可以加入我的