PHP 篇网络了一些常见的根本、进阶口试题,根本的口试题不再作答。
根本篇
Get 和 POST 的差异

Cookie 和 Session 的差异和关系
单引号和双引号的差异
isset 和 empty 的差异
echo、print_r、print、var_dump 之间的差异
什么是 MVC?
传值和传引用的差异?
进阶篇
简述 S.O.L.I.D 设计原则
PHP7 和 PHP5 的差异,详细多了哪些新特性?
性能提升了两倍
增加了却合比较运算符 (<=>)
增加了标量类型声明、返回类型声明
try...catch
增加多条件判断,更多 Error 缺点可以进行非常处理
增加了匿名类,现在支持通过new class 来实例化一个匿名类,这可以用来替代一些“用后即焚”的完全类定义
为什么 PHP7 比 PHP5 性能提升了?
变量存储字节略小,减少内存占用,提升变量操作速率
改进数组构造,数组元素和 hash 映射表被分配在同一块内存里,降落了内存占用、提升了 cpu 缓存命中率
改进了函数的调用机制,通过优化参数通报的环节,减少了一些指令,提高实行效率
简述一下 PHP 垃圾回收机制(GC)
PHP 5.3 版本之前都是采取引用计数的办法管理内存,PHP 所有的变量存在一个叫zval
的变量容器中,当变量被引用的时候,引用计数会+1,变量引用计数变为0时,PHP 将在内存中销毁这个变量。
但是引用计数中的循环引用,引用计数不会消减为 0,就会导致内存透露。
在 5.3 版本之后,做了这些优化:
并不是每次引用计数减少时都进入回收周期,只有根缓冲区满额后在开始垃圾回收;
可以办理循环引用问题;
可以总将内存透露保持在一个阈值以下。
理解更多可以查看 PHP 手册,垃圾回收机制。
如何办理 PHP 内存溢出问题
增大 PHP 脚本的内存分配
变量引用之后及时销毁
将数据分批处理
Redis、Memecached 这两者有什么差异?
Redis 支持更加丰富的数据存储类型,String、Hash、List、Set 和 Sorted Set。Memcached 仅支持大略的 key-value 构造。
Memcached key-value存储比 Redis 采取 hash 构造来做 key-value 存储的内存利用率更高。
Redis 供应了事务的功能,可以担保一系列命令的原子性
Redis 支持数据的持久化,可以将内存中的数据保持在磁盘中
Redis 只利用单核,而 Memcached 可以利用多核,以是均匀每一个核上 Redis 在存储小数据时比 Memcached 性能更高。
Redis 如何实现持久化?
RDB 持久化,将 Redis 在内存中的的状态保存到硬盘中,相称于备份数据库状态。
AOF 持久化(Append-Only-File),AOF 持久化是通过保存 Redis 做事器锁实行的写状态来记录数据库的。相称于备份数据库吸收到的命令,所有被写入 AOF 的命令都因此 Redis 的协议格式来保存的。
扩展阅读
3年PHPer的口试总结
垃圾回收机制
S.O.L.I.D 面向工具设计
浅谈IOC--说清楚IOC是什么
Redis和Memcached的差异