2019最新整理PHP面试题附答案( 三 )


基本锁类型:锁包括行级锁和表级锁
28、索引的作用?和它的优点缺点是什么?
答:索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索 。它很类似与现实生活中书的目录,不需要查询整本书内容就可以找到想要的数据 。索引可以是唯一的,创建索引允许指定单个列或者是多个列 。缺点是它减慢了数据录入的速度,同时也增加了数据库的尺寸大小 。
29、如何通俗地理解三个范式?
第一范式:1NF是对属性的原子性约束,要求属性具有原子性,不可再分解;
第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;
第三范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余 。
30、主键、外键和索引的区别?
定义:
主键--唯一标识一条记录,不能有重复的,不允许为空
外键--表的外键是另一表的主键, 外键可以有重复的, 可以是空值
索引--该字段没有重复值,但可以有一个空值
作用:
主键--用来保证数据完整性
外键--用来和其他表建立联系用的
索引--是提高查询排序的速度
个数:
主键--主键只能有一个
外键--一个表可以有多个外键
索引--一个表可以有多个唯一索引
31、简述 private、 protected、 public修饰符的访问权限 。
private : 私有成员, 在类的内部才可以访问 。
protected : 保护成员,该类内部和继承类中可以访问 。
public : 公共成员,完全公开,没有访问限制 。
32、堆和栈的区别?
A、堆是程序运行期间动态分配的内存空间,你可以根据程序的运行情况确定要分配的堆内存的大小;
B、栈是编译期间就分配好的内存空间,因此你的代码中必须就栈的大小有明确的定义 。
33、常用的魔术方法有哪些?举例说明
答:php规定以两个下划线(__)开头的方法都保留为魔术方法,所以建议大家函数名最好不用__开头,除非是为了重载已有的魔术方法 。
__construct() 实例化类时自动调用 。
__destruct() 类对象使用结束时自动调用 。
__set() 在给未定义的属性赋值的时候调用 。
__get() 调用未定义的属性时候调用 。
__isset() 使用isset()或empty()函数时候会调用 。
__unset() 使用unset()时候会调用 。
__sleep() 使用serialize序列化时候调用 。
__wakeup() 使用unserialize反序列化的时候调用 。
__call() 调用一个不存在的方法的时候调用 。
__callStatic()调用一个不存在的静态方法是调用 。
__toString() 把对象转换成字符串的时候会调用 。比如 echo 。
__invoke() 当尝试把对象当方法调用时调用 。
__set_state() 当使用var_export()函数时候调用 。接受一个数组参数 。
__clone() 当使用clone复制一个对象时候调用 。
34、$this和self、parent这三个关键词分别代表什么?在哪些场合下使用?
$this 当前对象
self 当前类
parent 当前类的父类
$this在当前类中使用,使用->调用属性和方法
self也在当前类中使用,不过需要使用::调用
parent在类中使用
35、作用域操作符::如何使用?都在哪些场合下使用?
调用类常量
调用静态方法
36、__autoload()方法的工作原理是什么?
答:使用这个魔术函数的基本条件是类文件的文件名要和类的名字保持一致 。
当程序执行到实例化某个类的时候,如果在实例化前没有引入这个类文件,那么就自动执行__autoload()函数 。
这个函数会根据实例化的类的名称来查找这个类文件的路径,当判断这个类文件路径下确实存在这个类文件后
就执行include或者require来载入该类,然后程序继续执行,如果这个路径下不存在该文件时就提示错误 。
使用自动载入的魔术函数可以不必要写很多个include或者require函数 。
37、简述高并发网站解决方案 。
A、前端优化(CND加速、建立独立图片服务器)
B、服务端优化(页面静态化、并发处理[异步|多线程]、队列处理)
C、数据库优化(数据库缓存[Memcachaed|redis]、读写分离、分库分表、分区)
D、Web服务器优化(负载均衡、反向代理)
38、PHP遍历文件夹下所有文件
<?phpfunction read_all($dir){ if(!is_dir($dir)) return false; $handle = opendir($dir); if($handle){ while(($fl = readdir($handle)) !== false){ $temp = $dir.$fl; //$fl !='.' && $fl != '..' 排除当前目录及父级目录 if(is_dir($temp) && $fl!='.' && $fl != '..'){ echo '目录:'.$temp.'<br>'; read_all($temp); }else{ if($fl !='.' && $fl != '..'){ echo '文件:'.$temp.'<br>'; } } } }}read_all("./dir/");?>


推荐阅读