面试题零碎知识点(一)

JAVA基础

基础运算
数值型变量在默认情况下为Int型,byte和short型在计算时会自动转换为int型计算,结果也是int 型。
jdk1.8新特性 : 接口中可以有普通方法(非静态方法)和静态方法
private,public,protect这些规定修饰符只能用来修饰类,类成员变量,类方法。不能用于局部方法里面。

JAVA程序类型
Application,Applet,Serverlets。
1、Application,即”Java应用程序“,是可以独立运行的Java程序,由Java解释器控制执行,也是最常见的类型。
2、Applet,即“Java小程序“,不能独立运行(嵌入到Web页中)。由Java兼容浏览器控制执行。

3、Serverlets,是Java技术对CGI 编程的解决方案。是运行于Web server上的、作为来自于Web browser 或其他HTTP client端的请求和在server上的数据库及其他应用程序之间的中间层程序。

Java程序初始化顺序:
父类的静态代码块
子类的静态代码块
父类的普通代码块
父类的构造方法
子类的普通代码块
子类的构造方法

重写
普通方法,运用的是动态单分配,是根据new的类型确定对象,从而确定调用的方法;
静态方法,运用的是静态多分派,即根据静态类型确定对象,因此不是根据new的类型确定调用的方法

抽象类
特点:
1.抽象类中可以构造方法
2.抽象类中可以存在普通属性,方法,静态属性和方法。
3.抽象类中可以存在抽象方法。
4.如果一个类中有一个抽象方法,那么当前类一定是抽象类;抽象类中不一定有抽象方法。
5.抽象类中的抽象方法,需要有子类实现,如果子类不实现,则子类也需要定义为抽象的。

接口
1.在接口中只有方法的声明,没有方法体。
2.在接口中只有常量,因为定义的变量,在编译的时候都会默认加上
public static final
3.在接口中的方法,永远都被public来修饰。
4.接口中没有构造方法,也不能实例化接口的对象。
5.接口可以实现多继承
6.接口中定义的方法都需要有实现类来实现,如果实现类不能实现接口中的所有方法
7.则实现类定义为抽象类。

接口是用来给别人实现的所以不能是 static ,也不能是final 修饰interface
对于其声明的方法,也不能用static 或final来修饰,只能public
因为static 和 final 修饰的 不能被继承
对于其成员变量,却只能是public static final 类型,并且需要赋值

泛型:
泛型的出现可以把运行时出现的问题提前到编译时期发现。
泛型的主要目标是提高 Java 程序的类型安全
泛型的一个附带好处是,消除源代码中的许多强制类型转换

list的remove方法
倒序循环,因为list删除只会导致当前元素之后的元素位置发生改变,所以采用倒序可以保证前面的元素没有变化;
顺序循环时,删除当前位置的值,下一个值就会补到当前位置,所以需要执行i–操作;
从列表中删除项目的第一次出现。

栈:
一种特殊的线性表,只能固定在栈顶插入,栈顶删除,遵循后进先出(Last in First Out)的原则

集合&数组
JAVA集合只能存放引用类型的的数据,不能存放基本数据类型。
数组可以存放引用类型的的数据,和基本数据类型。

String的intern方法
可以使用intern方法从常量池中获取,如果常量池中不存在该字符串,那么就新建一个这样的字符串放到常量池中。

public class Test {
    private static  String a="ab";
    public static void main(String[] args) {
        String s1="a";
        String s2="b";
        String s=s1+s2;
        System.out.println(s.intern()==a);
    }
}

以下代码运行结果:
String a=“ab”;
final String bb=“b”;
String b=“a”+bb;
System.out.println(a==b);

True

线程
在这里插入图片描述
方法一:
线程安全的,虽然StringBuilder是线程不安全,但是在method1里面只有当前线程可以调用而且没有返回值。符合只有一个线程可以操作此数据,所以线程是安全的。
在这里插入图片描述
方法二:
线程不安全,因为StringBuilder本来就不安全,这个对象可以被多个线程调用方法执行。所以可能存在多个线程操作同一个对象。
在这里插入图片描述
方法三:
线程不安全,在方法内可能是安全的,但是在方法外,返回的StringBuilder类型就是不安全的,可能会被多个线程抢占这个返回值。所以线程不安全。
在这里插入图片描述
方法四:
线程是安全的,虽然StringBuilder是不安全的,但是因为在方法内,没有人可以调用。符合只有一个线程调用,所以是安全的,返回值返回的是String类型,也是线程安全的。
在这里插入图片描述

