java基础

关键字    reflection/JavaIO/restful/activeMQ/dubbo/Lucene/Junit/Zookeeper/SOA/多线程, docker,golang,Redis集群,异步处理,高并发,负载均衡,分布式系统,缓存.消息.安全,阿里云或AWS(amazon web services)应用平台搭建经验, Scrum敏捷开发

JAVA框架    Webx,SSM,SSH, Stripes

应用服务器    Nginx, Jboss, weblogic,Jetty

建模工具    UML,power designer

Web前端技术    angularJs/HTML5/CSS3/react.js/require.js/AMD/bower/NPM/Bootstrap

平台    Linux

持续集成工具    jenkins

编译工具    Maven

版本管理    SVN,Git,CleanCase,AccuRev

开发工具    IntelliJ IDEA

数据库    mongoDB, Memcached,Oracle

大数据相关    Hadoop, mapreduce,spark

项目管理工具    Redmine, Jira


JAVA基础问题

No.    问题    答案

1    请描述一下HTTP协议的Get,Post区别?    •    Get从服务器获取数据,Get是不安全的,因为在传输过程,数据被放在请求的URL中,同时get请求有长度限制。

•    Post向服务器传递数据,Post安全性高,post是通过HTTP post机制,数据不会显示在地址栏中,用户看不到这个过程。post请求没有长度限制。

2    进程和线程的区别是什么?    一个程序至少有一个进程,一个进程至少有一个线程.

同一个进程中的多个线程之间可以并发执行。

3    什么是Spring IOC 容器?    Spring IOC 负责创建对象,管理对象(通过依赖注入(DI),装配对象,配置对象,并且管理这些对象的整个生命周期

4    Java 中的final关键字有哪些用法?     (1)修饰类:表示该类不能被继承

(2)修饰方法:表示方法不能被重写

(3)修饰变量:表示变量只能一次赋值以后值不能被修改

7    简单介绍您所了解的MVC?    数据模型(model)-用户界面(view)-控制器(controller)

8    说出一些java常见的包?    java.lang, java.io, java.util, java.sql, java.net

10 redis 和移动端的realm类似,是一个key-value存储系统。。为了保证效率,数据都是缓存在内存中。区别的是redis会周期性 的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave。。和SDImage非常类似。


21、描述一下JVM加载class文件的原理机制?

答:JVM中类的装载是由类加载器(ClassLoader)和它的子类来实现的,Java中的类加载器是一个重要的Java运行时系统组件,它负责在运行时查找和装入类文件中的类。

由于Java的跨平台性,经过编译的Java源程序并不是一个可执行程序,而是一个或多个类文件。当Java程序需要使用某个类时,JVM会确保这个类已经被加载、连接(验证、准备和解析)和初始化。

类的加载是指把类的.class文件中的数据读入到内存中,通常是创建一个字节数组读入.class文件,然后产生与所加载类对应的Class对象。加载完成后,Class对象还不完整,所以此时的类还不可用。当类被加载后就进入连接阶段,这一阶段包括验证、准备(为静态变量分配内存并设置默认的初始值)和解析(将符号引用替换为直接引用)三个步骤。最后JVM对类进行初始化,包括:1)如果类存在直接的父类并且这个类还没有被初始化,那么就先初始化父类;2)如果类中存在初始化语句,就依次执行这些初始化语句。

类的加载是由类加载器完成的,类加载器包括:根加载器(BootStrap)、扩展加载器(Extension)、系统加载器(System)和用户自定义类加载器(java.lang.ClassLoader的子类)。从Java 2(JDK 1.2)开始,类加载过程采取了父亲委托机制(PDM)。PDM更好的保证了Java平台的安全性,在该机制中,JVM自带的Bootstrap是根加载器,其他的加载器都有且仅有一个父类加载器。类的加载首先请求父类加载器加载,父类加载器无能为力时才由其子类加载器自行加载。JVM不会向Java程序提供对Bootstrap的引用。下面是关于几个类加载器的说明:

Bootstrap:一般用本地代码实现,负责加载JVM基础核心类库(rt.jar);

Extension:从java.ext.dirs系统属性所指定的目录中加载类库,它的父加载器是Bootstrap;

System:又叫应用类加载器,其父类是Extension。它是应用最广泛的类加载器。它从环境变量classpath或者系统属性java.class.path所指定的目录中记载类,是用户自定义加载器的默认父加载器。

25、Java 中会存在内存泄漏吗,请简单描述。

