阿里巴巴史上最全Java面试题总结(程序员必备)

本文里的面经内容全部来源于牛客网,作为秋招备战复习与查缺补漏时使用。里面部分面经有我的注释和想法,以及部分解答,不一定正确,大家可以查询补充。

阿里巴巴,三面,java实习
昨天晚上11点打电话来,问我可以面试不,我说不可以,然后就约到了今天,
1.上来问我项目用的框架,然后问我springmvc里面有的参数的设定,问的是细节,然后问我如果传的多个值是一个对象的属性,问我如何处理,我说直接在后端接收为对象就行了,然后突然问我http怎么传对象,这里有点不明白面试官想问啥,然后就换别的问题了,
可以序列化对象为二进制数据,然后在http1.1以上版本传输即可,然后再进行反序列化

2.数据库索引都有哪些,介绍一下,然后面试官就问我说话的漏洞,感觉会抓住某一个比较突出的词来逼问,这里除非特别清楚,否则就被问死了,我这里有点虚,回答的有点犹豫,
b+树,hash索引,b树索引

3.数据库事务,然后问我mysql三个select不显式声明事务,他们每一条是个事务吗?这里记得有点不清楚,就是问不显式声明事务,select是一个事务吗
默认autocommit,每一条都是是一个事务

4.乐观锁和悲观锁,我说到了cas,然后问我java中有哪些地方用到了cas,然后我说concurrenthashmap,然后是咋用的,这个类是怎么保证线程安全的,他还说了一个put啥东西我没注意,就说不知道。
chm,原子类,AQS等。
chm在put操作没有冲突时进行cas尝试,直到成功。
原子类使用cas执行自加自减操作防止并发问题。
AQS的修改state也是使用了cas操作。
5.问我序列化,然后问到了远程方法调用,我说没接触过
序列化主要是把对象压缩成二进制数据,进行网络传输,rpc就是基于序列化和网络通信编程实现的。
6.问我项目是练手还是买钱,他笑着对我说,我也笑了
7.dao层是model层吗?这个以前没注意,就说是,也不知道对不对,记得以前面试好像有面试官问我model和pojo的区别
差远了。dao是数据持久化层,负责数据库操作,model负责数据模型。
8.索引在什么情况下会失效,这个当时有点激动,想了一下没说出来,有点遗憾,
前缀匹配,没用用到,函数,判空,<>等
今天面试,面试官给人的感觉很强势,会抓你回答问题的漏洞,也根据我的语气问我不熟悉的地方,剩下的问题没想起来,面了30分钟,面试官很nice

  篇幅限制下面就只能给大家展示小册部分内容了。整理了一份核心面试笔记包括了:Java面试、Spring、JVM、MyBatis、Redis、MySQL、并发编程、微服务、Linux、Springboot、SpringCloud、MQ、Kafka 面试专题

需要全套面试笔记【点击此处即可】免费获取

阿里一面

简单说说在学校做过最有成就感的事情(和技术相关的)
开发了一款游戏,搭了一个人博客,写了博客集,做了3个项目。并且在GitHub上有长期记录。
你的项目用到了数据库,谈谈对事务的理解
事务保证一致性,原子性,隔离性和持久性。
假设你要做一个银行app,有可能碰到多个人同时向一个账户打钱的情况,有可能碰到什么问题,如何解决(锁)
可能到时同时修改,导致有人修改失败,汇款出现问题,解决方式就是事务或者使用锁。
说说乐观锁和悲观锁
乐观锁在数据库中就是MVCC,悲观锁就是行锁和表锁。innodb支持行锁,在索引上加锁
最近在看什么书
大数据,zookeeper,netty。大型中间件,大型分布式,大型网站
Java基础(就问了一句==和equals)

说说现在能写出来哪些排序算法
快排,冒泡,选择,归并,插入,堆排序。计数排数,桶排序。

在学校有没有参加社团之类的
有的。

给定一个文件名,如何在d盘找出来这个文件,说说思路。
使用操作系统查找。find -name,locate,whereis

可以来杭州么(我意向写的北京)
能来实习的时间大概是什么时候

就聊了20分钟,感觉问的都很简单。。
然而11号晚上面试的,今天还是面试中,是不是要凉了

1.自我介绍,刚开始,有点懵,两句介绍完了,太不好了,
2.项目中自己觉得做的最好的地方,因为自己的项目真的没有啥亮点,都是基本业务层的实现,所以说了个前段的,然后嘴贱说了个redis,被问死,面试官说你猜的还是看别人的,我说猜的,然后就尴尬了。
3.java虚拟机类加载机制
双亲委派加载
4.java中的锁

