java面试题(个人整理)

 

 

1.ArrayList 和 LinkedList之间的区别是什么?

Arraylist是动态数组的数据实现,linkedlist是双向链表的数据实现

Arraylist效率比linkedlist高,但是Arraylist安全性比linkedlist低

2.重载和重写有什么区别?

  • 重写一般是在继承父类的时候,重写父类的方法 重载一般是用于在一个类内实现若干重载的方法
  • 重写的方法名,参数数目相同 参数类型兼容 ,重载的方法名相同 参数列表不同
  • 重写方法的修饰符大于被重写方法的修饰符,重载与修饰符无关
  • *重写不可以抛出异常,没有抛出的一般异常,可以抛出运行时异常

3. 字节流和字符流的区别?

字节流以8位字节传输,字符流是以16位字符传输

 

4. 创建线程有哪几种方式?

继承thread重写run方法

实现runnable接口

实现callable接口

 

5. session 和 cookie 有什么区别?

存储位置

安全性

容量个数限制

6. 什么是跨域?有哪些解决方案?

跨域问题

跨域不一定会有跨域问题。(如果不是ajax请求,就不会造成跨域问题)

 

因为跨域问题是浏览器对于ajax请求的一种安全限制:一个页面发起的ajax请求,只能是于当前页同域名的路径,这能有效的阻止跨站攻击。

因此:跨域问题 是针对ajax的一种限制。

但是这却给我们的开发带来了不便,而且在实际生成环境中,肯定会有很多台服务器之间交互,地址和端口都可能不同,怎么办?

跨域解决方案

目前比较常用的跨域解决方案有3种:

 

  最早的解决方案,利用动态去填充script标签可以跨域的原理实现。

 

  限制:

  - 需要服务的支持

  - 只能发起GET请求

- nginx反向代理(部署)

  思路是:利用nginx反向代理把跨域为不跨域,支持各种请求方式

  缺点:需要在nginx进行额外配置,语义不清晰 --

 

- CORS(都可以使用-采纳)

  规范化的跨域请求解决方案,安全可靠。

  优势:

  - 在服务端进行控制是否允许跨域,可自定义规则

  - 支持各种请求方式

  缺点:

  - 会产生额外的请求,要做询问

 

7. spring mvc 运行流程

  • spring mvc 先将请求发送给 DispatcherServlet。
  • DispatcherServlet 查询一个或多个 HandlerMapping,找到处理请求的 Controller。
  • DispatcherServlet 再把请求提交到对应的 Controller。
  • Controller 进行业务逻辑处理后,会返回一个ModelAndView。
  • Dispathcher 查询一个或多个 ViewResolver 视图解析器,找到 ModelAndView 对象指定的视图对象。

 

8. Spring Boot有哪些优缺点?

 

优点

 

  • 配置简单
  • 独立运行
  • 自动装配
  • 无代码生成和 xml 配置
  • 提供应用监控
  • 易上手
  • 提升开发效率

缺点没有

9. MyBatis 中 #{}和 ${}的区别是什么?

\#{}是预编译处理,${}是字符替换。 在使用 #{}时,MyBatis 会将 SQL 中的 #{}替换成“?”,配合 PreparedStatement 的 set 方法赋值,这样可以有效的防止 SQL 注入,保证程序的运行安全。

 

10.Redis有哪些应用场景?

Redis 是一个使用 C 语言开发的高速缓存数据库。

Redis 使用场景:

  • 记录帖子点赞数、点击数、评论数;
  • 缓存近期热帖;
  • 缓存文章详情信息;
  • 记录用户会话信息。

 

1.HashMap 的数据结构是什么?

HashMap底层实现还是数组,只是数组的每一项元素都是一条链表头

2.Java中常见的异常有哪些?

NullPointerException 空指针异常

ClassNotFoundException 指定类不存在

NumberFormatException 字符串转换为数字异常

IndexOutOfBoundsException 数组下标越界异常

ClassCastException 数据类型转换异常

FileNotFoundException 文件未找到异常

NoSuchMethodException 方法不存在异常

IOException IO 异常

SocketException Socket 异常

 

3.线程的状态有哪几种?怎么流转的?

