7.24 华为提前批Java视频一面

全程一小时,非常准时,面试官也挺nice,就是我比较菜

  1. 聊项目相关,主要是 Kafka Connect 的一些知识
  2. Kafka 可靠性:zookeeper,分布式集群,partition 的 leader 和 follower
  3. 多进程之间的通信方式:管道、共享存储器、消息传递系统(翻了一下操作系统,发现 C/S 模式没答上来)
  4. Java 内存模型,说了一下作用还有主内存+工作内存,还有内存间相互操作的一些命令、约束
  5. Spring 微服务?(我简历里有提到 Spring,但是没有提到微服务,后面得知是部门业务相关所以问了)
  6. OpenStack 了解吗?(同上)
  7. 聊了一下7.15笔试的最后一题(完全背包)
  8. 手撕算法(详情见后文)
  9. volatile 能用来实现免锁队列吗?(我答的是不能保证原子性所以不能)
  10. 如何实现免锁队列?(答了CAS,队列元素用原子类包装)
    1. 面试官一直在问我免锁队列的关键指令是什么?我说了"CompareAndSet"才让他满意

反问环节:

  1. 我还有机会吗?—— 你们提前批都有
  2. 编码风格和习惯?—— 挺好的(主要是手撕算法结束之后,他特意提到编码风格,我就问了一下)
  3. 知识储备需要补充哪些内容?(扯到部门的业务上面去了……和我讲了讲 openstack)

手撕代码:

对字符串列表中的每个字符串进行压缩,输出一个压缩后的字符串列表,要求和原列表的位置相对应

  • 压缩:保留头尾字符,中间用省略掉的字符个数填充,例如 kubernetes 压缩为 k8s
  • 如果出现两个字符串的压缩结果相同,需要从左开始,减少省略的字符,直到压缩结果不同
    • aabbcc & abbbcc => a4c, 改成 aa3c, ab3c
  • 若压缩后的字符串长度没有比原来的短,就输出原先的字符串
  • 提供一个辅助方法,它可以生成从字符串指定位置开始压缩得到的结果
public List<String> wordsCompress(List<String> data);

private String compressHelper(String word, int start){
    // compressHelper("internet", 1) -> "i6t"
    // compressHelper("internet", 2) -> "in5t"
    // compressHelper("internet", 3) -> "int4t"
}

// sample case
// input
{"like", "god", "me", "internet", "internal", "interval", "intension", "face", "intrusion"}

// output
{"l2e", "god", "me", "i6t", "internal", "interval", "inte4n", "f2e", "intr4n"}

说实话自己挺菜的,一开始想了个漏洞百出的错误思路,后来经过面试官提示才写出正确思路:

  • 先预处理列表,把长度相同的字符串组织成一个列表,然后按长度存哈希表
  • 再对每一个长度的哈希桶进行遍历,辅助函数的第二个参数从1递增,直到这个桶生成的不同的压缩结果数和桶内原列表的字符串数相等
  • 整体的所有压缩结果用一个原字符串到压缩结果的字符串的哈希表存一下,方便生成结果
#面经##Java##秋招##校招#
全部评论
lz 哪个部门的提前批啊?
1 回复 分享
发布于 2020-07-24 19:34
老哥,如果提前批没过还可以秋招投吗
点赞 回复 分享
发布于 2020-07-24 19:22
华为有提前批?
点赞 回复 分享
发布于 2020-07-24 20:06
华为有提前批?+1
点赞 回复 分享
发布于 2020-07-24 20:09

相关推荐

10-16 13:44
已编辑
南京邮电大学 测试开发
点赞 评论 收藏
分享
10-15 10:13
已编辑
门头沟学院 Java
记录的意义在于学习,华为的面试官对技术这一块我感觉真的专业,尤其是二面的面试官,感觉很大佬的样子。一面不会的问题:1.&nbsp;元空间相关的垃圾回收问题,full&nbsp;GC2.&nbsp;代理模式和装饰器模式的区别3.&nbsp;final关键字修饰的抽象类能不能被继承4.&nbsp;final关键字修饰的抽象方法能不能被重载和重写5.&nbsp;finalize关键字的作用(其实final是我自己作出来的,真的点到为止即可,不要过多的延伸)6.&nbsp;好像是“遮掩”和“遮蔽”的区别7.&nbsp;项目中提到的使用sharding-jdbc进行分库分表,路由是如何做的8.&nbsp;分库分表分了几个表========================================================二面,面试官看着我的项目问的,用一些开源的项目让如此大佬来问,我真的觉得脸红惭愧,自己做的一堆垃圾,大佬还要想办法如何问这个问题才合适。没答上来的很多,但答案都在项目里写着。1.&nbsp;线程池如何来创建,线程池的核心参数2.&nbsp;如果你写了一个接口,访问的速度非常慢,那你应该如何来处理优化&nbsp;&nbsp;&nbsp;&nbsp;这个问题的原因是项目里写了我用了Redis3.&nbsp;还是这个接口,假设SQL&nbsp;Redis层面都没问题,响应速度还是很慢,你应该如何处理&nbsp;&nbsp;&nbsp;&nbsp;这里我想了一会,他直接提示,从JVM层面考虑,我还是没想到&nbsp;&nbsp;&nbsp;&nbsp;简单一点,你来说一下如何定位问题吧——应该是使用JVM相关的工具,但我一点不会4.&nbsp;相关的设计模式5.&nbsp;看到你用了分库分表,如果有多个实例,你如何避免资源的竞争&nbsp;&nbsp;&nbsp;&nbsp;这个是因为简历上写了Redis的分布式锁,也答了分布式锁SETNX。6.&nbsp;你用到了Kafka,那我问你,Kafka应该在什么场景下使用&nbsp;&nbsp;&nbsp;&nbsp;我把kafka应用场景背了一遍,面试官说是为了连接生产者和消费者(有一个很关键的词,我忘掉了)========================================================主管面,就放开面了,自觉的一二面表现很一般,基本已经知道结果了,就每太纠结,正常和主管聊天了番外:面完晚上还梦到了入职华为,导师是二面的面试官,醒来一看天亮了,才知道什么事真正的白日做梦
投递华为等公司10个岗位
点赞 评论 收藏
分享
评论
2
19
分享
牛客网
牛客企业服务