GC
PHP 7 的内存回收原理?
PHP 7 的垃圾回收和 PHP 5 有什么区别?
结构
PHP 7 中对zVal做了哪些修改?
PHP 7 中哪些变量类型在栈,哪些变量类型在堆?
变量在栈会有什么优势?PHP 7是如何让变量新建在栈的?
详细描述PHP中HashMap的结构是如何实现的?
下面代码中,在PHP 7下, $a 和 $b、$c、$d 分别指向什么zVal结构?
$d 被修改的时候,PHP 7 / PHP 5 的内部分别会有哪些操作?
$a = 'string';
$b = &$a;
$c = &$b;
$d = $b;
$d = 'to';
JIT 是做了哪些优化,从而对PHP的速度有不少提升?
字符串操作
strtr 和 str_replace 有什么区别,两者分别用在什么场景下?
strtr的程序是如何实现的?
字符串在手册中介绍,「PHP可安全用于二进制对象」,比如:str_replace strpos str等函数下都有这句话,这句话怎么理解,为什么是用于二进制是安全的?
字符串连接符.,在PHP内核中有哪些操作?
多次.连接,是否会造成内存碎片过多?
性能分析
线上环境中,PHP进程偶尔会卡死(或者运行卡顿),请问如何检测本质问题?
中间件
Laravel的中间件的顺序执行,类似于下面的管道的实现,请实现管道的makeFn函数
functionpipe($input, $list) {
$fn = makeFn($list);
return$fn($input);
}
$r = pipe(0, [$a, $b, $c]);
echo$r;
//$a, $b, $c 类似于$a = function($input, $next) {
$input++;
$output = $next($input);
return$output;
};
functionmakeFn($list){
//请实现
}
实现
用PHP实现一个定时任务器,类似crontab,需要做到前一个任务不论运行时长、运行失败,都不能影响下一个任务的准点执行?
安全
RSA AES 加密的区别,分别用于什么场景下?
反射
实现如下curry函数(PHP 7)
echo a(1, 3); //4echo a(3)(5); //8echo a(1, 2)(3, 4, 5)(6); //21
如何读取某函数的参数列表,以及参数的默认值。
如何模拟Java的注解方法,比如识别如下代码中的路由
PHP 8中的注解 #Function(xxx) 需要如何实现
classController{
/**
* @Route("/", name="index")
* @CheckRequest
*/publicfunctionindex(Request $request){
return'result';
}
}
描述下IoC (DI)的实现原理?
算法
目前有{} () [] <>四种配对符号,要求写一个算法检查类似{([()()]<()>)}是否配对(此字符串是正确的配对),
比如{([() --- (]) --- <()>)}即是不合规,因为---标记的部分(])让]被隔断
这种符号配对算法常用于语法判断,比如IDE。(下面是配对示例),比如以下PHP代码中的括号不论如何嵌套,都必须保持配对的原则才能通过编译:
if ($a) {
$user['posts'][ $user['id_list'][ User::get($request['token'])['id'] ] ] = null;
}
生成2亿个优惠券码,长度在14位,有效字符是3456789ABCDEFGHJKMNPQRSTUVWXY,其中不含有印刷歧义的0 O 1 I L 2 Z。需要快速生成并设计一个结构,能快速发放,并且快速验证是否已经被使用
写一个最长匹配的替换算法,比如字符串aabcabcabaa根据下面替换关系,得到的结果是1345,最长匹配会这样分割:aabc abc ab aa
替换对应关系如下
ab=> 4aa=> 5aabc=> 1abc=> 3
有一个文件,保存了20亿行的数字,每个数字长度在5-10之间,这些数字中有很多重复,设计一个算法在只有2核1G内存的电脑上对这些数字快速去重并保存?
数据库篇
搭建MySQL分布式,有哪些方式?
MySQL主从同步,和主主同步有哪些区别,以及优劣势?
Laravel中,多态一对多,多态多对多,数据库要怎么设计?
比如一个关键词表tags,需要关联用户、帖子、评论、视频等表。
描述MySQL的注入原理,以及防止注入有哪些方式?
怎么解决数据库中常见的 N+1 效率问题
比如:
$users = SELECT * FROM `users` WHERE `gender` = 'male';
foreach ($users as &$user)
$user['posts'] = SELECT * FROM `posts` WHERE `user_id` = $user['id'];
MySQL中脏读应该怎么处理?
引申:比如京东的库存,0点多人抢购的时候库存问题?
如下数据库中会有哪些值
//请注意是多重嵌套事务
STARTTRANSACTION;
INSERTINTO `users` (`name`) VALUES('a');
STARTTRANSACTION;
INSERTINTO `users` (`name`) VALUES('b');
STARTTRANSACTION;
INSERTINTO `users` (`name`) VALUES('c');
ROLLBACK;
COMMIT;
ROLLBACK;
MySQL默认隔离RR下,行锁在什么情况下会退化为表锁?
为什么MySQL使用B+树,而不是其它树,比如红黑树?
MySQL在什么时候会不使用索引?
Elasticsearch 如何实现类似SQL的 WHERE id = 12 AND gender IN ('male', 'unknow');
Elasticsearch 如何实现类似SQL的 GROUP BY nickname, gender
Redis 是如何保证执行的原子性的?
Redis有哪些数据结构,其中的set、sorted set、bitmap, bloom filter用于什么场景?
Redis 在事务中如何做到:发现事务执行过程中数据被污染就回滚执行?
前端篇
描述XSS注入原理,以及如何防止?
描述Csrf注入原理,以及如何防止?
通讯协议篇
详细描述 HTTPS(SSL)工作原理?
Web服务器,客户端的IP能伪造吗?如果能,列出伪造方法;如果不能,说明原因?
描述域名劫持的各种方法,为什么HTTPS不能被劫持?
描述HTTP协议是什么,以及HTTP 2 和 HTTP 1.1 有什么区别?
详细描述IP协议、TCP协议,以及UDP协议与它们的区别。
TCP协议中,最大传输单元MTU一般最大是多少,在TCP协议中,如果一个数据被分割成多个包,这些包结构中什么字段会被标记相同。
UDP分包和TCP分包会有哪些区别?
HTTP协议中 Transfer-Encoding: Chunked 适用于哪些应用场景,这个与使用Content-Length: xxx在收到的报文包上有哪些区别?
分布式篇
描述epoll和poll、select的区别,为什么epoll会具备性能优势?
描述下惊群的原因?有什么有效的方法可以避免惊群?
什么是Hash一致性,这个方法主要运用在什么场景?
如何实现增加新节点之后,整体做最小的数据移动
有哪些常见分布式锁的解决方案,Redis如何完成一个分布式锁?
ZooKeeper、Etcd 能解决哪些问题?具体说明。
综合篇
比如: 我国在2020年1月1日08:00:00时, 东京是2020年1月1日09:00:00, 请问他们此时的时间戳差异多少?
描述OAuth2的工作原理,绘制出其工作的时序图?
Swoole 或 Go 中协程实现原理,以及为什么会提升效率?
Swoole服务端启动后有哪些进程,这些进程分别是完成什么工作?
列出几个中文分词工具?
git 放弃未提交的文件有哪些方法?
git删除远程分支、Tag有什么方法?
git覆盖远程仓库有什么办法?