• Java问题?


    Java多线程

    • 线程池的原理,为什么要创建线程池?
    • 线程的生命周期,什么时候会出现僵死进程;
    • 什么实现线程安全,如何实现线程安全;
    • 创建线程池有哪几个核心参数? 如何合理配置线程池的大小?
    • synchronized、volatile区别、synchronized锁粒度、模拟死锁场景、原子性与可见性;

    JVM相关

    • JVM内存模型,GC机制和原理;GC分哪两种;什么时候会触发Full GC?
    • JVM里的有几种classloader,为什么会有多种?
    • 什么是双亲委派机制?介绍一些运作过程,双亲委派模型的好处;(这个我真的不会...)
    • 什么情况下我们需要破坏双亲委派模型;
    • 常见的JVM调优方法有哪些?可以具体到调整哪个参数,调成什么值?
    • JVM虚拟机内存划分、类加载器、垃圾收集算法、垃圾收集器、class文件结构是如何解析的;

    Java扩展

    • 红黑树的实现原理和应用场景;
    • NIO是什么?适用于何种场景?
    • Java9比Java8改进了什么;
    • HashMap内部的数据结构是什么?底层是怎么实现的?
    • 说说反射的用途及实现,反射是不是很慢,我们在项目中是否要避免使用反射;
    • 说说自定义注解的场景及实现;
    • List和Map区别,Arraylist与LinkedList区别,ArrayList与Vector 区别;

    Spring

    • Spring AOP的实现原理和场景;(应用场景很重要)
    • Spring bean的作用域和生命周期;
    • Spring Boot比Spring做了哪些改进? Spring 5比Spring4做了哪些改进;(惭愧呀,我们还在用Spring4,高版本的没关心过)
    • Spring IOC是什么?优点是什么?
    • SpringMVC、动态代理、反射、AOP原理、事务隔离级别;

    中间件

    • Dubbo完整的一次调用链路介绍;
    • Dubbo支持几种负载均衡策略?
    • Dubbo Provider服务提供者要控制执行并发请求上限,具体怎么做?
    • Dubbo启动的时候支持几种配置方式?
    • 了解几种消息中间件产品?各产品的优缺点介绍;
    • 消息中间件如何保证消息的一致性和如何进行消息的重试机制?
    • Spring Cloud熔断机制介绍;
    • Spring Cloud对比下Dubbo,什么场景下该使用Spring Cloud?

    数据库篇

    • 锁机制介绍:行锁、表锁、排他锁、共享锁;
    • 乐观锁的业务场景及实现方式;
    • 事务介绍,分布式事物的理解,常见的解决方案有哪些,什么事两阶段提交、三阶段提交;
    • MySQL记录binlog的方式主要包括三种模式?每种模式的优缺点是什么?
    • MySQL锁,悲观锁、乐观锁、排它锁、共享锁、表级锁、行级锁;
    • 分布式事务的原理2阶段提交,同步异步阻塞非阻塞;
    • 数据库事务隔离级别,MySQL默认的隔离级别、Spring如何实现事务、
    • JDBC如何实现事务、嵌套事务实现、分布式事务实现;
    • SQL的整个解析、执行过程原理、SQL行转列;

    Redis

    • Redis为什么这么快?redis采用多线程会有哪些问题?
    • Redis支持哪几种数据结构;
    • Redis跳跃表的问题;
    • Redis单进程单线程的Redis如何能够高并发?
    • Redis如何使用Redis实现分布式锁?
    • Redis分布式锁操作的原子性,Redis内部是如何实现的?

    Java基础

    1.HashMap的源码,实现原理,JDK8中对HashMap做了怎样的优化。
    2.HaspMap扩容是怎样扩容的,为什么都是2的N次幂的大小。
    3.HashMap,HashTable,ConcurrentHashMap的区别。
    4.极高并发下HashTable和ConcurrentHashMap哪个性能更好,为什么,如何实现的。
    5.HashMap在高并发下如果没有处理线程安全会有怎样的安全隐患,具体表现是什么。
    6.java中四种修饰符的限制范围。
    7.Object类中的方法。
    8.接口和抽象类的区别,注意JDK8的接口可以有实现。
    9.动态代理的两种方式,以及区别。
    10.Java序列化的方式。
    11.传值和传引用的区别,Java是怎么样的,有没有传值引用。
    12.一个ArrayList在循环过程中删除,会不会出问题,为什么。
    13.@transactional注解在什么情况下会失效,为什么。

    数据结构和算法

    1.B+树
    2.快速排序,堆排序,插入排序(其实八大排序算法都应该了解
    3.一致性Hash算法,一致性Hash算法的应用

    JVM

    1.JVM的内存结构。
    2.JVM方法栈的工作过程,方法栈和本地方法栈有什么区别。
    3.JVM的栈中引用如何和堆中的对象产生关联。
    4.可以了解一下逃逸分析技术。
    5.GC的常见算法,CMS以及G1的垃圾回收过程,CMS的各个阶段哪两个是Stop the world的,CMS会不会产生碎片,G1的优势。
    6.标记清除和标记整理算法的理解以及优缺点。
    7.eden survivor区的比例,为什么是这个比例,eden survivor的工作过程。
    8.JVM如何判断一个对象是否该被GC,可以视为root的都有哪几种类型。
    9.强软弱虚引用的区别以及GC对他们执行怎样的操作。
    10.Java是否可以GC直接内存。
    11.Java类加载的过程。
    12.双亲委派模型的过程以及优势。
    13.常用的JVM调优参数。
    14.dump文件的分析。
    15.Java有没有主动触发GC的方式(没有)。

    多线程

    1.Java实现多线程有哪几种方式。
    2.Callable和Future的了解。
    3.线程池的参数有哪些,在线程池创建一个线程的过程。
    4.volitile关键字的作用,原理。
    5.synchronized关键字的用法,优缺点。
    6.Lock接口有哪些实现类,使用场景是什么。
    7.可重入锁的用处及实现原理,写时复制的过程,读写锁,分段锁(ConcurrentHashMap中的segment)。
    8.悲观锁,乐观锁,优缺点,CAS有什么缺陷,该如何解决。
    9.ABC三个线程如何保证顺序执行。
    10.线程的状态都有哪些。
    11.sleep和wait的区别。
    12.notify和notifyall的区别。
    13.ThreadLocal的了解,实现原理。

    数据库相关

    1.常见的数据库优化手段
    2.索引的优缺点,什么字段上建立索引
    3.数据库连接池。
    4.durid的常用配置。

    计算机网络

    1.TCP,UDP区别。
    2.三次握手,四次挥手,为什么要四次挥手。
    3.长连接和短连接。
    4.连接池适合长连接还是短连接。

    设计模式

    1.观察者模式
    2.代理模式
    3.单例模式,有五种写法,可以参考文章单例模式的五种实现方式
    4.可以考Spring中使用了哪些设计模式

    分布式相关

    1.分布式事务的控制。
    2.分布式锁如何设计。
    3.分布式session如何设计。
    4.dubbo的组件有哪些,各有什么作用。
    5.zookeeper的负载均衡算法有哪些。
    6.dubbo是如何利用接口就可以通信的。

    缓存相关

    1.redis和memcached的区别。
    2.redis支持哪些数据结构。
    3.redis是单线程的么,所有的工作都是单线程么。
    4.redis如何存储一个String的。
    5.redis的部署方式,主从,集群。
    6.redis的哨兵模式,一个key值如何在redis集群中找到存储在哪里。
    7.redis持久化策略。

    框架相关

    1.SpringMVC的Controller是如何将参数和前端传来的数据一一对应的。
    2.Mybatis如何找到指定的Mapper的,如何完成查询的。
    3.Quartz是如何完成定时任务的。
    4.自定义注解的实现。
    5.Spring使用了哪些设计模式。
    6.Spring的IOC有什么优势。
    7.Spring如何维护它拥有的bean。

    一些较新的东西

    1.JDK8的新特性,流的概念及优势,为什么有这种优势。
    2.区块链了解
    3.如何设计双11交易总额面板,要做到高并发高可用。

    一些小建议

    1.可以去leetcode上刷题换换思路。
    2.八大排序算法一定要手敲一遍(快排,堆排尤其重要)。
    3.了解一些新兴的技术。
    4.面试之后面试官都会问你有没有什么问题,千万不要没问题,也别傻乎乎的问一些敏感问题。
    5.了解你要面试的公司的产品及竞争产品。
  • 相关阅读:
    针式电子书下载列表(暂时)
    硬盘坏道造成SQL 2000的异常
    一种“您无权查看该网页”的原因和解决方法
    学习英语的一些方法
    “针式背单词”帮助文件
    ClickOnce的Excel模板文件发布
    IC 设计书籍和相关资料
    Useful links on GPU Programming &Examp; Architecture
    点评美国名校的(EE)和(CS)
    微电子/物理学名人 约翰·巴丁 John Bardeen
  • 原文地址:https://www.cnblogs.com/zeenzhou/p/10906598.html
Copyright © 2020-2023  润新知