JavaWeb开发面试题

一、Java基础

 

1. String类为什么是final的。

避免继承改写,提高性能,常量池

 

2. HashMap的源码,实现原理,底层结构。

链表+数组

 

3. 说说你知道的几个Java集合类:list、set、queue、map实现类咯。。。

list的实现包含了ArrayListLinkedList 对应的安全类分别为 Vector和?

set通过hashMap实现

queue队列,linkedBlockQueue

 

4. 描述一下ArrayList和LinkedList各自实现和区别

数组和链表的方式

 

5. Java中的队列都有哪些,有什么区别。

?阻塞队列和非阻塞队列

 

6. 反射中,Class.forName和classloader的区别

?Class.forName首先通过类加载classLoader加载

 

7. Java7、Java8的新特性(baidu问的,好BT)

java8函数式编程

 

8. Java数组和链表两种结构的操作效率,在哪些情况下(从开头开始,从结尾开始,从中间开始),哪些操作(插入,查找,删除)的效率高

链表在插入删除都比数组高,如果是结尾则大致相同

数组在查找比较高

 

9. Java内存泄露的问题调查定位:jmap,jstack的使用等等

jdk下的相关工具

 

10. string、stringbuilder、stringbuffer区别

string在方法区有常量池,builder和buffer采用堆对象的形式。后者线程安全,效率低。

 

 

11. hashtable和hashmap的区别

table线程安全效率低

 

13 .异常的结构,运行时异常和非运行时异常,各举个例子

异常一般分为运行时和非运行时,运行时的比如空指针异常,越界异常,类转换异常

非运行时的比如文件找不到异常,IO异常

 

14. String a= “abc” String b = “abc” Stringc = new String(“abc”) String d = “ab” + “c” .他们之间用 == 比较的结果

a 、b、c true

c false

 

15. String 类的常用方法

charAt

getBytes

reverse

 

 

16. Java 的引用类型有哪几种

四种

强 弱 虚 ?

 

17. 抽象类和接口的区别

主要是多继承和单继承的区别

抽象类可以包含普通方法

 

18. java的基础类型和字节大小。

byte short int long float double boolean  char

8   16   32  64  32  64   ?     16

 

19. Hashtable,HashMap,ConcurrentHashMap 底层实现原理与线程安全问题(建议熟悉 jdk 源码,才能从容应答)

table即加同步锁的HashMap, ConcurrentHashMap加分段锁

 

20. 如果不让你用Java Jdk提供的工具,你自己实现一个Map,你怎么做。说了好久,说了HashMap源代码,如果我做,就会借鉴HashMap的原理,说了一通HashMap实现

? 怎么实现HashMap ,定义数组然后扩容,+链表?

 

21. Hash冲突怎么办?哪些解决散列冲突的方法?

扩容因子?

 

22. HashMap冲突很厉害,最差性能,你会怎么解决?从O(n)提升到log(n)咯,用二叉排序树的思路说了一通

??

 

23. rehash

??

24. hashCode() 与equals() 生成算法、方法怎么重写

IDE直接重写

 

二、Java IO

 

1. 讲讲IO里面的常见类,字节流、字符流、接口、实现类、方法阻塞。

字节流 FileInputStream

字符流 FileReader和FileWriter

接口 InputStream  OutputStream

??

 

2. 讲讲NIO。

选择器 缓冲和通道

 

3. String 编码UTF-8 和GBK的区别?

UTF-8的编码 中文字符 3个字节英文1个字符

GBK是 2个字节中文字符?

 

4. 什么时候使用字节流、什么时候使用字符流?

大文件用字符流,文件小可以用字节流或者序列化的时候?

 

5. 递归读取文件夹下的文件,代码怎么实现

File.isDireatory 和File.isFile重载本方法

 

三、Java Web

 

1. session和cookie的区别和联系,session的生命周期,多个服务部署时session管理。

cookie在客户端,session在服务端,session在request请求时创建,如果没有在getSession的时候创建,会话结束,服务器到期,sessionid就变化,多服务器部署可以将session存在redis中,或者持续化到本地,??

 

2. servlet的一些相关问题

servlet 容器tomcat   servlet上下文初始化 ,监听器 ,过滤器 ,servlet

 

3. webservice相关问题

应用服务器 tomcat jetty

 

4. jdbc连接,forname方式的步骤,怎么声明使用一个事务。举例并具体代码

加载驱动

建立连接后设置自动提交为flase,然后相应的操作。

 

5. 无框架下配置web.xml的主要配置内容

servlet及servlet的映射路径,欢迎页面,错误页面等

过滤器,监听器

 

6. jsp和servlet的区别

jsp管视图端

servlet控制层

 

 

四、JVM

 

1. Java的内存模型以及GC算法

分为方法区、堆,本地方法区、栈、程序计数器,方法区和堆是共享区,其它是私有区

也可以用线程私有变量

GC算法主要是标记清理,整理清理, 现在的算法主要次用G1 并发清理算法

 

2. jvm性能调优都做了什么

设置堆区、方法区、栈区等合适大小避免内存溢出

 

3. 介绍JVM中7个区域,然后把每个区域可能造成内存的溢出的情况说明

