杭州某国企 Java 面经

2024-03-05 12:04
文章标签 java 面经 杭州 国企

本文主要是介绍杭州某国企 Java 面经,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

杭州某国企 Java 面经

面试官:这边收到你的xxx简历,现在方便做一个简单的面试沟通吗?

我:方便的方便的,内心OS:面经+1。

1)

面试官:先做个自我介绍吧

我:常规操作,比八股背的熟多了,主要突出我全栈的一个学习过程,并且做了一个开源项目,我这边给大家的建议,尤其是双非同学,如果没啥亮点的话,个人博客和喜欢写一些笔记,画一些思维导图,喜欢看技术书籍,是比较好的亮点,如果不是电话面,可以直接给面试官共享屏幕,或者让他访问你的博客,这是一个很大的加分项,92 的同学直接学历碾压了,本身学历就是亮点,所以可能没有什么产出的话,问题也不是很大,千万别说自己的缺点…

2)

面试官:把你的项目给我简单介绍一下

我:阿巴阿巴,介绍项目的主要两个亮点功能,从需求分析、技术选型、业务实现,一步步讲下来,在重点和难点的时候再多加以阐述即可。

3)

面试官:你的数据是存在哪里的?

我:MySQL 数据库,面试官追问查询优化方面,我主要阐述了慢查询日志的使用,和利用索引覆盖的特性,加快查询速度,这块结合具体的业务场景去讲就好了,可以把 Jemter 的参数跑出来会更可信。

4)

面试官:所有的情况都可以用索引覆盖吗?

我:no,只有 Where、Group By、Join 这些后面的字段如果没有加索引,才能够利用索引覆盖,而且索引并不是加的越多越好,阐述下索引在变动过程中需要维护,这部分时间也需要进行考虑。

5)

面试官:缓存你用过哪些?

我:我的项目主要是用了 Redis,然后面试官追问 Redis 的数据结构底层原理,比如字符串的 SDS,对比原有 C 语言字符串的好处,比如 O(1) 获取长度,不会缓冲区溢出,二进制安全,减少修改字符串的内存重新分配次数(惰性空间释放,空间预分配)

6)

面试官:缓存过期策略了解吗?

我:惰性删除机制在取出 key 时进行过期检查,对 CPU 友好,定期删除机制会每隔一段时间抽取一批 key 执行删除过期 key 操作,对内存更加友好, Redis 采用的是定期删除+惰性删除,此外利用内存淘汰机制进行兜底,数据淘汰策略在 Redis 4 版本以前有 6 种,4 以后新增了两种 LFU 的算法。

7)

面试官:你用过哪些设计模式?

我:阿巴阿巴,主要包括门面模式(外观)、适配器模式、注册器模式、模版方法模式、策略模式等等,结合业务代码区讲就好了。

8)

面试官:你觉得什么时候需要用到单例模式?

我:频繁实例化被销毁,频繁 new 对象,保证全局只有一个对象实例,创建对象耗时过多或者耗费资源过多,经常使用该对象,频发访问 IO 的对象,比如数据库连接池,SpringBean 的单例注册表也是有一个缓存池。

9)

面试官:解释下线程安全和不安全

我:阿巴,多线程竞争一个共享资源,这边可以介绍下临界区等,操作系统的知识,还可以介绍下死锁等等,可以结合具体的超卖问题。

10)

主要问了下能多久到岗,实习多久等等,我反问了工作时间和待遇,然后直接拒了,实习生还要加班,而且待遇太低了,直接面经+1。

开源 AI 项目 Gitee 地址:https://gitee.com/falle22222n-leaves

欢迎老铁们 Star 下!累计总后端 700 + Star ,最近在写详细的文档,后续将会推出。⭐⭐⭐

北京某科技数字有限公司 Java 面经

1)

面试官:先讲一下 RESTFUL 风格怎么使用?

我:阿巴阿巴,四种方法讲一下,然后配合 @PathVariable 注解讲一下,路径占位符讲一下,RESTFUL 的好处讲一下,比如路径更简洁、安全(不暴露参数),高效(支持缓存),差不多就行。

