记录一次java面试(一)

本文分享了一次技术面试经历,详细解析了面试官提问的多个技术模块,包括Java基础、微服务设计等,以及面试者的回答与反思,提供了面试准备的方向。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近参加了一次面试,我这篇文章将对面试进行复盘,因为没有复盘的面试,不是一次成功的面试。

面试问题大概几个模块:

1、java基础

2、javaweb

3、运维

4、数据库

5、微服务基础

6、微服务设计

7、成长性

第一次面试的问题:

都是循序渐进的,这是我面试的一些回答,以及反思

1、io,nio,aio的区别?

回答:io 是 同步阻塞,nio同步非阻塞,aio当时记不大清(以为自己没用过,其实后来一想,Callable,Future不就是aio吗),

aio异步非阻塞

2、讲讲nio

回答:nio 是同步非阻塞,由一个或多个线程处理多个channel,基于事件驱动,也就是selector,Linux 的 selector,poll,epoll,如果可以讲讲这方面就更好了

3、问有用过Spring吗?IOC是个咋回事?

回答:用过,IOC就是控制反转,也可以叫依赖注入,将本来由程序员做的一些操作,比如new 对象,现在交个spring容器来处理,简化了编程。

4、那IOC创建的对象默认是单例对吧?那么他是否是线程不安全的呢?

回答:是的,Ioc创建对象默认是单例,也可以通过scope的prototype设置为非单例,他是线程不安全的,因为他是单例模式,是会出现线程不安全的情况

5、那么让你来做如何让他保证线程安全呢?

回答:可以,我之前对HttpRequestServlet也进行过测试,我将其使用@Autowide注解方式注入,然后测试了高并发情况下,我发现它是线程安全的,然后我分析它的源码,发现了它底层使用的是ThreadLocal来保证线程安全。

6、那么来问问你微服务,微服务使用过哪些组件?

回答:eureka做注册中心,config来做中心化配置,hystrix来做服务降级熔断。。。。。。

7、那么讲一讲hystrix

回答:hystrix做服务降级熔断,熔断方面就像一个断路器,当请求失败超过一定的阈值,则将其处于熔断状态,然后熔断一定时间,将恢复半熔断状态,半熔断状态可以接受请求,不用快速失败,如果请求成功则恢复。

8、那么来设计一下几个服务,服务A,下订单,服务B,涨积分,服务C,调用物流接口,现在支付成功后设计,可以使用其他的组件,如果需要的话

回答:我认为下订单要给客户一个良好的体验,时间越短越好,流程越短越好,所以我认为将其分为核心业务和非核心业务,比如订单服务为核心业务,涨积分为非核心业务(当时这里我对物流不清楚,我就把它划分成核心业务了= =沙雕),一个请求过来,先同步走订单服务,然后再将涨积分服务发送给MQ,让积分服务监听MQ,这里就将涨积分服务给异步实现了。

9、那么如果这里涨积分如果失败了怎么办?

回答:(当时这里我就知道要考分布式事务了)当时我用过txn框架,是一款分布式事务处理的框架,采用的是补偿机制。

我还认为分布式事务也可以不用技术方面来实现,我之前公司是做互联网金融的,如果是P2P,有一个用户下了100万的订单,但是P2P,都知道,100万订单可能并不是一单,而是将100万拆成了许多单,比如10个10万,那么现在有一个失败了,总不能让其回滚把,那么现在就需要由客服马上电话处理,通知该用户,我们将把您下的单进行处理,所以这里用人工服务更好,我们要让用户已最快的速度将钱打过来,给用户一个良好的体验

大概谈到这里,就差不多了,也谈了将近40分钟。

然后就结束了这一次面试。

总的来说,面试官会将你所掌握的知识,尽可能的深入挖掘,看看你最终能够回答到哪一步,他们不是为了想出难的题目让你回答不出来,而是想看看你对知识的掌握边界在哪,更好的了解你。

 

### Java 面试问题及答案 以下是针对具有 1 到 3 年经验的 Java 开发者的常见面试问题及其解答: #### 、基础概念 1. **什么是面向对象编程?Java 中如何体现这些特性?** - 面向对象编程 (OOP)种基于对象的程序设计范式,其核心理念包括封装、继承和多态。 封装通过将数据和行为绑定在起并隐藏内部实现细节来增强安全性[^1]。例如,在 Java 中可以通过 `private` 访问修饰符保护字段,并提供公共方法供外部调用。 继承允许子类从父类中获取属性和方法,从而减少重复代码并提升扩展性。例如,使用关键字 `extends` 创建子类。 多态使得同操作可以作用于不同的对象类型上,增强了灵活性和可维护性。 2. **解释装箱与拆箱的过程以及它们的作用。** - 装箱是指将基本数据类型自动转换为其对应的包装器类型的操作,而拆箱则是相反过程——将包装器类型转换回基本数据类型。这种机制简化了开发者的工作流程,减少了显式的类型转换需求[^2]。例如: ```java Integer a = Integer.valueOf(123); // 装箱 int b = a.intValue(); // 拆箱 ``` #### 二、集合框架 3. **ArrayList 和 LinkedList 的区别是什么?** - ArrayList 基于动态数组实现,随机访问性能较高(时间复杂度为 O(1)),但在中间位置插入或删除元素时效率较低(需移动大量元素)。LinkedList 使用双向链表结构存储元素,虽然随机访问较慢(时间复杂度为 O(n)),但插入和删除操作更高效,因为只需调整指针即可完成操作[^3]。 4. **HashMap 的工作原理是什么?** - HashMap 实现了个键值对映射的数据结构,底层依赖哈希表实现快速存取功能。当插入记录时,会先计算该 key 对应的 hash 值以决定它应该被放置在哪个桶里;如果发生冲突,则采用拉链法解决碰撞问题。此外,默认初始容量为 16,负载因子为 0.75,这意味着当实际大小超过此比例时会发生扩容操作[^4]。 #### 三、线程与并发 5. **Thread 类 vs Runnable 接口的区别在哪里?** - Thread 类本身实现了 Runnable 接口,因此可以直接覆盖 run 方法定义任务逻辑或者传递个实现了 Runnable 接口的对象给它的构造函数。相比直接继承 Thread 来说,推荐优先考虑实现 Runnable 或 Callable 接口的方式,这样能够更好地遵循单职责原则并且更容易与其他组件集成[^5]。 6. **synchronized 关键字是如何工作的?** - synchronized 可用于同步方法或代码块,确保每次只有个线程能进入临界区执行特定部分代码。对于实例方法而言,锁住的是当前对象(this),而对于静态方法来说则锁定整个 Class 对象。另外需要注意死锁风险以及性能开销等问题[^6]。 #### 四、异常处理 7. **try-catch-finally 结构中的 finally 是否总会被执行?** - 不论 try 块内的语句是否抛出了未捕获的异常还是正常结束返回,finally 子句几乎总是会被执行一次用来释放资源等清理动作。唯例外情况是在 JVM 提前终止之前已经退出应用程序的情况下才不会运行 finally[]^7]^。 --- ### 示例代码片段 以下是些可能涉及的实际编码场景: ```java // 展示 synchronized 的简单应用 public class Counter { private int count; public synchronized void increment() { this.count++; } public int getCount() { return this.count; } } ``` ```java // Lambda 表达式演示 List<String> names = Arrays.asList("Alice", "Bob", "Charlie"); names.forEach(name -> System.out.println(name)); ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值