shoxvc2000

shoxvc2000 查看完整档案

上海编辑中原工学院信息商务学院  |  软件工程 编辑  |  填写所在公司/组织填写个人主网站
编辑
_ | |__ _ _ __ _ | '_ \| | | |/ _` | | |_) | |_| | (_| | |_.__/ \__,_|\__, | |___/ 个人简介什么都没有

个人动态

shoxvc2000 提出了问题 · 2月2日

PHP-fpm管理机制

PHP-fpm不是应该是master进程监听9000端口么,为什么我看网络管理是worker进程监听9000端口?
微信截图_20210202145256.png
微信截图_20210202145329.png
是不是PHP7版本对fastCGI做了优化?

关注 1 回答 0

shoxvc2000 提出了问题 · 1月26日

关于MySQL索引的index_merge

关于MySQL的index_merge和复合索引有什么本质的区别,原理是什么?我有一个表有deleteTime和isFinish两个索引;

  • 当创建两个单独的索引的时候我用explain看到使用索引类型是index_merge,extra是intersect方式,rows是1360行;
  • 假如单独使用where deleteTime或者where isFinish这两个索引的话,rows分别是2600行左右;
  • 如果创建了(deleteTime,isFinish)这个复合索引的话结果的row是130行-符合预期。请问是什么原因?

请大神解惑

关注 2 回答 1

shoxvc2000 提出了问题 · 1月19日

MySQL事件设置问题

在MySQL设置了一个定时执行的事件,每天晚上23:55执行,但是看information.events表的执行结果发现最后一次执行时间是15:55,请问是什么原因?如果是时区的问题,我用select now()看到跟当前事件是对的上的
image.png
image.png

CREATE DEFINER=code@% EVENT NewEvent ON SCHEDULE EVERY 1 DAY STARTS '2021-01-06 23:55:00' ON COMPLETION NOT PRESERVE ENABLE DO BEGIN
UPDATE growth SET settle = 1 WHERE clubId in (SELECT clubId from club_ranking_ignore) AND settle = 0;

关注 3 回答 2

shoxvc2000 提出了问题 · 2020-12-29

node-kafka怎么订阅多个topic

如题,每个topic单独commit,单独设置offset

关注 1 回答 0

shoxvc2000 关注了问题 · 2020-10-30

微信小程序页面栈10层限制如何突破?

在提出这个问题之前,已经在各社区、搜索引擎看了很多关于如何突破限制的文章。既然如此,我为什么还要提出这个问题?因为那些解决方案还是难以解决我所需要的。

需求如下:

  1. 要求该小程序以正常流程走动
  2. 非设置、个人信息等类型页面栈,各页面栈之间需要能够相互之间跳转
  3. 有...a9,a10个页面栈,非必要情况下 a10 前往 a11 后返回的页面依旧是 a10

目前,需求2在我强烈劝说下,可使用 wx.redirectTo 进行跳转。然而,需求3仍然找不到办法解决。
作为多年小前端,做这个伸手党实在是不太好意思,肯请各路大神们给个思路!谢谢🙏

有个小思路是这样的:当在 a10 点击时,从页面栈 a4 开始逐渐将堆积的页面栈移除,不过发现目前能够一次性移除多个页面栈的只有 wx.navigateBack, delete 没有测试过,应该是不可行的。

关注 4 回答 2

shoxvc2000 提出了问题 · 2020-08-12

MySQL派生表的优化问题

查询的时候由于使用了子查询和join导致产生派生表,请问大神们怎么优化?imageimage

关注 1 回答 0

shoxvc2000 提出了问题 · 2020-08-10

想深入MySQL事务原理

想深入学习事务的原理应该看什么书

关注 2 回答 1

shoxvc2000 提出了问题 · 2020-08-04

PHP-fpm怎么实现进程间同步与互斥的?

如题,PHP如何实现进程间同步与互斥

关注 3 回答 2

shoxvc2000 收藏了文章 · 2020-07-22

高级PHP(初级架构师)面试题

PHP 篇

GC

  • PHP 7 的内存回收原理?

    请详细描述ZendMM的工作原理

  • 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中创建多进程有哪些方式?

    互斥信号该如何实现?

  • Swoole服务端启动后有哪些进程,这些进程分别是完成什么工作?
  • 线上环境中,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){
        //请实现
    
    }
    

内存优化

Cli

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

安全

  • PHP中密码加密,使用什么方式加密?

    这种加密的优点是什么?

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

反射

  • 实现如下函数(PHP 7)

    echo a(1, 3); //4
    echo a(3)(5); //8
    echo a(1, 2)(3, 4, 5)(6); //21
  • 如何读取某函数的参数列表,以及参数的默认值。
  • 如何模拟Java的注解方法,比如识别如下代码中的路由
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行锁在什么情况下会退化为表锁?
  • 数据库不使用B+树,还可以使用什么数据结构?
  • 为什么MySQL使用B+树,而不是其它树,比如红黑树
  • MySQL在什么时候会不使用索引?
  • Elasticsearch 如何实现类似SQLWHERE id = 12 AND gender IN ('male', 'unknow');
  • Elasticsearch 如何实现类似SQLGROUP BY nickname, gender
  • Redis 是如何保证执行的原子性的?
  • Redis有哪些数据结构,其中的bitmap, bloom filter用于什么场景?
  • Redis 在事务中如何做到:发现事务执行过程中数据被污染就回滚执行?

前端篇

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

ES 6

  • ES 6中的 Promise 对象是做什么的?
  • 解释ES 6async、await的使用场景?
  • ES 6遍历器Iterator 怎么写,其作用是什么?

    回调地狱(callback hell) 如何使用 遍历器Iterator 实现,提示:Thunk

  • 写出下面代码执行后输出的内容

    var p1 = new Promise(resolve => {
        console.log(1);
        resolve(2);
    })
    let p2 = new Promise(resolve => {
        console.log(3);
        resolve(p1);
    });
    p1.then(re => {
        console.log(re);
    });
    p2.then(re => {
        console.log(re);
    });
  • 请简述JavascriptEvent Loop规范,并描述MacroTask机制和MicroTask机制的区别,以及对应的函数?

Vue

  • vueangularJS 中检测脏数据的原理有什么区别?
  • vue中,vuex的主要作用是什么?
  • vuedatacomputed 有什么区别?

    {
        computed: {
            now() {
                return new Date();
            }
        }
    }

    上面的now变量,是否能够在每次调用时得到当前时间?

  • vuexmutationsactions 有什么区别?
  • vuex中如何在外部(可以理解为任意一段<script>中)设置变量的值,以及如何调用mutations

通讯协议篇

  • 详细描述 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如何完成一个分布式锁?
  • ZooKeeper 能解决哪些问题?具体说明。
  • 分布式一致性有哪些方案?

综合篇

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

shoxvc2000 提出了问题 · 2020-07-09

UNIAPP开发Android

使用uniapp开发Android应用会有什么坑?

关注 2 回答 1

认证与成就

  • 获得 7 次点赞
  • 获得 60 枚徽章 获得 0 枚金徽章, 获得 19 枚银徽章, 获得 41 枚铜徽章

擅长技能
编辑

开源项目 & 著作
编辑

(゚∀゚ )
暂时没有

注册于 2015-06-09
个人主页被 913 人浏览