5.反射,怎么实现,一激动说成了序列化,
因为Java虚拟机会把类加载到方法区,并且保留Class对象作为每个类的元对象,通过这个对象就可以获取该类的信息,从而获取它的方法,构造函数,变量等内容。
通过反射,还可以动态地指定实现类,因为反射可以通过配置文件来配置实现类。然后加载该类到方法区,通过构造方法进行实例化。
6.数据库的索引,隔离级别几种,分别是啥,然后就没问了,我还以为会让我详细解释一下。

7.快速排序思想

8.问我jdk看的第几版,嘴贱了一下,说了
1.8,然后问我hashmap默认的数据结构,果不其然问到了红黑树,然后问红黑树插入,果断不会,这太套路了
红黑树的增删改查都比较复杂,但是就是先操作,然后进行树的调整,保证几个特性符合要求。
1 根节点是黑节点
2 红节点不相邻
3 根节点到每个叶子节点的黑节点数都相同,于是保证整棵树的平衡性。
(3)每个叶子节点(NIL)是黑色。 [注意:这里叶子节点,是指为空(NIL或NULL)的叶子节点!]
(4)如果一个节点是红色的,则它的子节点必须是黑色的。

9.问道spring,问我都用到了哪些里面的东西,我说ioc,本来问我ioc的实现,突然,问我控制反转了什么,最后说完这个,就没问实现了,直接问我还有啥问他。

控制反转主要为了对象实例化的解耦,只需要写上接口就可以,通过配置文件或者注解将实际对象注入。
并且由Spring的bean容器来管理所有的对象。

感觉不好,开始的项目中的redis自己把自己坑死了,这次面试以前都很开心,这次不知怎么,一点都开心不起来,可能好运用完了

Java基础

面试题1: 解释==equals的区别。

答案

  • ==用于比较两个引用是否指向同一对象(对于基本数据类型是比较值)。
  • equals是一个方法,用于比较对象内容是否相等,默认行为是比较引用,但可以被覆写。
编程题1: 编写一个类Person,包含姓名和年龄属性,并覆写equals方法以比较两个Person对象的姓名和年龄是否相等。
public class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Person person = (Person) o;
        return age == person.age && Objects.equals(name, person.name);
    }

    // Getters and setters
}

容器

面试题2: 描述ArrayListLinkedList的区别。

答案

  • ArrayList是基于动态数组实现的,支持快速随机访问。
  • LinkedList是基于双向链表实现的,支持快速插入和删除。
编程题2: 实现一个方法,使用LinkedList实现一个队列,并进行入队和出队操作。
import java.util.LinkedList;

public class MyQueue {
    private LinkedList<Integer> list = new LinkedList<>();

    public void enqueue(int element) {
        list.addLast(element);
    }

    public int dequeue() {
        if (list.isEmpty()) {
            throw new NoSuchElementException("Queue is empty");
        }
        return list.removeFirst();
    }

    public boolean isEmpty() {
        return list.isEmpty();
    }
}

多线程

面试题3: 描述synchronizedReentrantLock的区别。

答案

  • synchronized是Java内置的同步机制,简单易用,但不够灵活。
  • ReentrantLockjava.util.concurrent.locks包中的一个类,提供了更灵活的锁定机制。
编程题3: 使用ReentrantLock实现一个简单的线程安全的计数器。
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class Counter {
    private int count = 0;
    private final Lock lock = new ReentrantLock();

    public void increment() {
        lock.lock();
        try {
            count++;
        } finally {
            lock.unlock();
        }
    }

    public int getCount() {
        lock.lock();
        try {
            return count;
        } finally {
            lock.unlock();
        }
    }
}

JVM

面试题4: 解释Java中的垃圾回收机制。

答案

  • Java通过垃圾回收器自动回收不再使用的对象,释放内存资源。
  • 主要涉及到标记-清除、复制、标记-整理等算法。
编程题4: 如何检测一个对象是否可回收?

答案

  • 在Java中,可以通过System.gc()建议JVM进行垃圾回收,但最准确的检测需要通过垃圾回收日志分析。

框架

面试题5: Spring框架中,什么是依赖注入(DI)?

答案

  • 依赖注入是一种设计模式,允许对象之间的依赖关系由容器在运行时动态注入,而不是在代码中硬编码。
编程题5: 使用Spring框架,编写一个简单的Java配置类,配置一个Bean
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class AppConfig {
    @Bean
    public MyService myService() {
        return new MyServiceImpl();
    }
}

代码解读

这些编程题目旨在帮助你在面试中展示你的编码能力。建议在准备面试时,多练习类似的题目,并尝试解决实际问题。祝你在阿里巴巴的面试中取得成功!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值