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