博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP中常见的面试题2(附答案)
阅读量:6291 次
发布时间:2019-06-22

本文共 3929 字,大约阅读时间需要 13 分钟。

---恢复内容开始---

1.下面程序输出是什么?

$int_a = 5;function factorial() {  for($int_i=$int_a; $int_i>0; $int_i--) {    $int_a = $int_a * $int_i;   }}factorial();echo $int_a;

结果:  5

 

2. 写一个函数Check_ip,使用正则表达式检测一个IPV4的IP是否正确,正确返回1,错误返回0,例如 Check_ip(‘127.0.0.1’)。

function check_ip($mact){        $a='/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/';        $v=preg_match($a,$mact);        if ($v!=0) {            return  1;        } else {            return  0;        }  }

 

 

3. 请指出以下代码的错误之处(圈出来并加以改正):

”;   }    }
$value){ echo $key.””.$value.”
”; } }?>

 

4.  有一数组 $a=array(4,3,8,9,2); 写一个排序函数对数组进行排序操作,要求使用快速排序法.快速排序的基本思想是:在待排序记录序列中,任取其中的一个记录(这里取了第一个)并以该记录的关键字作为基准,经过一趟排序后,所有关键字比它小的记录都交换到它的左边,比它大的记录都交换到它的右边.然后再分别对划分到它左,右两部分记录序列重复上述过程,直至每一部分最终划分为一个记录时为止即完成了排序工作.

//参考答案function kuaiSort($arr){    //递归的出口    if (count($arr) <= 1) return $arr;    //取出第一个元素    $flag = $arr[0];    //声明两个数组    $left = [];    $right = [];    //注意这里的索引是从1开始的    for ($i = 1; $i < count($arr); $i++) {        if ($arr[$i] > $flag) {            $right[] = $arr[$i];        } else {            $left[] = $arr[$i];        }    }    $left = kuaiSort($left);    $right = kuaiSort($right);    return array_merge($left, [$flag], $right);}

 

5. 有一表 menu(id, pid, name),请用递归法打印树形菜单,将所有的menu列出来.

/*参考sql   create table menu (      id int auto_increment primary key,      pid int,      name varchar(255)   )engine MyISAM default charset=utf8;   insert into menu values (1,0,'服装'),(2,0,'数码'),(3,1,'外套'),(4,3,'男装'),(5,2,'手机'),(6,3,'女装'); *///函数实现function getMenu($pid) {      $pdo= new PDO('mysql:host=localhost;dbname=lamp;charset=utf8','root','');      //获取pid为 $pid的菜单      $stmt = $pdo->query("select * from menu where pid = $pid");      $menus = $stmt->fetchAll(PDO::FETCH_ASSOC);      //判断      if(empty($menus)) {         return;      }      $res = [];      foreach ($menus as $key => $value) {         $value['submenu'] = getMenu($value['id']);         $res[] = $value;      }     return $res;}$res = getMenu(0);

 

6. 在开发项目中,需要上传超过8M的文件,请说明在php.ini需要修改的配置项。

  post_max_size=2M(默认)

  Upload_max_filesize=8M(默认)

 

 