答:理论上Java因为有垃圾回收机制(GC)不会存在内存泄露问题(这也是Java被广泛使用于服务器端编程的一个重要原因);然而在实际开发中,可能会存在无用但可达的对象,这些对象不能被GC回收,因此也会导致内存泄露的发生。例如hibernate的Session(一级缓存)中的对象属于持久态,垃圾回收器是不会回收这些对象的,然而这些对象中可能存在无用的垃圾对象,如果不及时关闭(close)或清空(flush)一级缓存就可能导致内存泄露


52、List、Set、Map是否继承自Collection接口?

答:List、Set 是,Map 不是。Map是键值对映射容器,与List和Set有明显的区别,而Set存储的零散的元素且不允许有重复元素(数学中的集合也是如此),List是线性结构的容器,适用于按数值索引访问元素的情形。

61、编写多线程程序有几种实现方式?

答:Java 5以前实现多线程有两种实现方法:一种是继承Thread类;另一种是实现Runnable接口。两种方式都要通过重写run()方法来定义线程的行为,推荐使用后者,因为Java中的继承是单继承,一个类有一个父类,如果继承了Thread类就无法再继承其他类了,显然使用Runnable接口更为灵活。

68、Java中如何实现序列化,有什么意义?

答:序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决对象流读写操作时可能引发的问题(如果不进行序列化可能会存在数据乱序的问题)。

131、阐述Session加载实体对象的过程。

答:Session加载实体对象的步骤是:

① Session在调用数据库查询功能之前,首先会在一级缓存中通过实体类型和主键进行查找,如果一级缓存查找命中且数据状态合法,则直接返回;

② 如果一级缓存没有命中,接下来Session会在当前NonExists记录(相当于一个查询黑名单,如果出现重复的无效查询可以迅速做出判断,从而提升性能)中进行查找,如果NonExists中存在同样的查询条件,则返回null;

③ 如果一级缓存查询失败则查询二级缓存,如果二级缓存命中则直接返回;

④ 如果之前的查询都未命中,则发出SQL语句,如果查询未发现对应记录则将此次查询添加到Session的NonExists中加以记录,并返回null;

⑤ 根据映射配置和SQL语句得到ResultSet,并创建对应的实体对象;

⑥ 将对象纳入Session(一级缓存)的管理;

⑦ 如果有对应的拦截器,则执行拦截器的onLoad方法;

⑧ 如果开启并设置了要使用二级缓存,则将数据对象纳入二级缓存;

⑨ 返回数据对象。

144、解释一下MyBatis中命名空间(namespace)的作用。

答:在大型项目中,可能存在大量的SQL语句,这时候为每个SQL语句起一个唯一的标识(ID)就变得并不容易了。为了解决这个问题,在MyBatis中,可以为每个映射文件起一个唯一的命名空间,这样定义在这个映射文件中的每个SQL语句就成了定义在这个命名空间中的一个ID。只要我们能够保证每个命名空间中这个ID是唯一的,即使在不同映射文件中的语句ID相同,也不会再产生冲突了。

java基础_第1张图片
SpringMVC请求过程


java基础_第2张图片
文字说明


java基础_第3张图片
分类


Servlet 生命周期、工作原理

Servlet 生命周期:Servlet 加载--->实例化--->服务--->销毁。

init():在Servlet的生命周期中,仅执行一次init()方法。它是在服务器装入Servlet时执行的,负责初始化Servlet对象。可以配置服务器,以在启动服务器或客户机首次访问Servlet时装入Servlet。无论有多少客户机访问Servlet,都不会重复执行init()。

service():它是Servlet的核心,负责响应客户的请求。每当一个客户请求一个HttpServlet对象,该对象的Service()方法就要调用,而且传递给这个方法一个“请求”(ServletRequest)对象和一个“响应”(ServletResponse)对象作为参数。在HttpServlet中已存在Service()方法。默认的服务功能是调用与HTTP请求的方法相应的do功能。

destroy(): 仅执行一次,在服务器端停止且卸载Servlet时执行该方法。当Servlet对象退出生命周期时,负责释放占用的资源。一个Servlet在运行service()方法时可能会产生其他的线程,因此需要确认在调用destroy()方法时,这些线程已经终止或完成。

http://www.cnblogs.com/xuekyo/archive/2013/02/24/2924072.html

page/request/session/application范围

1.简单说 page指当前页面。在一个jsp页面里有效

2.request 指从http请求到服务器处理结束,返回响应的整个过程。在这个过程中使用forward方式跳转多个jsp。在这些页面里你都可以使用这个变量。

3.Session 有效范围当前会话,从浏览器打开到浏览器关闭这个过程。

4.application它的有效范围是整个应用。

作用域里的变量,它们的存活时间是最长的,如果不进行手工删除,它们就一直可以使用

你可能感兴趣的:(java基础)