RUNNING:这是最正常的状态,接受新的任务,处理等待队列中的任务。

SHUTDOWN:不接受新的任务提交,但是会继续处理等待队列中的任务。

STOP:不接受新的任务提交,不再处理等待队列中的任务,中断正在执行任务的线程。

TIDYING:所有的任务都销毁了,workCount 为 0,线程池的状态在转换为 TIDYING 状态时,会执行钩子方法 terminated()。

TERMINATED:terminated()方法结束后,线程池的状态就会变成这个。

 

4.get 和 post 请求有哪些区别?

get 请求会被浏览器主动缓存,而 post 不会。

get 传递参数有大小限制,而 post 没有。

post 参数传输更安全,get 的参数会明文限制在 url 上,post 不会。

 

5. Spring IOC容器是什么?有什么好处?

控制反转是 spring 的核心

Spring IoC负责创建对象、管理对象(通过依赖注入(DI)、装配对象、配置对象,并且管理这些对象的整个生命周期。

优点是什么

    IoC或依赖注入把应用的代码量降到最低;

    它使应用容易测试,单元测试不再需要单例和JNDI查找机制;

    最小的代价和最小的侵入性使松散耦合得以实现;

    IoC容器支持加载服务时的饿汉式初始化和懒加载。

6. Spring MVC常用的注解有哪些?

@RequestMapping:用于处理请求url 映射的注解,可用于类或方法上。用于类

上,则表示类中的所有响应请求的方法都是以该地址作为父路径。

@RequestBody:注解实现接收http 请求的json 数据,将json 转换为java 对象。

@ResponseBody:注解实现将conreoller 方法返回对象转化为json 对象响应给

客户。

@RequestParam , 将请求的参数绑定到方法中的参数上

@RequestParam(value = “name”, required = false) String name

@PathVariable , 用于对应restful 风格url 中的参数

@RequestMapping(value="/happy/{dayid}") findPet(@PathVariable String dayid)

7. Spring Boot的核心配置文件有哪些?

properties,yml

8. MyBatis 怎么实现分页?

逻辑分页: 使用 MyBatis 自带的 RowBounds 进行分页,它是一次性查询很多数据,然后在数据中再进行检索。

物理分页: 自己手写 SQL 分页或使用分页插件 PageHelper,去数据库查询指定条数的分页数据的形式。

 

9. 介绍一下数据库设计三范式。

  • 第一范式:强调的是列的原子性,即数据库表的每一列都是不可分割的原子数据项
  • 第二范式:要求实体的属性完全依赖于主关键字。所谓完全依赖是指不能存在仅依赖主关键字一部分的属性。
  • 第三范式:任何非主属性不依赖于其它非主属性

 

10.Redis为什么这么快?

 

 

1.说一下equals和hashCode 的区别和联系?

Equals比较两个对象地址

hashCode用于返回字符串的哈希码

1如果两个对象相等,那么它们的hashCode()值一定相同。

这里的相等是指,通过equals()比较两个对象时返回true。

2如果两个对象hashCode()相等,它们并不一定相等。

2. finally 顺序,try里面return , finally还会执行吗?

不管有没有都会执行finally

3.如何保证多线程安全?

同步方法;

使用synchronized同步代码块,

用Lock锁机制;

1.Confinement

限制数据共享。

将可变数据限制在单一线程内部,避免竞争。核心思想就是线程之间不共享可变数据类型。

2.Immutable

将可变数据类型改为Immutable类型。

避免多线程间的race condition。

3.Threadsafe data type

共享线程安全的可变数据。

如果必须要在多线程间使用mutable的数据类型,必须要使用线程安全的数据类型。在JDK的类文档中,记录着是否线程安全。如List,Set,Map等集合类,都是线程不安全的。

4.Synchronization

通过锁的机制共享不安全的可变数据。

4.请求转发和重定向的区别?

客户端给服务端发送请求,服务端之间可以互相转发请求,然后再响应给客户端

重定向就是给服务端发送请求,服务端之间不能互相转发传递

客户端发起一次请求,服务器端给出一次响应

5.Spring AOP是什么? 有什么作用?

面向切面编程(面向方面编程)

用来解决面向对象编程过程中不好解决的一些问题:
事务管理

日志管理

监控管理

 

6. Spring 事务的传播机制?

PROPAGATION_REQUIRED 表示当前方法必须运行在事务中。如果当前事务存在,方法将会在该事务中运行。否则,会启动一个新的事务

PROPAGATION_SUPPORTS 表示当前方法不需要事务上下文,但是如果存在当前事务的话,那么该方法会在这个事务中运行

PROPAGATION_MANDATORY   表示该方法必须在事务中运行,如果当前事务不存在,则会抛出一个异常

PROPAGATION_REQUIRED_NEW      表示当前方法必须运行在它自己的事务中。一个新的事务将被启动。如果存在当前事务,在该方法执行期间,当前事务会被挂起。如果使用JTATransactionManager的话,则需要访问TransactionManager

PROPAGATION_NOT_SUPPORTED    表示该方法不应该运行在事务中。如果存在当前事务,在该方法运行期间,当前事务将被挂起。如果使用JTATransactionManager的话,则需要访问TransactionManager

PROPAGATION_NEVER 表示当前方法不应该运行在事务上下文中。如果当前正有一个事务在运行,则会抛出异常

PROPAGATION_NESTED     表示如果当前已经存在一个事务,那么该方法将会在嵌套事务中运行。嵌套的事务可以独立于当前事务进行单独地提交或回滚。如果当前事务不存在,那么其行为与PROPAGATION_REQUIRED一样。注意各厂商对这种传播行为的支持是有所差异的。可以参考资源管理器的文档来确认它们是否支持嵌套事务

————————————————

版权声明:本文为CSDN博主「bobby1994」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/bestkilly/article/details/82190549

 

7. Spring Boot自动配置原理是什么?

主要是Spring Boot的启动类上的核心注解SpringBootApplication注解主配置类,有了这个主配置类启动时就会为SpringBoot开启一个@EnableAutoConfiguration注解自动配置功能。
有了这个EnableAutoConfiguration的话就会:
1,从配置文件METAINF/Spring.factories加载可能用到的自动配置类
2、去重,并将exclude和excludeName属性携带的类排除
3、过滤,将满足条件(@Conditional)的自动配置类返回

8. MyBatis 如何获取自动生成的主键id?

插入时

useGeneratedKeys 设置为 true
把 keyColumn 设置为数据库的自增长列名
把 keyProperty 设置为java类接收自增长主键的属性名

9. 介绍一下数据库事务的特性和隔离级别

四大特性

1、原子性:事务包含的所有数据库操作要么全部成功,要不全部失败回滚

2、一致性:一个事务执行之前和执行之后都必须处于一致性状态。拿转账来说,假设用户A和用户B两者的钱加起来一共是5000,那么不管A和B之间如何转账,转几次账,事务结束后两个用户的钱相加起来应该还得是5000,这就是事务的一致性。

3、隔离性:一个事务未提交的业务结果是否对于其它事务可见。级别一般有:read_uncommit,read_commit,read_repeatable,串行化访问。

4、持久性:一个事务一旦被提交了,那么对数据库中数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作。

三、数据库的隔离级别

数据库事务的隔离级别有4个,由低到高依次为Read uncommitted 、Read committed 、Repeatable read 、Serializable ,这四个级别可以逐个解决脏读 、不可重复读 、幻读 这几类问题。

 

10. Redis有哪几种持久化方式?

RDB(Redis Database):指定的时间间隔能对你的数据进行快照存储。

AOF(Append Only File):每一个收到的写命令都通过write函数追加到文件

 

1.操作字符串的类有哪些,他们的区别?

String是声明了不可变的对象,当要改变字符串内容的时候就不能用string

Stringbuilder和Stringbuffer主要是安全问题,builder安全性比buffer低,但

2. Servlet的生命周期是怎样的?

3. Spring 中 BeanFactory和ApplicationContext的区别?

4. Spring Boot自动配置原理是什么?

5. MySQL引擎MylSAM和InnoDB的区别?

6. Redis有哪些应用场景?

Redis是分布式数据库,他的数据类型有

高并发

海量数据

7. RabbitMQ怎么避免消息丢失?

RabbitMQ消息丢失的情况

第一种:生产者弄丢了数据。生产者将数据发送到 RabbitMQ 的时候,可能数据就在半路给搞丢了,因为网络问题啥的,都有可能。

 

第二种:RabbitMQ 弄丢了数据。MQ还没有持久化自己挂了

第三种:消费端弄丢了数据。刚消费到,还没处理,结果进程挂了,比如重启了。

解决方案

一:针对生产者

方案1.开启RabbitMQ事务

 

可以选择用 RabbitMQ 提供的事务功能,就是生产者发送数据之前开启 RabbitMQ 事务channel.txSelect,然后发送消息,如果消息没有成功被 RabbitMQ 接收到,那么生产者会收到异常报错,此时就可以回滚事务channel.txRollback,然后重试发送消息;如果收到了消息,那么可以提交事务channel.txCommit。

 

// 开启事务

channel.txSelect

try {

    // 这里发送消息

} catch (Exception e) {

    channel.txRollback

 

    // 这里再次重发这条消息

}

 

// 提交事务

channel.txCommit

缺点:

但是问题是,RabbitMQ 事务机制是同步的,你提交一个事务之后会阻塞在那儿,采用这种方式基本上吞吐量会下来,因为太耗性能。

方案2 使用confirm机制

 

事务机制和 confirm 机制最大的不同在于,事务机制是同步的,你提交一个事务之后会阻塞在那儿,但是 confirm 机制是异步的,你发送个消息之后就可以发送下一个消息,然后那个消息 RabbitMQ 接收了之后会异步回调你的一个接口通知你这个消息接收到了。

8. 什么是SOA? SOA和微服务架构有什么区别?

9. Spring Cloud有哪些重要的组件?

10.Spring Cloud Eureka 怎么实现服务注册和发现?

 

  1. 说一下Java中的集合体系,以及他们的特点。

List集合:

1、ArrayList(最常用)

底层是动态数组,故优缺点同数组:查询快,增删慢
线程不安全,效率高

2、LinkedList

底层是链表,(巧记:和数组优缺点互补)查询慢,增删快
线程不安全,效率高

3、Vector

底层是数组,查询快,增删慢
线程安全,效率低

Set集合:

1、HashSet

(也可参考我的另一篇:https://blog.csdn.net/tiansheshouzuo/article/details/88902405)
底层是哈希表
哈希表唯一依赖两个方法:hashCode(),equals();
向HashSet集合中放入新元素的执行顺序:
1、调用Hashcode()函数,看是否已经有相同的哈希值
2、如果没有则放入该新元素,如果有则调用equals()函数逐个比对,如果没有,则放入,如果有,则不执行添加元素操作。

2、LinkedHashSet

底层是:哈希表(元素不可重复)+链表(有序,因为链表记录每个元素都记录后一个元素的地址)
PS:何为有序?
有序指的不是自动排序,序指的是元素存入集合的顺序,当元素存入的顺序和元素的排序位置是一致时就是有序

3、TreeSet

底层是红黑树,自然平衡二叉树,因为是二叉树结构所以集合内元素自动按升序排列(升序是其最大特征)。
元素不可重复
(理解思路1:TreeSet是对Set集合的实现,而Set集合都是不可重复的
理解思路2:TreeSet自动排序,添加元素时会调用compareTo(Object obj)方法,遇到重复不添加元素)
有两种排序方法:自然排序(默认升序)和定制排序。

Map集合:(一对数据地去保存:“键+值”)

1、HashMap

底层是哈希表(哈希表的本质是数组+链表)
把它的键套用HashSet的规则即可,只是每个键都附带了其各自的值。

2、LinkedHashMap

底层是哈希表和链表
把它的键套用LinkedHashSet的规则即可,只是每个键都附带了其各自的值。

3、Hashtable

底层是哈希表(哈希表的本质是数组+链表),十分类似于HashMap
与HashMap唯一区别:Hashtable线程安全,效率低,不允许null键null值
HashMap线程不安全,效率高,允许null键null值

4、TreeMap

底层是红黑树,自然平衡二叉树
其键的存储类似于TreeSet,只是每个键都附带了其各自的值(value)。

List集合特点:1、有存放顺序(有序)2、元素可重复

Set集合特点:1、没有存放顺序 2、元素不可重复

Map集合特点:Map属于双列集合,由键值对组成(键+值 成对存储),其中键完全和List集合的特点相同(底层一样),值依附于每一个键上,不受规则影响(比如TreeMap的键不可重复,但值可重复)

  1. ArrayList底层基于什么实现?他和LinkendList有什么区别?在实际开发中你怎么选择?

ArrayList是实现了基于动态数组的数据结构,而LinkedList是基于链表的数据结构;

区别:List接口的实现方式不同

ArrayList实现了List接口,以数组的方式来实现的,因此对于快速的随机取得对象的需求,使用ArrayList实现执行效率上会比较好。

LinkedList是采用链表的方式来实现List接口的,因此在进行insert和remove动作时效率要比ArrayList高。适合用来实现Stack(堆栈)与Queue(队列)。

 

 

3.HashMap和HashTable的区别,在多线程中又要保证线程安全,又要保证性能,应该用哪种Map?

  • 存储:HashMap 运行 key 和 value 为 null,而 Hashtable 不允许。
  • 线程安全:Hashtable 是线程安全的,而 HashMap 是非线程安全的。
  • 推荐使用:在 Hashtable 的类注释可以看到,Hashtable 是保留类不建议使用,推荐在单线程环境下使用 HashMap 替代,如果需要多线程使用则用 ConcurrentHashMap 替代。 
  1. 创建线程有几种方式,有什么区别?

线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针、程序计数器等),但代码区是共享的,
即不同的线程可以执行同样的函数。多线程是指程序中包含多个执行流,即在一个程序中可以同时运行多个不同的线程来执行不同的任务,

  • 继承 Thread 类重写 run 方法;
  • 实现 Runnable 接口;
  • 实现 Callable 接口。

5.thread中的run和start方法有什么区别?

通过start()方法来启动一个线程,此时线程处于就绪状态,可以被JVM来调度执行,在调度过程中,JVM通过调用线程类的run()方法来完成实际的业务逻辑,当run()方法结束后,此线程就会终止,所以通过start()方法可以达到多线程的目的。

如果直接调用线程类的run()方法,会被当做一个普通的函数调用,程序中仍然只有主线程这一个线程,即start()方法呢能够异步的调用run()方法,但是直接调用run()方法确实同步的,无法达到多线程的目的。

6.Synchronized 和 lock的区别?

  • synchronized 可以给类、方法、代码块加锁;而 lock 只能给代码块加锁。
  • synchronized 不需要手动获取锁和释放锁,使用简单,发生异常会自动释放锁,不会造成死锁;而 lock 需要自己加锁和释放锁,如果使用不当没有 unLock()去释放锁就会造成死锁。

通过 Lock 可以知道有没有成功获取锁,而 synchronized

7.Synchronized 加在普通方法上,锁的对象是什么? 加在静态方法上锁住的对象是什么?

synchronized关键字可用于修饰代码块普通方法静态方法synchronized修饰代码块的时候其可以获取内置锁的对象包括this、XXX.class以及其他对象

synchronized修饰的普通方法获取的是等效于this的指向对象的内置锁,即新创建的对象本身;synchronized修饰的静态方法获取的是该方法所在类的内置锁,即XXX.class

8.Synchronized 和 volatitle 关键字的区别?

  • volatile 是变量修饰符;synchronized 是修饰类、方法、代码段。
  • volatile 仅能实现变量的修改可见性,不能保证原子性;而 synchronized 则可以保证变量的修改可见性和原子性。
  • volatile 不会造成线程的阻塞;synchronized 可能会造成线程的阻塞。

 

9.Spring Cloud和 Spring Boot的关系?

maven是springboot的基础,springboot项目本身就是maven项目。在maven项目中使用springboot的多个starter加几个约定,就能成为springboot项目了。

springboot是springcloud的基础,springcloud本身是springboot项目。

关系:maven->springboot->springcloud

10.Spring Cloud Feign 是什么? 和 Ribbon 的区别?

Ribbon

   通过RestTmplate,以url完成服务的调用

Feign

   feign底层还是ribbon,只是进行了封装,让我们以接口的方式进行调用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值