7. 写出session的运行机制,session与cookie的区别。多台WEB服务器如何共享session。

  (1)session的运行机制:

    用户A访问站点Y,如果站点Y指定了session_start();(以下假设session_start()总是存在)那么会产生一个session_id,这个session_id一般会以COOKIE的形式保存到用户A(我们可以通过在php.ini里设置session.use_only_cookies为1,强制SESSIONID必须以COOKIE专递。)。这时候SESSION ID表现为$_COOKIE[‘PHPSESSID’];(PHPSESSID可用session_name()函数来下修改),用户A接着访问,这个session id($_COOKID[‘PHPSESSID’])就会在A每次访问Y的时候传送到站点Y。在站点Y上,会有这么一个目录,是用来保存SESSION的实际数据的。站点Y接收到session id,然后通过session id,来获得与SESSION数据的关联,并返回SESSION数据

  (2)session与cookie的区别:

    1. 存储位置

    Cookie在客户端存储,消耗客户端资源, session在服务器存储,消耗服务器资源.

    2. 安全性

    Session相对安全, cookie相对不安全, 因为用户可以看到传递的信息

    3. 大小限制

    单个cookie的最大长度为4k, session没有大小限制

    4. 过期机制

    Cookie的过期是实时, 过期时间一到cookie就会失效, 但session的过期是概率性触发, 也就是说即时session过期并不是立即就失效.

  (3)多台服务器如何共享SESSION:

    session专门存储到一台独立的服务器上,存数据库,memcache,redis都可以, 多台服务器都来这台服务器上操作session即可.

 

8. SQL中LEFT JOIN 的含义是什么? 如果tbl_user记录了学生的姓名(name)和学号(ID),tbl_score记录了学生(有的学生考试以后被开除了,没有记录)的学号(ID)和考试成绩(score)以及考试科目(subject),要想打印出各个学生姓名及对应的各科总成绩,请写出SQL语句.

学号 id
姓名 name

 

 

 

学号 id
成绩 score
科目 subject

 

 

 

 

id

name

1

a

2

b

 

 

 

 

Id

Score

subject

1

10

语文

1

20

数学

2

30

语文

2

40

数学

 

 

 

 

 

 

 

答:left join 的含义:LEFT JOIN是以左

  表为基准进行外联查询。

SQL:  select tbl_user.name sum(tbl_score.score) from tbl_user   left join tbl.score on tbl_user.id=tbl_score.id;

 

9. 读代码

$val) { $val = &$data[$key]; //输出数组 var_dump($data); }?>

问题1:程序执行时,每一次循环结束后变量$data的值是什么?请解释

答:第一次循环时,把下表为0的成员,引用赋值给变量$val,$val与$data[0]内容相同,

要是其中一个改变,另一个也改变,此时,$data原样输出,只是$data[0]变成了引用

输出结果 a b c

第二次循环时,$key的值为1,把$data[1]引用复制给$val.

由于$val与$data[0]也是引用关系,所以这时,$val,$data[0],$data[1]三者值同为’B’

$val不再与$data[0]有关系了,只与$data[1]是引用关系

// b  b  c

第三次循环时,$key的值为2,把$data[2]引用复制给$val,

由于$data[1]与$val是引用关系,所以都将改变$data[1]、$val、$data[2]三者值一样

//b c c

问题2:程序执行完后,变量$data的值是什么?请解释。(10分)

答:结果为B c c

转载于:https://www.cnblogs.com/AngryBigCat/p/7277560.html

你可能感兴趣的文章
对象的继承及对象相关内容探究
查看>>
Spring: IOC容器的实现
查看>>
Serverless五大优势,成本和规模不是最重要的,这点才是
查看>>
Nginx 极简入门教程!
查看>>
iOS BLE 开发小记[4] 如何实现 CoreBluetooth 后台运行模式
查看>>
Item 23 不要在代码中使用新的原生态类型(raw type)
查看>>
为网页添加留言功能
查看>>
JavaScript—数组(17)
查看>>
Android 密钥保护和 C/S 网络传输安全理论指南
查看>>
以太坊ERC20代币合约优化版
查看>>
Why I Began
查看>>
同一台电脑上Windows 7和Ubuntu 14.04的CPU温度和GPU温度对比
查看>>
js数组的操作
查看>>
springmvc Could not write content: No serializer
查看>>
Python系语言发展综述
查看>>
新手 开博
查看>>
借助开源工具高效完成Java应用的运行分析
查看>>
163 yum
查看>>
第三章:Shiro的配置——深入浅出学Shiro细粒度权限开发框架
查看>>
80后创业的经验谈(转,朴实但实用!推荐)
查看>>