1.HTTP 常用的状态码及使用场景?
- 1xx:表示目前是协议的中间状态,还需要后续请求
- 2xx:表示请求成功
- 3xx:表示重定向状态,需要重新请求
- 4xx:表示请求报文错误
- 5xx:服务器端错误
常用状态码:
- 101 切换请求协议,从 HTTP 切换到 WebSocket
- 200 请求成功,有响应体
- 301 永久重定向:会缓存
- 302 临时重定向:不会缓存
- 304 协商缓存命中
- 403 服务器禁止访问
- 404 资源未找到
- 400 请求错误
- 500 服务器端错误
- 503 服务器繁忙
2.抽象类和接口的区别
- 抽象类中的方法可以有方法体,就是能实现方法的具体功能,但是接口中的方法不行。
- 抽象类中的成员变量可以是各种类型的,而接口中的成员变量只能是 public static final 类型的。
- 接口中不能含有静态代码块以及静态方法(用 static 修饰的方法),而抽象类是可以有静态代码块和静态方法。
- 一个类只能继承一个抽象类,而一个类却可以实现多个接口。
注:JDK 1.8 以后,接口里可以有静态方法和方法体了。 注:JDK 1.8 以后,接口允许包含具体实现的方法,该方法称为"默认方法",默认方法使用 default 关键字修饰。更多内容可参考 Java 8 默认方法。 注:JDK 1.9 以后,允许将方法定义为 private,使得某些复用的代码不会把方法暴露出去。更多内容可参考 Java 9 私有接口方法。
3.java 重写(Overriding)和重载(Overloading)的区别
重写是父类与子类之间多态性的一种表现,重载可以理解成多态的具体表现形式。
- (1)方法重载是一个类中定义了多个方法名相同,而他们的参数的数量不同或数量相同而类型和次序不同,则称为方法的重载(Overloading)。
- (2)方法重写是在子类存在方法与父类的方法的名字相同,而且参数的个数与类型一样,返回值也一样的方法,就称为重写(Overriding)。
- (3)方法重载是一个类的多态性表现,而方法重写是子类与父类的一种多态性表现。
4.常见的排序算法以及时间复杂度
5.事务的特性
事务具有4个基本特征,分别是:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Duration),简称ACID
-
① 原子性 事务的原子性是指事务必须是一个原子的操作序列单元。事务中包含的各项操作在一次执行过程中,只允许出现两种状态之一,要么都成功,要么都失败
任何一项操作都会导致整个事务的失败,同时其它已经被执行的操作都将被撤销并回滚,只有所有的操作全部成功,整个事务才算是成功完成
-
② 一致性(Consistency) 事务的一致性是指事务的执行不能破坏数据库数据的完整性和一致性,一个事务在执行之前和执行之后,数据库都必须处以一致性状态。
比如:如果从A账户转账到B账户,不可能因为A账户扣了钱,而B账户没有加钱
-
③ 隔离性 事务的隔离性是指在并发环境中,并发的事务是互相隔离的,一个事务的执行不能被其它事务干扰。也就是说,不同的事务并发操作相同的数据时,每个事务都有各自完整的数据空间。
一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务是不能互相干扰的
-
④ 持久性(Duration) 事务的持久性是指事务一旦提交后,数据库中的数据必须被永久的保存下来。即使服务器系统崩溃或服务器宕机等故障。只要数据库重新启动,那么一定能够将其恢复到事务成功结束后的状态
6.面向对象的三大特征
面向对象具有三大特性:继承、封装、多态
继承:
如:子类 继承 父类,子类就具备了父类的公共属性和方法。
作用:
1、减少重复代码。
2、成就了类与类的关系,为多态打下基础。
封装:
封装,顾名思义是将内容封装到某个地方,然后再去调用被封装到某处的内容。所以运用面向对象的封装特性时。
需要注意两点:
1、将内容封装到某处
2、从某处调用被封装的内容
作用:
1、就是将常用部分封装起来,在其它地方(包含其它项目)可重复使用,减少大量冗余代码。
2、从而达到通用、灵活、独立的效果(避免Ctrl+C、Ctrl+V)
多态:
多态就是指不同的对象收到相同的消息时,会产生不同的行为,同一个类在不同的场合下表现出不同的行为特征,或不同的状态。
也就是说一个类(父类)具备了多种形态或状态,被称为多态。
7.spring Bean的作用范围
范围 | 作用描述 |
---|---|
singleton | Spring中默认的作用范围是一个单例的模式,IOC容器中只会有一个bean定义的实例 |
prototype | 多例的,每次调用getBean()方法获取bean标签的作用范围为prototype时,都会产生新的实例 |
request | 应用在web项目中,Spring创建这个类以后,将这个类存入到request范围中 |
session | 应用在web项目中,Spring创建这个类以后,将这个类存入到session范围中 |
globalsessio | 应用在web项目中,必须在porlet环境下使用。但是如果没有这种环境,相对于session |
8.mysql 超过5名学生的课
方法一:使用 GROUP BY 子句和子查询【通过】
思路
先统计每门课程的学生数量,再从中选择超过 5 名学生的课程。
使用 GROUP BY 和 COUNT 获得每门课程的学生数量。
SELECT
class, COUNT(DISTINCT student)
FROM
courses
GROUP BY class
;
注:使用 DISTINCT 防止在同一门课中学生被重复计算。
class | COUNT(student) |
---|---|
Biology | 1 |
Computer | 1 |
English | 1 |
Math | 6 |
使用上面查询结果的临时表进行子查询,筛选学生数量超过 5 的课程。
SELECT
class
FROM
(SELECT
class, COUNT(DISTINCT student) AS num
FROM
courses
GROUP BY class) AS temp_table
WHERE
num >= 5
;
注:COUNT(student) 不能直接在 WHERE 子句中使用,这里将其重命名为 num。
方法二:使用 GROUP BY 和 HAVING 条件【通过】
在 GROUP BY 子句后使用 HAVING 条件是实现子查询的一种更加简单直接的方法。
SELECT
class
FROM
courses
GROUP BY class
HAVING COUNT(DISTINCT student) >= 5
;