方法区,如果使用很多的string常量会导致溢出

堆区,如果使用很多的新建对象会溢出

栈区,如果int被递归计算很多次,可能使得栈深度过深,导致栈溢出

直接内存,可能在写IO的时候导致

 

4. 介绍GC 和GC Root不正常引用。

如果检查到GC root没有相应的引用就放到一个回收队列中进行回收,在回收之前有最后一次寄回,就是 finiziled

 

5. 自己从classload 加载方式,加载机制说开去,从程序运行时数据区,讲到内存分配,讲到String常量池,讲到JVM垃圾回收机制,算法,hotspot。反正就是各种扩展

???

 

6. jvm 如何分配直接内存,new 对象如何不分配在堆而是栈上,常量池解析

??分配在栈上? 方法区也是堆吧

 

7. 数组多大放在 JVM 老年代(不只是设置 PretenureSizeThreshold ,问通常多大,没做过一问便知)

??

 

8. 老年代中数组的访问方式

??

 

9. GC 算法,永久代对象如何 GC, GC 有环怎么处理

??当新生代即其它代GC不够时,永久代进行GC,采用整理清除法

 

10. 谁会被 GC ,什么时候 GC

没有root了

11. 如果想不被 GC 怎么办

强引用存活

12. 如果想在 GC 中生存 1 次怎么办

finalized

五、开源框架

 

1. hibernate和ibatis的区别

??

ibatis 更新                                                     

 

2. 讲讲mybatis的连接池。

??

 

3. spring框架中需要引用哪些jar包,以及这些jar包的用途

context core bean 等基础jar包,mvc需要mvc aopjdbc等

 

4. springMVC的原理

分层开发,将对象模型、视图层、控制层分开,使用ModelAndView来封装模型数据和视图数据,在控制层进行处理和传递,采用责任链的模式进行拦截。???

 

5. springMVC注解的意思

@Controller 控制层

@Service 服务层

@Compement 持久层

@RequestMapping 访问URL

@Bean 注入

 

6. spring中beanFactory和ApplicationContext的联系和区别

??

 

7. spring注入的几种方式(循环注入)

set注入

和构造注入

 

8. spring如何实现事物管理的

aop来实现事务管理 ??

 

9. springIOC

控制反转,依赖注入,在需要的时候进行注入关联

 

10. spring AOP的原理

动态代理模式,利用JDK或者cglib的方法

11. hibernate中的1级和2级缓存的使用方式以及区别原理(Lazy-Load的理解)

??

 

12. Hibernate的原理体系架构,五大核心接口,Hibernate对象的三种状态转换,事务管理。

??

 

六、多线程

 

1. Java创建线程之后,直接调用start()方法和run()的区别

run是普通方法,start是线程方法

 

2. 常用的线程池模式以及不同线程池的使用场景

都用自定义的方式?

 

3. newFixedThreadPool此种线程池如果线程数达到最大值后会怎么办,底层原理。

通过一个阻塞队列来?

 

4. 多线程之间通信的同步问题,synchronized锁的是对象,衍伸出和synchronized相关很多的具体问题,例如同一个类不同方法都有synchronized锁,一个对象是否可以同时访问。或者一个类的static构造方法加上synchronized之后的锁的影响。

不可以,需要先拿到对象锁??

 

5. 了解可重入锁的含义,以及ReentrantLock和synchronized的区别

可重入锁是为了避免阻塞自己,?

 

6. 同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为什么他是同步的且效率高

分段锁,不会锁定所有的,这样它的效率高

 

7. atomicinteger和Volatile等线程安全操作的关键字的理解和使用

原子类,不会产生多线程冲突,volatile的原理也是如此

 

8. 线程间通信,wait和notify

wait释放锁,等待唤醒

notify唤醒其它线程

 

9. 定时线程的使用

时间到后尝试获取cpu资源运行线程。?

 

10. 场景:在一个主线程中,要求有大量(很多很多)子线程执行完之后,主线程才执行完成。多种方式,考虑效率。

join

countDown方式

Cys。。对象同步方式

 

11. 进程和线程的区别

进程相当于一个程序运行,至少包含一个线程,线程是代码块运行的最小单元,一个进程可以有多个线程

 

12. 什么叫线程安全?举例说明

同一时间变量只能被一个线程改变,而不能被多个,互斥。

 

13. 线程的几种状态

创建 就绪 运行 结束

 

14. 并发、同步的接口或方法

sync.. 同步方法

 

15. HashMap 是否线程安全,为何不安全。 ConcurrentHashMap,线程安全,为何安全。底层实现是怎么样的。

可能产生资源竞争,加分段锁

 

16. J.U.C下的常见类的使用。ThreadPool的深入考察; BlockingQueue的使用。(take,poll的区别,put,offer的区别);原子类的实现。

?? 线程池

获得线程 线程断开 放回线程池 提供线程

 

17. 简单介绍下多线程的情况,从建立一个线程.开始。然后怎么控制同步过程,多线程常用的方法和结构

先获得同步锁,在执行逻辑,逻辑结束释放锁定(可唤醒其它线程),