SQL

外键的作用:
保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值或使用空值。

myisam&innodb
1、MyISAM:默认表类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的顺序访问方法) 的缩写,它是存储记录和文件的标准方法。不是事务安全的,而且不支持外键,如果执行大量的select,insert MyISAM比较适合。
2、InnoDB:支持事务安全的引擎,支持外键、行锁、事务是他的最大特点。如果有大量的update和insert,建议使用InnoDB,特别是针对多个并发和QPS较高的情况。

SQL语句优化
https://www.cnblogs.com/Little-Li/p/8031295.html
https://www.cnblogs.com/wangzhengyu/p/10412499.html

SQL语句中删除视图的命令是
DROP VIEW

网络

Http&Https
http是一种超文本传输协议,传输的数据都是未加密的,也就是显示在明面上的,是现在互联网上应用最为广泛的一种网络协议,相对来说不太安全,但是所需成本很小。http一般的端口号为80.

https则是具有安全性的ssl加密传输协议。简单来说,https是一种安全版的http,传输的数据是通过SSL加密的,比起http来说很安全,https协议的主要作用就是:建立一个信息安全通道,来确保数组的传输,确保网站的真实性。但是相对来说,成本所需较高,尤其是所需ca证书等级越高,费用越高(ca证书功能越强大,所需费用越高)。https一般的端口号为443。

http和https各有各自的优缺点,http花费少,安全性不高;https花费稍高,但是你“买”来了安全;

TCP&UDP
区别:

1、tcp是基于连接的,可靠性高;udp是基于无连接的,可靠性较低;

2、由于tcp需要有三次握手、重新确认等连接过程,实时性差;同时过程复杂,也使其易于被攻击;而udp无连接,因而实时性较强,也稍安全;

3、在传输相同大小的数据时,tcp报头20字节;udp首部开销只有8个字节,tcp报头比udp复杂,故实际包含的用户数据较少。tcp无丢包,而udp有丢包,故tcp开销大,udp开销较小;

4、每条tcp连接只能是点到点的;udp支持一对一、一对多、多对一、多对多的交互通信。
https://blog.csdn.net/j18874964028sss/article/details/78299844

**

JVM

**
JVM的内存可分为哪个区
栈区
1.每个线程包含一个栈区,栈中只保存方法中(不包括对象的成员变量)的基础数据类型和自定义对象的引用(不是对象),对象都存放在堆区中
2.每个栈中的数据(原始类型和对象引用)都是私有的,其他栈不能访问。
3.栈分为3个部分:基本类型变量区、执行环境上下文、操作指令区(存放操作指令)。

堆区
1.存储的全部是对象实例,每个对象都包含一个与之对应的class的信息(class信息存放在方法区)。
2.jvm只有一个堆区(heap)被所有线程共享,堆中不存放基本类型和对象引用,只存放对象本身,几乎所有的对象实例和数组都在堆中分配。

方法区
又叫静态区,跟堆一样,被所有的线程共享。它用于存储已经被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。

Spring MVC

action的生命周期是在每次请求时创建一个新的action。一次请求只能调用一次filter,也就是说在一个action的生命周期中只能调用一次filter。拦截器可以被多次调用。

拦截器&过滤器
拦截器不依赖servlet容器,过滤器依赖于servlet容器。
原因:拦截器是spring的各容器自己实现的,过滤器是servlet实现的

Servlet过滤器和SpringMVC的拦截器是有区别的,区别如下:
①拦截器是基于Java的反射机制的,而过滤器是基于函数回调。
  ②拦截器不依赖于servlet容器,过滤器依赖于servlet容器。
  ③拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
  ④拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
  ⑤在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
  ⑥拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值