准备面试三

一、对于List而言,要否则就使用迭代器,要否则就从后往前删除,从前日后删除会出现角标越界。
    由于我List有两个remove方法,一个是int做为形参(删除指定位置的元素),一个是Object做为形参(删除指定的元素)。传一个基本数据类型的数字调用的是第一个方法。一旦删除,原List集合在删除角标以后的元素会往前走,致使集合的长度也变小了。
二、Java泛型是使用擦除来实现的,这意味着当你使用泛型的时候,任何具体的类型信息都被擦除了,你惟一知道的就是你在使用一个对象。所以List<String>和List<Integer>在运行期间其实是相同的类型,这两种类型都被擦除成它们的"原生"类型,即List。
三、Java把内存分为两种:一种是栈内存,一种是堆内存。在函数中定义一些基本数据类型的变量和对象的引用变量都是在函数的栈内存中分配。堆内存用来存放有new建立的对象和数组。
    在堆中产生了一个数组或者对象以后,还能够在栈中定义一个特殊的变量,让栈中的这个变量的取值等于数组或对象在堆内存中的首地址,栈中的这个变量就成了数组或对象的引用变量,之后就能够在程序中使用栈中的引用变量来访问堆中的数组或者对象,引用变量就至关于为数组或者对象起的一个名称。
四、JDK1.8的新特性
    1.速度更快---红黑树
    2.代码更少---Lambda
    3.最大化减小空指针异常----Optional
五、concurrentHashMap底层原理
    在concurrentHashMap中,不管是读操做仍是写操做都能保证很高的性能,在进行读操做时不须要加锁,而在写操做时经过分段锁技术只对所操做的段加锁而不影响客户端对其余段的访问。
    concurrentHashMap的高效并发机制经过如下三方面解决:
    1.经过锁分段技术保证并发环境下的写操做
    2.经过HashEntry的不变性,Volatile变量的内存可见性和加锁重读机制保证高效、安全的读操做
    3.经过不加锁和加锁两种方案控制跨段操做的安全性
六、JSP内置对象的做用
    1.pageContext表示页容器
    2.request服务器端得到客户端的信息:头信息,Cookie,请求参数
    3.response服务器回应给客户端的信息:Cookie、重定向
    4.session表示一个用户,用于登录验证上
    5.application表示整个服务器,getRealPath()
    6.config初始化参数
    7.Exception表示的是错误页的处理操做
    8.page  整个页面
    9.out  输出
7.servlet的五个加载方法
    1.init:初始化操做
    2.service:处理客户端的请求
    3.destroy:释放资源
    4.getServletConfig:返回容器调用init()方法时传递给Servlet对象的ServletConfig对象,包含了Servlet的初始化参数。
    5.getServletInfo:返回一个String类型的字符串,包括了Servlet的信息。
八、SpringAOP通常用于什么地方
    事务,缓存,异常,日志
九、collection相关:https://www.cnblogs.com/IvesHe/p/6108933.html
十、一个方法里面 有一个String参数 这个参数里有符号字符汉字数字  要求将参数里的数字挑选出来  进行相加  求和
    须要使用String类中提供的toCharArray()方法进行分割操做,分割成单个字符,将每一个字符进行int转换,转换成功就相加,不然不想加。
十一、如何判断方法传入的参数是何种类型
    使用Java反射,obj.getClass().getTypeName()便可判断
十二、Mybatis Mapper配置文件里的经常使用标签
    1.properties:属性
    2.settings:全局配置参数
    3.typeAliases:类型别名
    4.plugins:插件
    5.environments:环境集合属性对象
    6.environment:环境子属性对象
    7.transactionManager:事务管理
    8.dataSource:数据源
    9.mappers:映射器
    10.objectFactory:对象工厂
    11.typeHandlers:类型处理器
1三、Redis   缓存雪崩,穿透
    缓存雪崩:因为原有的缓存过时失效,新的缓存尚未缓存进来,有一个请求缓存请求不到,致使全部请求都跑去了数据库,致使数据库压力过大,致使宕机,使得系统崩溃。
    解决思路:1.采用加锁计数,或者使用合理的队列数量来避免缓存失效
        2.分析用户行为,尽可能让失效时间点均匀分布
        3.作主备缓存服务器
    缓存穿透:缓存穿透是指用户查询数据,在数据库中没有,天然在缓存中也不会有。这样就致使用户查询的时候,在缓存中找不到,而后再去数据中查询一遍
    解决思路:1.若是数据库也没有,直接设置一个默认值放到缓存,这样最简单。
        2.采用一个过滤器,将可能存在的数据哈希到一个容器中,不存在的直接拦截。
    缓存预热:缓存预热就是系统上线后,将相关的缓存数据直接加载到缓存系统,这样避免用户请求的时候,再去加载相关的数据
    解决思路:1.直接写个缓存刷新页面,上线时手动操做
        2.数据量不大的时候,能够在WEB系统启动时加载
        3.定时刷新缓存
1四、开发中内存溢出的常见缘由
    1.内存中加载的数据量过于庞大,如一次性从数据库中取出过多的数据
    2.集合类中有对对象的引用,使用完未清空,使得JVM不可以回收
    3.代码中存在死循环
    4.第三方软件的BUG
    5.启动参数内存值设定的太小
    解决:
    1.修改JVM启动参数,直接增长内存
    2.检查错误日志
    3.查看代码,找出可能发生内存溢出的位置
1五、String、StringBuffer、StringBuilder的区别
    1.String类中使用字符数组保存字符串,String类是final类型的,String对象是不可变的
    2.StringBuffer和StringBuilder都是可变的
    3.String的对象是不可变的,也能够理解为常量,显然线程安全
    4.StringBuffer对方法加了同步锁或者调用的方法加了同步锁,因此是线程安全的
    5.StringBuilder并无对方法加同步锁,因此是非线程安全的
1六、responseBody做用
    1.@ResponseBody是做用在方法上的,@ResponseBody表示该方法的返回结果直接写入HTTP  response body中,通常在异步(AJAX)获取数据使用
1七、autowired和 resource的区别
    1.@Autowired与@Resource均可以用来装配bean,均可以写在字段上
    2.@Autowired默认按类型装配(这个注解是属业spring的),默认状况下必需要求依赖对象必须存在,若是要容许null值,能够设置它的required属性为false
    3.@Resource(这个注解属于J2EE的),默认按照名称进行装配,名称能够经过name属性进行指定,若是没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,html

相关文章
相关标签/搜索