new一个线程池,传入需要进行处理的数据,用coutDown来阻塞执行,或者是Future来阻塞执行,最后完成。

 

18. volatile的理解

强制jvm按顺序读取相应的变量的值

 

19. 实现多线程有几种方式,多线程同步怎么做,说说几个线程里常用的方法

主要用线程池来执行,countDown或者是Future

 

七、网络通信

 

1. http是无状态通信,http的请求方式有哪些,可以自己定义新的请求方式么。

put delete get post 等 不可以?

 

2. socket通信,以及长连接,分包,连接异常断开的处理。

tcp握手三次,??

 

3. socket通信模型的使用,AIO和NIO。

通信模型NIO吧。??

 

4. socket框架netty的使用,以及NIO的实现原理,为什么是异步非阻塞。

??

 

5. 同步和异步,阻塞和非阻塞。

?? 同步即发送请求即时获得结果,异步即另起事务处理,阻塞表示等待结果,非阻塞表示不需要等待结果

 

6. OSI七层模型,包括TCP,IP的一些基本知识

网络层

物理层

逻辑层

链路层等

TCP IP??

 

7. http中,get post的区别

post能传的字符更多,并且是表单提交,更加安全

 

8. 说说http,tcp,udp之间关系和区别。

??

 

9. 说说浏览器访问www.taobao.com,经历了怎样的过程。

域名解析à 相应的服务器,然后访问资源 负载平衡 à静态资源  à 动态资源 à ??

 

10. HTTP协议、  HTTPS协议,SSL协议及完整交互过程;

??

 

11. tcp的拥塞,快回传,ip的报文丢弃

??

 

12. https处理的一个过程,对称加密和非对称加密

??

13. head各个特点和区别

??

14. 说说浏览器访问www.taobao.com,经历了怎样的过程。

八、数据库MySql

 

1. MySql的存储引擎的不同

表锁和行锁,innoble的一般推荐

 

2. 单个索引、联合索引、主键索引

一个值作为索引

多个值顺序索引

以主键作为索引

 

3. Mysql怎么分表,以及分表后如果想按条件分页查询怎么办(如果不是按分表字段来查询的话,几乎效率低下,无解)

??使用hash算法进行分表,分表后按条件分页查询,??

 

4. 分表之后想让一个id多个表是自增的,效率实现

?? 不会

 

5. MySql的主从实时备份同步的配置,以及原理(从库读主库的binlog),读写分离

不会???

 

6. 写SQL语句。。。

??

 

7. 索引的数据结构,B+树

??

 

8. 事务的四个特性,以及各自的特点(原子、隔离)等等,项目怎么解决这些问题

??

原子、隔离?

 

 

9. 数据库的锁:行锁,表锁;乐观锁,悲观锁

行锁,就是锁该行几上下几行

表锁,就是锁住整个表

乐观锁,尝试更改,失败重试三次

悲观锁,就是forUpdate锁定,其它不能更改

 

10. 数据库事务的几种粒度;

四种吧

???

 

 

11. 关系型和非关系型数据库区别

结构化的数据

非关系的可以存储非结构化数据??

 

 

九、设计模式

 

1. 单例模式:饱汉、饿汉。以及饿汉中的延迟加载,双重检查

枚举,

 

2. 工厂模式、装饰者模式、观察者模式。

上下文处理,调用

 

3. 工厂方法模式的优点(低耦合、高内聚,开放封闭原则)

???

 

十、算法

 

1. 使用随机算法产生一个数,要求把1-1000W之间这些数全部生成。(考察高效率,解决产生冲突的问题)

??

 

2. 两个有序数组的合并排序

??

 

3. 一个数组的倒序

??

 

4. 计算一个正整数的正平方根

??M

 

5. 说白了就是常见的那些查找、排序算法以及各自的时间复杂度

??

 

6. 二叉树的遍历算法

??

 

7. DFS,BFS算法

??

 

9. 比较重要的数据结构,如链表,队列,栈的基本理解及大致实现。

??

 

10. 排序算法与时空复杂度(快排为什么不稳定,为什么你的项目还在用)

??

 

11. 逆波兰计算器

??

 

12. Hoffman 编码

??

 

13. 查找树与红黑树

??

十一、并发与性能调优

 

1. 有个每秒钟5k个请求,查询手机号所属地的笔试题(记得不完整,没列出),如何设计算法?请求再多,比如5w,如何设计整个系统?

2. 高并发情况下,我们系统是如何支撑大量的请求的

3. 集群如何同步会话状态

4. 负载均衡的原理

5 .如果有一个特别大的访问量,到数据库上,怎么做优化(DB设计,DBIO,SQL优化,Java优化)

6. 如果出现大面积并发,在不增加服务器的基础上,如何解决服务器响应不及时问题“。

7. 假如你的项目出现性能瓶颈了,你觉得可能会是哪些方面,怎么解决问题。

8. 如何查找 造成 性能瓶颈出现的位置,是哪个位置照成性能瓶颈。

9. 你的项目中使用过缓存机制吗?有没用用户非本地缓存

十二、其他

 

1.常用的linux下的命令

ls 打印目录

cat 打开文件

 



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值