一些面经上的问题汇总

博客内容涉及了概率论中的线段随机分段形成三角形的问题,解释了正向代理和反向代理的区别,讨论了Java中ArrayList、HashMap的扩容机制,C++虚函数的实现原理,以及Chrome的多进程特性。还提到了数据库优化、线程池的组成、ABA问题的解决方案、爬虫的多线程选择,并讲解了如何使用top命令查看线程以及触发Full GC的条件。此外,还涵盖了数据结构如AVL树和红黑树,以及Dijkstra算法。
摘要由CSDN通过智能技术生成
  1. 一条长度为l的线段,随机在其上选2个点,将线段分为3段,问这3个子段能组成一个三角形的概率是多少?

    假设我们选择的两个点的坐标是x和y(先假设x < y),那么由三角形两边和大于第三边的性质,有:

         x+y-x>1-y 
         x+1-y>y-x 
         1-y+y-x>x
    

    由上述不等式得到:x < 0.5, 0.5 < y < x+0.5,然后画个图就能得到联合概率为1/8,不要忘了这个结果是在假设x < y时得来的,所以再乘以2,得到1/4。

  2. 正向代理和反向代理

    正向代理是一个位于客户端和目标服务器之间的代理服务器(中间服务器)。为了从原始服务器取得内容,客户端向代理服务器发送一个请求,并且指定目标服务器,之后代理向目标服务器转交并且将获得的内容返回给客户端。正向代理的情况下客户端必须要进行一些特别的设置才能使用。

    反向代理正好相反。对于客户端来说,反向代理就好像目标服务器。并且客户端不需要进行任何设置。客户端向反向代理发送请求,接着反向代理判断请求走向何处,并将请求转交给客户端,使得这些内容就好似他自己一样,一次客户端并不会感知到反向代理后面的服务,也因此不需要客户端做任何设置,只需要把反向代理服务器当成真正的服务器就好了

  3. ArrayList 是要插入的元素没地方插了再扩容, HashMap 是达到负载因子了就扩容

  4. C++ 虚函数的实现原理

    参考 https://www.cnblogs.com/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值