123

PHP 篇

GC

  • PHP 7 的内存回收原理?
  • PHP 7 的垃圾回收和 PHP 5 有什么区别?

结构

  • PHP 7 中对zVal做了哪些修改?
  • PHP 7 中哪些变量类型在,哪些变量类型在

    变量在栈会有什么优势?PHP 7是如何让变量新建在栈的?

  • 详细描述PHPHashMap的结构是如何实现的?
  • 下面代码中,在PHP 7下, $a$b$c$d 分别指向什么zVal结构?

    $d 被修改的时候,PHP 7 / PHP 5 的内部分别会有哪些操作?

    $a = 'string';
    $b = &$a;
    $c = &$b;
    $d = $b;
    $d = 'to';
  • JIT 是做了哪些优化,从而对PHP的速度有不少提升?

字符串操作

  • strtrstr_replace 有什么区别,两者分别用在什么场景下?

    strtr的程序是如何实现的?

  • 字符串在手册中介绍,「PHP可安全用于二进制对象」,比如:str_replace strpos str等函数下都有这句话,这句话怎么理解,为什么是用于二进制是安全的?
  • 字符串连接符.,在PHP内核中有哪些操作?

    多次.连接,是否会造成内存碎片过多?

性能分析

  • 线上环境中,PHP进程偶尔会卡死(或者运行卡顿),请问如何检测本质问题?

中间件

  • Laravel的中间件的顺序执行,类似于下面的管道的实现,请实现管道的makeFn函数

    function pipe($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;
    };
    
    function makeFn($list){
        //请实现
    
    }
    

实现

  • PHP实现一个定时任务器,类似crontab,需要做到前一个任务不论运行时长、运行失败,都不能影响下一个任务的准点执行?

安全

  • RSA AES 加密的区别,分别用于什么场景下?

反射

  • 实现如下curry函数(PHP 7)

    echo a(1, 3); //4
    echo a(3)(5); //8
    echo a(1, 2)(3, 4, 5)(6); //21
  • 如何读取某函数的参数列表,以及参数的默认值。
  • 如何模拟Java的注解方法,比如识别如下代码中的路由
  • PHP 8中的注解 #Function(xxx) 需要如何实现
class Controller {
     /**
      * @Route("/", name="index")
      * @CheckRequest
      */
     public function index(Request $request){
         return 'result';
     }
}
  • 描述下IoCDI)的实现原理?

算法

  • 目前有{} () [] <>四种配对符号,要求写一个算法检查类似{([()()]<()>)}是否配对(此字符串是正确的配对),

    比如{([() --- (]) --- <()>)}即是不合规,因为---标记的部分(])]被隔断

    这种符号配对算法常用于语法判断,比如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 => 4
    aa => 5
    aabc => 1
    abc => 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点多人抢购的时候库存问题?

  • 如下数据库中会有哪些值

    //请注意是多重嵌套事务
    START TRANSACTION;
      INSERT INTO `users` (`name`) VALUES('a');
      START TRANSACTION;
        INSERT INTO `users` (`name`) VALUES('b');
        START TRANSACTION;
          INSERT INTO `users` (`name`) VALUES('c');
        ROLLBACK;
      COMMIT;
    ROLLBACK;
  • MySQL默认隔离RR下,行锁在什么情况下会退化为表锁?
  • 为什么MySQL使用B+树,而不是其它树,比如红黑树
  • MySQL在什么时候会不使用索引?
  • Elasticsearch 如何实现类似SQLWHERE id = 12 AND gender IN ('male', 'unknow');
  • Elasticsearch 如何实现类似SQLGROUP BY nickname, gender
  • Redis 是如何保证执行的原子性的?
  • Redis有哪些数据结构,其中的setsorted setbitmap, bloom filter用于什么场景?
  • Redis 在事务中如何做到:发现事务执行过程中数据被污染就回滚执行?

前端篇

  • 描述XSS注入原理,以及如何防止?
  • 描述Csrf注入原理,以及如何防止?

通讯协议篇

  • 详细描述 HTTPSSSL)工作原理?
  • Web服务器,客户端的IP能伪造吗?如果能,列出伪造方法;如果不能,说明原因?
  • 描述域名劫持的各种方法,为什么HTTPS不能被劫持?
  • 描述HTTP协议是什么,以及HTTP 2HTTP 1.1 有什么区别?
  • 详细描述IP协议TCP协议,以及UDP协议与它们的区别。
  • TCP协议中,最大传输单元MTU一般最大是多少,在TCP协议中,如果一个数据被分割成多个包,这些包结构中什么字段会被标记相同。
    UDP分包和TCP分包会有哪些区别?
  • HTTP协议Transfer-Encoding: Chunked 适用于哪些应用场景,这个与使用Content-Length: xxx在收到的报文包上有哪些区别?

分布式篇

  • 描述epollpoll、select的区别,为什么epoll会具备性能优势?
  • 描述下惊群的原因?有什么有效的方法可以避免惊群?
  • 什么是Hash一致性,这个方法主要运用在什么场景?
    如何实现增加新节点之后,整体做最小的数据移动
  • 有哪些常见分布式锁的解决方案,Redis如何完成一个分布式锁?
  • ZooKeeperEtcd 能解决哪些问题?具体说明。

综合篇

  • 比如: 我国在2020年1月1日08:00:00时, 东京是2020年1月1日09:00:00, 请问他们此时的时间戳差异多少?
  • 描述OAuth2的工作原理,绘制出其工作的时序图?
  • Swoole 或 Go 中协程实现原理,以及为什么会提升效率?
  • Swoole服务端启动后有哪些进程,这些进程分别是完成什么工作?
  • 列出几个中文分词工具?
  • git 放弃未提交的文件有哪些方法?
    git删除远程分支、Tag有什么方法?
    git覆盖远程仓库有什么办法?

member
6.2k 声望159 粉丝

擅长计算机开关机、Windows系统的安装。