zoukankan      html  css  js  c++  java
  • 面试官说我“不讲武德?”普通本科生靠刷题字节四面成功!

    刚刚电话进来一个年轻人,体重九十多公斤,年轻人啪一下,很快啊,啪!左一个算法题,右一个项目,我大意了,没有答上来,传统面试点到为止,我说小伙子你不讲武德,他说他乱问的,他可不是乱问啊,有备而来。我劝年轻人,耗子喂汁,社招问题还是那些校招问题,社招要讲以和为贵,谢谢朋友们。

    一面

    1、介绍一下自己, 为什么选择出来看看机会

    2、聊项目, 警报怎么做的, 统一接入监控项怎么做的

    3、聊项目, 配置中心项目, 问实时配置推送怎么做

    4、讨论为什么选择所有的组件依赖放在配置中心中控制

    5、我现在要做一个限流功能, 怎么做?这个限流要做成分布式的, 怎么做?

    6、怎么抢锁?锁怎么释放?

    7、加了超时之后有没有可能在没有释放的情况下, 被人抢走锁?怎么解决?

    8、不用 zk 的心跳, 可以怎么解决这个问题呢?

    9、假如这个限流希望做成可配置的, 需要有一个后台管理系统随意对某个 api 配置全局流量, 怎么做?

    10、某一个业务中现在需要生成全局唯一的递增 ID, 并发量非常大, 怎么做

    11、算法题:M*N 横向纵向均递增的矩阵找指定数

    12、有什么想问我的?

    二面

    1、平时用的工具链和技术栈是什么?

    2、golang 踩过坑吗?这段 golang 代码有没有 bug?

    3、Java 中 HashMap 的存储, 冲突, 扩容, 并发访问分别是怎么解决的?

    4、拉链法中链表过长时变形为红黑树有什么优缺点?

    5、HashMap 的并发不安全体现在哪?

    6、HashMap 在扩容时, 对读写操作有什么特殊处理?

    7、ConcurrentHashMap 是怎么做到并发安全的?

    8、Java 有哪些锁机制, 分别有什么特点?

    9、知道 CAS 吗? Java 中 CAS 是怎么实现的?

    10、MySQL 的存储引擎用的是什么?(InnoDB)为什么选 InnoDB?

    11、MySQL 的聚簇索引和非聚簇索引有什么区别?

    12、B+树和二叉树有什么区别和优劣?

    13、针对一个场景设计索引,具体场景忘记了,反正考察的是联合索引与列选择性的知识

    14、现有一个新的查询场景, 要怎么解决?

    15、假如要查 A in () AND B in (), 怎么建索引?

    16、查 A in () AND B in () 时, MySQL 是怎么利用索引的?

    17、假如查询 A in (), MySQL 是针对 N 个值分别查一次索引, 还是有更好的操作?

    18、用过 Redis 的哪几种数据结构?ZSET 是怎么实现的?

    19、zrange start, stop, 总长度为 n, 复杂度是多少?

    20、Kafka 的消费者如何做消息去重?

    21、MySQL 去重、Redis 去重、假如场景量极大且允许误判,布隆过滤器也可以

    22、介绍一下 Kafka 的 ConsumerGroup

    23、Kubernetes 和 Docker 用得怎么样?

    24、时序型数据库的存储结构是怎么样的?

    25、LSM 树了解吗? 是一种什么存储结构?

    26、在生产中用过 Cassandra 和 RocksDB 吗?量有多大?

    27、Cassandra 的墓碑机制是什么?

    三面

    1、聊项目和工作经验

    2、用 Kubernetes 的过程中踩过哪些坑?

    3、考虑一个业务场景: 头条的文章的评论量非常大, 比如说一篇热门文章就有几百万的评论, 设计一个后端服务, 实现评论的时序展示与分页

    4、假如用 id 翻页的方式, 数据库表如何设计?索引如何设计?

    5、假如量很大, 你觉得需要分库分表吗? 怎么分?

    6、分库分表后怎么查询分页?

    7、分库分表后怎么保证主键仍然是递增的?

    8、现在需要支持深分页, 页码直接跳转, 怎么实现?

    9、瞬时写入量很大可能会打挂存储, 怎么保护?(断路器)

    10、断路器内部怎么实现的?(可以用 ringbuffer)

    11、断路器会造成写入失败, 假如我们不允许写入失败呢?

    12、算法题: N 场演唱会, 以 [{startTime, endTime}…] 的形式给出, 计算出最多能听几场演唱会

    HR面

    技术规划

    还投了哪些公司

    字节了解

    项目中最大的收获

    是不是看完面经之后还觉得有些迷惑,所以我给大家准备了字节面试的必刷面试题!由于文章篇幅限制,只能展示题目,需要答案解析以及面试资料的朋友们注意了,扫下方二维码可免费领取!!!


    Java基础

    1.JAVA 中的几种数据类型是什么,各自占用多少字节。

    2.String 类能被继承吗,为什么。

    3. 两个对象的 hashCode() 相同,则 equals() 也一定为 true,对吗?

    4. String 属于基础的数据类型吗?

    5.Java 中操作字符串都有哪些类?它们之间有什么区别?

    6.Java 中 IO 流分为几种?

    7.BIO、NIO、AIO 有什么区别?

    8.用过哪些 Map 类,都有什么区别,HashMap 时线程安全的吗,并发下使用的 Map 是什么,他们的内部原理分别是什么,比如存储方法,hashcode,扩容,默认容量等。

    9. 如何将字符串反转?

    10.抽象类必须要有抽象方法吗?

    11.普通类和抽象类有哪些区别?

    12.抽象类能使用 final 修饰吗?

    13.ArrayList 和 LinkedList 有什么区别?

    14.ConcurrentHashMap的数据结构(必考)

    15.volatile作用(必考)

    16.Atomic类如何保证原子性(CAS操作)(必考)

    17.为什么要使用线程池(必考)

    Redis

    • Redis的应用场景
    • Redis支持的数据类型(必考)
    • zset跳表的数据结构(必考)
    • Redis的数据过期策略(必考)
    • Redis的LRU过期策略的具体实现
    • 如何解决Redis缓存雪崩,缓存穿透问题
    • Redis的持久化机制(必考)
    • Redis为什么是单线程的?
    • 什么是缓存穿透?怎么解决?
    • Redis持久化有几种方式?
    • Redis为什么这么快?(必考)
    • Redis怎么实现分布式锁?
    • Redis如何做内存优化?
    • Redis淘汰策略有哪些?
    • Redis常见的性能问题有哪些?该如何解决?
    • Redis的使用要注意什么?

    ZooKeeper

    • CAP定理
    • ZAB协议
    • leader选举算法和流程
    • zookeeper 是什么?
    • zookeeper 有几种部署模式?
    • zookeeper 怎么保证主从节点的状态同步?

    Mysql

    • 事务的基本要素
    • 事务隔离级别(必考)
    • 如何解决事务的并发问题(脏读,幻读)(必考)
    • MVCC多版本并发控制(必考)
    • binlog,redolog,undolog都是什么,起什么作用
    • InnoDB的行锁/表锁
    • myisam和innodb的区别,什么时候选择myisam
    • 为什么选择B+树作为索引结构(必考)
    • 索引B+树的叶子节点都可以存哪些东西(必考)
    • 查询在什么时候不走(预期中的)索引(必考)
    • sql如何优化
    • explain是如何解析sql的
    • order by原理

    JVM

    • 运行时数据区域(内存模型)(必考)
    • 垃圾回收机制(必考)
    • 垃圾回收算法(必考)
    • Minor GC和Full GC触发条件
    • GC中Stop the world(STW)
    • 各垃圾回收器的特点及区别
    • 双亲委派模型
    • JDBC和双亲委派模型关系
    • JVM 中一次完整的 GC 流程是什么样子的,对象如何晋升到老年代,说说你知道的几种主要的 JVM 参数

    Spring

    • Spring的IOC/AOP的实现(必考)
    • 动态代理的实现方式(必考)
    • Spring如何解决循环依赖(三级缓存)(必考)
    • Spring的后置处理器
    • Spring的@Transactional如何实现的(必考)
    • Spring的事务传播级别
    • BeanFactory和ApplicationContext的联系和区别

    其他

    • 高并发系统的限流如何实现
    • 高并发秒杀系统的设计
    • 负载均衡如何设计

    操作系统篇

    • 进程和线程的区别
    • 进程同步的几种方式
    • 线程间同步的方式
    • 什么是缓冲区溢出。有什么危害,其原因是什么
    • 进程中有哪几种状态
    • 分页和分段有什么区别

    多线程篇

    • 多线程的几种实现方式,什么是线程安全
    • volatile 的原理,作用,能代替锁吗?
    • sleep 和 wait 的区别
    • sleep(0)的意义
    • Lock 和 Synchronized 的区别
    • synchronized 的原理是什么,一般用在什么地方(比如加载静态方法和非静态方法的区别)

    补充

    另外还会考一些计算机网络之类的。像消息队列,RPC框架这种考的比较少。计算机网络就是分层啊,tcp/udp啊,三次握手之类的。操作系统就是进程与线程啊,进程的数据结构以及如何通信之类的。

    数据结构的排序算法也比较常考,考的话一定会让你手写个快排。剩下的算法题就靠LeetCode的积累了。其实非算法岗考的算法题都蛮简单的,很多题完全就是考察你智力是否正常,稍微难点的涉及到一些算法思想的按照LeetCode题目类型的分类,每种题做一两道基本就能完全应付面试了。

    需要面试资料的朋友们注意了,扫下方二维码可免费领取!!!

  • 相关阅读:
    WPF中Auto与*的区别
    在XAML网格中RowDefinition High=“10*”
    WPF语言中Grid布局
    C# 解压缩文件
    WPF Visibility的用法
    Inno setup Compiler 安装程序
    征战蓝桥 —— 2014年第五届 —— C/C++A组第1题——猜年龄
    信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言——1082:求小数的某一位
    信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言——1082:求小数的某一位
    信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言——1082:求小数的某一位
  • 原文地址:https://www.cnblogs.com/ming569/p/14016478.html
Copyright © 2011-2022 走看看