2)

面试官:Post 请求的数据是放在哪里?

我:呃呃呃,表单用一个对象存,然后请求有请求头,请求行,请求体,请求体存储表单数据,简单的前端问题,可以对比下 GET 和 POST 区别,比如安全方面,数据长度限制方面等等,只要你会的,都可以按逻辑进行阐述,简单的问题其实去做一个完整的阐述,表达这块建议大家多面试练练。

3)

面试官:文件这块是怎么传输的?

我:我项目是上传过 Excel 文件主要利用了,MultiPartFile 这个工具类 SpringMVC 提供的,用 IO 读取就可以了,我写了个 Excel 工具类读取。

4)

面试官:你项目的安全框架用了什么?

我:阿巴阿巴,这边没用 SpringSecurity、Shrio、Sa-Token ,我就简单用了 AOP 底层代理模式+适配器+一个 JWT,主要用 Token 令牌进行一个,Token 存 Redis,然后动态刷新 Token 机制,用户无感知,这边要听 Redis 的过期策略和内存淘汰机制就更好了,能输出一波。

5)

面试官:JWT 密钥放在哪里?

我:服务端配置文件编写,我这边每个用户注册有 AK,SK,SK 就是密钥,可以根据密钥生成不同的 Token。

6)

面试官:Token 的参数构成有哪些?

我:Header(签名算法和令牌类型),PayLoad 负载包含用户信息、令牌颁发时间、过期时间等等,Signature 是根据头部、负载、密钥加密后合成的结果,一般的 xxx.xxx.xxx。

7)

面试官:Token 存放在哪里?

我:LocalStorage 这边,发送 Axios 请求时,多一个 Authorization 请求头携带 Bearer 空格 + Token

8)

面试官:Token 是怎么生成的?

我:JWT 工具类,用户登录之后,前端会得到一个我后端 Generate 的一个参数,前端获取后存下来就好。

9)

面试官:ArrayList,LinkedList,HashMap 各自的优缺点和使用场景讲一下

我:这边不作赘述了,常见的八股文,按自己的实践和单列集合和双列集合使用场景就可以了,考源码也无所谓都是简单题,比如 Map 的 Put 流程,为什么链表大于等于 8 并且数组长度>=64 树化,为什么从 8 到 6 后退化,Hash 冲突有几种解决方案,各自有什么好处,多线程 HashMap 安全吗,Key Value 为 Null 问题等等,可以讲的东西太多了,可能一个问题讲好几分钟也是正常,只要面试官想听,其实可以一直讲。

10)

面试官:ArrayList 和 LinkedLIst 获取数据的时间复杂度

我:O(1) 和 O(N),数组和链表…

11)

面试官:你数据库掌握能力怎么样?

我:比较弱,只做过几个多表连接,然后说一下,左右连接的区别,内连接,再说一下实际项目怎么写的 SQL,怎么做 SQL 优化等等,索引数据类型,索引失效,事务,隔离级别,三大日志,刷盘时机,MVCC 怎么实现的?行锁,表锁,意向锁,共享锁,独占锁,InnoDB 引擎对比 MyISAM 的优势等等,数据库要是问起来半小时起步了。

12)

面试官:输入 URL 后的一系列流程是什么?

我:URL 检查、缓存查询(计算机网络)、DNS 解析、获取 MAC 地址、TCP 三握、HTTPS 握手、返回数据、页面渲染(DOM)、TCP 四挥,其实这里面每一个都可以阐述,基本是计算机网络的基础知识。

13)

反问技术栈、主要做的业务,以及工作时间和待遇,总体来说面试比较简单,比较浅层,没啥深度考究,过了一天电话说 OC 了,然后是经典流程,拒了…未完待续

开源 AI 项目 Gitee 地址:https://gitee.com/falle22222n-leaves

欢迎老铁们 Star 下!累计总后端 700 + Star ⭐⭐⭐

这篇关于杭州某国企 Java 面经的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/776441

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定