一、数据结构与算法基础
1· 说一下几种常见的排序算法和分别的复杂度。
2· 用Java写一个冒泡排序算法
3· 描述一下链式存储结构。
4· 如何遍历一棵二叉树?
5· 倒排一个LinkedList。
6· 用Java写一个递归遍历目录下面的所有文件。
二、Java基础
1· 接口与抽象类的区别?
2· Java中的异常有哪几类?分别怎么使用?
3· 常用的集合类有哪些?比如List如何排序?
4· ArrayList和LinkedList内部的实现大致是怎样的?他们之间的区别和优缺点?
5· 内存溢出是怎么回事?请举一个例子?
6· ==和equals的区别?
7· hashCode方法的作用?
8· NIO是什么?适用于何种场景?
9· HashMap实现原理,如何保证HashMap的线程安全?
10· JVM内存结构,为什么需要GC?
11· NIO模型,select/epoll的区别,多路复用的原理
12· Java中一个字符占多少个字节,扩展再问int, long, double占多少字节
13· 创建一个类的实例都有哪些办法?
14· final/finally/finalize的区别?
15· Session/Cookie的区别?
16· String/StringBuffer/StringBuilder的区别,扩展再问他们的实现?
17· Servlet的生命周期?
18· 如何用Java分配一段连续的1G的内存空间?需要注意些什么?
19· Java有自己的内存回收机制,但为什么还存在内存泄露的问题呢?
20· 什么是java序列化,如何实现java序列化?(写一个实例)?
21· String s = new String("abc");创建了几个 String Object?
三、JVM
1· JVM堆的基本结构。
2· JVM的垃圾算法有哪几种?CMS垃圾回收的基本流程?
3· JVM有哪些常用启动参数可以调整,描述几个?
4· 如何查看JVM的内存使用情况?
5· Java程序是否会内存溢出,内存泄露情况发生?举几个例子。
6· 你常用的JVM配置和调优参数都有哪些?分别什么作用?
7· JVM的内存结构?
8· 常用的GC策略,什么时候会触发YGC,什么时候触发FGC?
四、多线程/并发
1. 如何创建线程?如何保证线程安全?
2· 如何实现一个线程安全的数据结构
3· 如何避免死锁
4· Volatile关键字的作用?
5· HashMap在多线程环境下使用需要注意什么?为什么?
6· Java程序中启动一个线程是用run还是start?
7· 什么是守护线程?有什么用?
8· 什么是死锁?如何避免
9· 线程和进程的差别是什么?
10· Java里面的Threadlocal是怎样实现的?
11· ConcurrentHashMap的实现原理是?
12· sleep和wait区别
13· notify和notifyAll区别
14· volatile关键字的作
15· ThreadLocal的作用与实现
16· 两个线程如何串行执行
17· 上下文切换是什么含义
18· 可以运行时kill掉一个线程吗?
19· 什么是条件锁、读写锁、自旋锁、可重入锁?
20· 线程池ThreadPoolExecutor的实现原理?
五、Linux使用与问题分析排查
1· 使用两种命令创建一个文件?
2· 硬链接和软链接的区别?
3· Linux常用命令有哪些?
4· 怎么看一个Java线程的资源耗用?
5· Load过高的可能性有哪些?
6· /etc/hosts文件什么做用?
7· 如何快速的将一个文本中所有“abc”替换为“xyz”?
8· 如何在log文件中搜索找出error的日志?
9· 发现磁盘空间不够,如何快速找出占用空间最大的文件?
10· Java服务端问题排查(OOM,CPU高,Load高,类冲突)
11· Java常用问题排查工具及用法(top, iostat, vmstat, sar, tcpdump, jvisualvm, jmap, jconsole)
12· Thread dump文件如何分析(Runnable,锁,代码栈,操作系统线程ID关联)
13· 如何查看Java应用的线程信息?
六、框架使用
1· 描述一下Hibernate的三个状态?
2· Spring中Bean的生命周期。
3· SpringMVC或Struts处理请求的流程。
4· Spring AOP解决了什么问题?怎么实现的?
5· Spring事务的传播属性是怎么回事?它会影响什么?
6· Spring中BeanFactory和FactoryBean有什么区别?
7· Spring框架中IOC的原理是什么?
8· spring的依赖注入有哪几种方式
9· struts工作流程
10· 用Spring如何实现一个切面?
11· Spring 如何实现数据库事务?
12· Hibernate对一二级缓存的使用,Lazy-Load的理解;
13· mybatis如何实现批量提交?
七、数据库相关
1· MySQL InnoDB、Mysaim的特点?
2· 乐观锁和悲观锁的区别?
3· 数据库隔离级别是什么?有什么作用?
4· MySQL主备同步的基本原理。
5· select * from table t where size > 10 group by size order by size的sql语句执行顺序?
6· 如何优化数据库性能(索引、分库分表、批量操作、分页算法、升级硬盘SSD、业务优化、主从部署)
7· SQL什么情况下不会使用索引(不包含,不等于,函数)
8· 一般在什么字段上建索引(过滤数据最多的字段)
9· 如何从一张表中查出name字段不包含“XYZ”的所有行?
10· MySQL,B+索引实现,行锁实现,SQL优化
11· Redis,RDB和AOF,如何做高可用、集群
12· 如何解决高并发减库存问题
13· mysql存储引擎中索引的实现机制;
14· 数据库事务的几种粒度;
15· 行锁,表锁;乐观锁,悲观锁
八、网络协议和网络编程
1· TCP建立连接的过程。
2· TCP断开连接的过程。
3· 浏览器发生302跳转背后的逻辑?
4· HTTP协议的交互流程。HTTP和HTTPS的差异,SSL的交互流程?
5· Rest和Http什么关系?大家都说Rest很轻量,你对Rest风格如何理解?
6· TCP的滑动窗口协议有什么用?讲讲原理。
7· HTTP协议都有哪些方法?
8· 交换机和路由器的区别?
9· Socket交互的基本流程?
10· 协议(报文结构,断点续传,多线程下载,什么是长连接)
11· tcp协议(建连过程,慢启动,滑动窗口,七层模型)
12· webservice协议(wsdl/soap格式,与rest协议的区别)
13· NIO的好处,Netty线程模型,什么是零拷贝
九、Redis等缓存系统/中间件/NoSQL/一致性Hash等
1· 列举一个常用的Redis客户端的并发模型。
2· HBase如何实现模糊查询?
3· 列举一个常用的消息中间件,如果消息要保序如何实现?
4· 如何实现一个Hashtable?你的设计如何考虑Hash冲突?如何优化?
5· 分布式缓存,一致性hash
6· LRU算法,slab分配,如何减少内存碎片
7· 如何解决缓存单机热点问题
8· 什么是布隆过滤器,其实现原理是? False positive指的是?
9· memcache与redis的区别
10· zookeeper有什么功能,选举算法如何进行
11· map/reduce过程,如何用map/reduce实现两个数据源的联合统计
十、设计模式与重构
1· 你能举例几个常见的设计模式
2· 你在设计一个工厂的包的时候会遵循哪些原则?
3· 你能列举一个使用了Visitor/Decorator模式的开源项目/库吗?
4· 你在编码时最常用的设计模式有哪些?在什么场景下用?
5· 如何实现一个单例?
6· 代理模式(动态代理)
7· 单例模式(懒汉模式,恶汉模式,并发初始化如何解决,volatile与lock的使用)
8· JDK源码里面都有些什么让你印象深刻的设计模式使用,举例看看?
十一:微服务
1、什么是微服务?
2、微服务之间是如何独立通讯的
3、springCloud和dubbo 有哪些区别?
4、springboot和springcloud,请你谈谈对他们的理解?
5、什么是微服务熔断?什么是服务降级?
6、微服务的优缺点分别是什么?说下你在项目开发中碰到的坑
7、你所知道的微服务技术栈有哪些?请列举一二
8、eureka和zookeeper都可以提供服务的注册和发现的功能,请说说两个的区别?
相信你可能经历过这些:
作为Java工程师的你,平时工作已经很忙了,到底该如何进阶,才能快速成长呢?
分享一些过来人的经验,供大家参考。
一朝成为Java工程师,就注定终身学习。
这一点深有体会,而让我坚持学习的动力,主要源于以下三个方面:
1、 不断增值自己,拥有更多选择权
如果将技术比做一棵树,每学会一门语言,就点亮树上一个果实,你会得越多,技术树的果实就越多,价值就越大。当技术树的果实积累到一定程度,你就能纵向往高阶技术方向晋级,职业发展之路更上一层楼。
2、 互联网没有舒适圈,止步不前便是退步
计算机技术更新迭代快、新技术层出不穷,如果想要成为一个优秀的Java工程师,就要做好随时学习的准备,并持之以恒,这样才能跟上互联网日新月异的发展节奏。
3、 学习是面对竞争、度过中年危机的最好方法
Java工程师是高薪职业,近年来互联网的高速发展下,更是一度成为抢手的热门职业,以至于投身到这个职业的人越来越多,千军万马过独木桥,想要不掉队,唯有努力学习,成为互联网公司高薪争抢的中高端Java工程师,才能不惧寒冬。
目前互联网寒冬让很多互联网人清醒了,众多大企裁员、招聘需求收缩,主要还是针对基础岗、温水煮青蛙给煮死的那波人,中高端Java工程师在市场上依然紧缺。
互联网公司主流技术选型
进阶高级Java、架构师必学6大主要技能,包括:数据结构和算法、Java高级特性、源码分析、数据库、Java框架与必备工具、系统架构设计等,希望能真正帮助到想要从程序员进阶为高级Java、架构师之路的朋友。
1、并发编程
通过深入了解最底层的运作原理,加强逻辑思维,才能编写出高效、安全的多线程并发程序。
包括:集合框架(源码)、工具类、框架Spring、SpringMVC、Mybatis、Shiro、Netty、服务器(tomcat、Nginx)、网络编程、序列化、JVM等。
2、设计模式
设计模式是可复用面向对象软件的基础,学习设计模试是每一位Java工程师进阶的必经之路,灵活地使用设计模式,可以让代码变得简洁、易懂、复用性更高。
常见常用的设计模式有:工厂模式、代理模式等。
3、研发相关的框架工具
对Java程序员来说,下图这些框架与工具经常会用到。工欲善其事必先利其器,熟练掌握并应用这些工具,能够帮助我们更高效、质量的开展工作,譬如,debug、高效去重、代码review等等。
3、分布式架构
随着业务体量及重要性的增大,单体架构模式无法对应大型应用场景,系统也决不允许存在单点故障导致整体不可用,所以只有垂直或水平拆分业务系统,形成一个分布式的架构来消除单点故障,从而提高整个系统的可用性。
包括:分布式Session、分布式缓存、数据库、一致性、负载均衡、消息队列(RabbitMQ、ZeroMQ、Kafka)等
4、微服务
因时因地制宜,选择使用微服务架构的收益将远远大于成本。
规模较少的企业可以考虑适当引入合适的微服务架构,改造已有系统或新建微服务应用,逐步积累微服务架构经验,不要全盘实施微服务架构,综合考量成本与效率、实用性。
有针对微服务的系列篇,文末有查看地址。
5、JVM性能优化
6、架构关键基础设施
最后,想说,职场也好,人生也罢,每个阶段都有一定的阻碍与瓶颈,这是我们都要经历的。
如果你能够认清自己以及自己所处的阶段,有针对性的去思考、充电,坚持做正确的事,付出比别人更多的努力,你就会比别人更加优秀,拥有更多的机会,这就是我们常说的马太效应:越努力,越幸运。
BAT面试真题+架构技术资料,提升软硬实力,收获高薪好offer
说了这么多,到底该如何学习呢,有没有资料或视频呀?
大厂Java面试题库、BAT架构技术资料库(关注小编,看个人介绍)
资料内容涵盖BAT架构技术与面试真题,减少你到处搜索资料的时间,成体系的实战技术知识,让你面试、进阶都更加容易。