二十道接地气的php面试题,让你直接通过面试!就此奉上~

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

答:"1"count

— 计算数组中的单元数目或对象中的属性个数int count ( mixed $var [, int $mode ] ), 如果 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、下面的程序会输入是否?

<?php

$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=’0’; a = f a l s e ; 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个。

答:

  1. 用户输入输出函数(fopen() file() require(),只能用于调用这些函数有相同脚本的拥有者)

  2. 创建新文件(限制用户只在该用户拥有目录下创建文件)

  3. 用户调用popen() systen() exec()等脚本,只有脚本处在safe_mode_exec_dir配置指令指定的目 录中才可能

  4. 加强HTTP认证,认证脚本拥有者的UID的划入认证领域范围内,此外启用安全模式下,不会设置PHP_AUTH

  5. mysql服务器所用的用户名必须与调用mysql_connect()的文件的拥有者用户名相同

  6. 受影响的函数变量以及配置命令达到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<$count-1; ++$i) {

        for($j=0; $j<$count-$i-1; ++$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<$count-1; ++$i) {
        $p = $i;
        for($j=$i+1; $j<$count; ++$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.'<br />';

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、写一个函数,能够便利指定目录的文件。

<?php

/*

*定义一个函数  查看一个指定目录的所有文件 包含子文件

*$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写程序排列这组数(要求:第一个是最大的,第二个是最小的,第三个是剩下中最大的,第四个是剩下最小的,第五个是剩下中最大的,第六个是剩下中最小的,依次向下排列。

<?php
$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和文档,如果有需要的可以

点击进入暗号: PHP+「平台」

在这里插入图片描述

在这里插入图片描述


更多学习内容可以访问【对标大厂】精品PHP架构师教程目录大全,只要你能看完保证薪资上升一个台阶(持续更新)

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要的可以加入我的 PHP技术交流群

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值