虾皮 10.12 二面

虾皮 10.12 二面

base 上海,部门国际,搞东南亚外卖

14:01 - 14:54

  1. 面试官自我介绍

  2. 自我介绍

  3. 实验室项目背景

  4. 实验室项目 MySQL 和 redis 怎么用的

  5. Redis 的数据过期策略

  6. ES 倒排索引怎么实现的, 数据怎么存储的

  7. ConcurrentHashMap 的原理

  8. 从零设计一个缓存, 你会用什么数据结构,ConcurrentHashMap 能做吗?为什么

手撕:

  1. 对一个有序的链表,实现时间复杂度小于O(N) 的查询接口;

  2. 用非递归的方式实现快排

反问:部门业务,什么时候出结果

作者:青山___

链接:牛客网 - 找工作神器|笔试题库|面试经验|实习招聘内推,求职就业一站解决_牛客网

来源:牛客网

Redis 的数据过期策略

定时删除 惰性删除 定期删除 以及结合使用的策略 听都没听过,,,纯寄

ES 倒排索引怎么实现的, 数据怎么存储的

倒排通过高效分词和优化的存储结构 (词典 倒排列表 压缩技术) 以及分片和副本策略实现快速且准确的搜索功能

ConcurrentHashMap 的原理

JDK1.7 使用了锁分段技术保证线程安全 1.8取消了分段锁 采用CAS和synchronizede来保证并发安全 数据结构采用数组+链表/红黑树

CAS(Compare And Swap): 比较并替换,是一种无锁算法。在不使用锁的情况下实现多线程之间的变量同步。

从零设计一个缓存, 你会用什么数据结构,ConcurrentHashMap 能做吗?为什么

设计一个缓存系统时,虽然ConcurrentHashMap可以作为存储组件因其高效的并发处理能力,但还需结合其他机制来实现缓存淘汰策略、过期时间管理以及统计监控等功能。

手撕:

1. 对一个有序的链表,实现时间复杂度小于O(N) 的查询接口;

二分查找 哈希

块索引 加缓存

(根据下标查询?)

2. 用非递归的方式实现快排

使用栈操作 写一个分区函数

然后依次把所有的左右边界压栈

太核心了 寄

相关推荐
FQNmxDG4S3 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
虹科网络安全4 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje5 小时前
Java语法进阶
java·开发语言·jvm
rKWP8gKv75 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫5 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287925 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本5 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
yaoxin5211235 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
极客先躯7 小时前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图
用户60648767188967 小时前
AI 抢不走的技能:用 Claude API 构建自动化工作流实战
java