很幸运遇到超棒的导师

刚跟导师one-one完,受益很多,感觉少走5年弯路。
总结就是:不能只是做业务需求crud,也要有技术意识和底蕴,鼓励我每天抽时间专门学习技术,
“不怕你学,就怕你不学”。
我也很崇拜导师,不仅业务做得好,很多技术点+业务坑考虑得也很周全,很多时候提出的业务完善idea也很棒。不push并时常关心我。梦中情导!#暑期记录#
全部评论

相关推荐

一面(35min)1. 自我介绍22. 如何按照插入的顺序去遍历hashMap?3. LinkedHashMap是怎么实现的?4. HashMap在多线程的情况下会出现哪些问题?5. 如何删除HashMap中指定的value的所有记录?6. Java中如何关闭一个线程池?7. 任何时候执行shutdownNow方法都能强制关闭线程池吗?8. 假设一个表中a、b、c、d四个字段,有一个查询语句:select a from table where b = ? and c > ? and d < ?,怎么建9. 索引使得这个查询效率最快?10. 谈谈你对ClickHouse的理解11. 用ES和ClickHouse去存储同样的数据,谁消耗的内存空间会更大?12. ClickHouse查询很快的原因是什么?13. 如何实现分页查询?14. 深分页问题怎么解决?15. 以快手举例,每个用户会有一个关注列表和被关注列表,有关注和取消关注操作,请问应该怎么设计数据存储结构来实现这个功能?二面 + HR面(45min)1. 一段Java代码从编写到执行输出结果这个过程经历了哪些操作?操作系统在这个里面干了什么?2. 问竞赛经历,数学模型怎么建立的、怎么调参的,用的哪些数学理论?3. 一个HTTP请求从客户端发出,到接受到response,这个过程经历了哪些事情?4. 服务端是怎么找到对应资源的?5. 如果是HTTPS发起的请求跟HTTP相比有什么不同?6. HTTPS加密的是什么样的数据?怎么加密的?防止哪些不安全的行为呢?7. 加密的算法分为哪些类型呢?RSA是对称还是非对称?RSA又有几种算法的变种?8. hash是什么?在哪些地方会用到?9. 问实习10. linux内核代码有没有了解过?11. Docker用过没12. 谈谈你对ClickHouse和Hive的了解13. 有了解过Hbase吗?14. MQ用过哪些?整体体验一般,二面连着hrbp一起的,后面反问业务跟我说了快二十分钟,面试官也挺有耐心的后续:OC已拒(面的秋招,但说先发实习offer,等能签三方再发正式offer,感觉不太靠谱...)
点赞 评论 收藏
分享
1. 个人介绍2. 实习经历3. 开源经历的项目介绍和个人贡献4. 实习期间项目背景、系统架构、主要技术栈及负责的功能模块7. 常用数据库(MySQL、MongoDB、PostgreSQL等)及使用场景8. select id,name,balance from account where update_time > '2020-09-19' offset 100000 limit 10;8.1 该 SQL 语句做什么事情?8.2 在 update_time 列上加上普通索引,请从数据库引擎层面解释这条SQL的查询过程是怎样的?8.3 在 update_time 这个列对应的索引中,它的叶子节点存的是什么数据?叶子节点会存储整行的所有数据吗?8.4 基于以上过程,这条 SQL 是不是需要执行两次数据库 IO 操作?8.5 原 SQL 加上 for update 的执行语义和执行效果。9. Redis9.1 Redis 常用的数据类型有哪些?String、Set、ZSet 分别适合什么场景?9.2 Redis 的 ZSet 底层是怎么实现的?9.3 跳表的特点是什么?索引是怎么生成的?9.4 Redis 是怎么删除过期键的?9.5 实习期间项目里 Redis 存了什么数据?缓存策略怎么做的?10. Nacos 在项目中怎么用?它的配置更新和服务交互机制是怎样的?11. Kafka11.1 核心组件和概念有哪些?Producer:消息生产者;Consumer:消息消费者;Broker:Kafka 服务器节点;Topic:消息分类主题;Partition:主题的分片,保证单分区内消息有序;Replica:分区副本,保证高可用。11.2 Kafka 消费者组 Rebalance 是什么?11.3 Kafka 是否支持 Exactly Once?会不会丢数据?11.4 Kafka 分区副本是怎么同步的?11.5 Raft 和 Paxos 算法是做什么的?区别是什么?12. 从磁盘把数据加载到内存,操作系统是怎么做的?涉及哪些机制?13. 目前在实习的项目中做了什么?项目背景和流程是什么?14. 给出并解释程序运行结果14.1 程序 Apackage mainimport "fmt"func main() {b := []int{1, 2, 3, 4, 5, 6}c := b[1:3]c[1] = 999fmt.Println(c)fmt.Println(b)}14.2 程序 Bpackage mainimport "fmt"func Append(s []int) {s = append(s, 5)}func Add(s []int) {for i := range s {s[i] = s[i] + 5}}func main() {s := []int{1, 2, 3, 4}Append(s)fmt.Println(s)Add(s)fmt.Println(s)}15. 题目一(leetcode 102. 二叉树的层序遍历)16. 题目二:现在有一个 DelayQueue 结构体,你需要实现它,使它具备延时队列的功能。// DelayQueue 延时队列type DelayQueue struct {}func NewDelayQueue() *DelayQueue {return nil}// Put 将元素放入延时队列func (dq *DelayQueue) Put(value any, delay time.Duration) {}// Get 从延时队列中获取元素,如果当前没有元素,或者元素还没有到期,则阻塞func (dq *DelayQueue) Get() any {return nil}func main() {dq := NewDelayQueue()dq.Put("World", 3*time.Second)dq.Put("Hello", 1*time.Second)// prints "Hello" 1s later// prints "World" 2s laterfor i := 0; i < 2; i++ {println(dq.Get().(string))}}具体要求:1. 调用 Put(value, delay) 时,把一个元素放入队列,并指定它在 delay 时间之后才可被取出。2. 调用 Get() 时,如果当前没有可取的元素(队列为空,或最早的元素还没到时间),则需要阻塞,直到有元素可取为止。多个元素可能有不同的延迟时间,Get() 必须按到期时间的先后顺序依次返回。比如:dq.Put("World", 3*time.Second)dq.Put("Hello", 1*time.Second)运行时应在 1 秒后打印 "Hello",再过 2 秒打印 "World"。3. 要求支持多个 goroutine 并发调用 Put() 和 Get(),不能发生数据竞争。4. 希望实现效率较高,比如 Get() 查找下一个到期元素的时间复杂度尽量低(提示:可以考虑最小堆或优先队列)。你需要在现有的 DelayQueue 代码基础上补全 NewDelayQueue()、Put() 和 Get() 方法,实现上述功能。请你先讲一讲你的设计思路,然后写出代码。
查看27道真题和解析
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务