**static 和 final 的理解** 

static:是静态变量修饰符,修饰的是全局变量,所以对象是共享的,在开始类设计的初期就分配空间。
    final:声明式属性,方法,类。分别表示属性不可变,方法不可覆盖,类不可继承,内部访问的是局部变量,局部变量必须定义成final类型的

**SpringMVC的理解**

SpringMVC是基于过滤器对Servlet进行封装的一个框架,在web.xml配置DispatcherServlet类,每次通过此类来管理收到的请求并进行处理。

**get 和 post 的区别**

1.get是通过URL提交数据,数据在URL上可以看到,post方式数据放在html header内提交,我发在地址栏看到
    2.get提交方式最多只能提交1024字节,而post则没有此限制
    3.get一班用作小数据提交,post用作大数据的情况下

**怎么优化sql语句**
    
    1. select语句中不使用‘*’来查询全部
    2. 减少访问数据库的次数
    3. 整合简单,减少无关联数据库的访问
    4. 删除重复记录
    5. 使用TRUNCATE 代替 DELETE
    6. 尽量多使用commit
**硬件之间的网络传输协议**
    
    -  物理层
    -  数据链路层
    -  网络层
    -  传输层
    -  会话层
    -  表示层
    -  应用层

**Mybatis 怎么实现数据的持久化**
### 加载配置并初始化
     
    触发条件:加载配置文件(一个个配置文件,一个是java代码注解)
    将sql的配置信息加载成为一个个MappedStatement对象,其中包括传入参数映射配置 ,执行sql语句,结果映射配置,存储在内存中。
### 接受调用请求

触发条件:调用Mybatis提供的API
    传入参数:为SQL的ID  传入的参数
    处理过程:将请求传递给下层的请求处理层进行处理

### 处理操作请求
    
    触发条件:API接口层传力请求过来
    传入参数:为SQL的ID的传入的参数
    处理过程:         
    1. 根据sql的ID查找对此那个的MappedStatement对象    
    2. 根据传入参数对象解析MappedStatement对象,得到最终的要执行的sql执行参数
    3. 获取数据库连接,根据得到的最终sql语句和执行传入的参数到数据库执行,获取到执行结果
    4. 更具MappedStatement对象的结果映射配置得到执行结果进行转换处理,并最终得到处理结果
    5. 释放连接资源

**前端和后端是如何进行交互 交互过程**

通过链接或者表单提交,使用ajax异步交互,则是对数据库进行交互管理
    1:前台一般对数据库内容按照页面代码控制进行检索并展示出来形成页面
    2:后台则是对数据库进行增删改查
**json数据传送到后台**

前端使用JSON.Stringify();转化成字符串 后台主要是是利用json的相关jar接受,
    我使用SpringMVC 的@RequestBody 绑定一个对应的实体类,其转化为对应的json数据对应其各个字段,从而接受到前端标端传入的各个数据。

**数据库中的存储过程,触发器,视图,索引**
    
    存储过程:是一系列预先编译好的,能实现特定数据操作功能的的sql代码集,存储在sql server服务器上
    触发器:特殊的存储过程,存储过程是是手动调用的,触发器是由事件自动调用的
    视图:不占物理存储空间,只是一种逻辑对象,可将看成一个虚表,有一个select语句指定,用于检索数据库表中某些行或列数据的语句存储定义
    索引:是数据库中的对象之一,是为了加速对表中数据行的检索而床创建的一种分散的一种存储结构。

**adstract 和 interface 的区别**
    
    abstract不能创建实例对象
    interface中的方法默认是public abstract类型,成员变量默认是public static final 类型
    
    抽象类可以有构造方法,接口中不能有构造方法
    抽象类中可以有普通成员变量,接口中没有普通成员变量
    抽象类中可以包含静态方法,接口不能有静态方法
    一个类可以实现多个接口,但只能继承一个抽象类    
    接口中的抽象方法默认是public static 类型,抽象类中的方法可以是public protected 和默认类型
    抽象类中的成员变量可以任意指定,而接口中的成员变量只能是pubic static final类型

**基本排序**

数据
    int[] a = {2,4,6,7,123,54,78,2,6};

快速排序

            public static void quickSort(int[] arr, int start,int end){
if(start > end){
System.out.println("起始位置选择错误");
return;
}
// 设定基准,分开数据
int base = arr[start];
int i = start;
int j = end;
// 开始一趟排序将数据分成两个部分,一部分比基准小,一部分比基准大
do{
while (arr[i] < base && i < end)
i++;
while (arr[j] > base && j > start)
j--;
if(i<=j){
int t = arr[i];
arr[i] = arr[j];
arr[j] = t;
i++;
j--;
}
// 开始确定其比基准数比较的次数
for(int x = 0; x < arr.length;x++){
System.out.print(arr[x]+" ");
}
System.out.println(""); }while(i <= j);
if(j > start)
quickSort(arr,start,j);
if(i < end)
quickSort(arr, i, end);
}
}

简单排序

    for(int i = 0; i < a.length-1;i++)
for(int j =i+1; j < a.length;j++) {
if (a[i] > a[j]) {
temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}

冒泡排序

    for(int i = 0; i < a.length-1;i++)
for(int j = 0; j <a.length-1-i;j++){
if(a[j] > a[j+1]){
int t = a[j+1];
a[j+1] = a[j];
a[j] = t;
}
}

选择排序

        public static void selectSort(int[] arr){
for(int i = 0; i < arr.length;i++){
int k = i;
for(int j = i; j < arr.length;j++){
if(arr[k] < arr[j]){
k = j;
}
}
int temp = arr[k];
arr[k] = arr[i];
arr[i] = temp;
}
}

  

插入排序

        public static void  insertSort(int[] arr){
System.out.println("--------------------");
int j , temp;
for(int i = 0; i < arr.length;i++){
temp = arr[i];
for(j = i;j > 0 && temp < arr[j-1];j--){
arr[j] = arr[j-1];
}
System.out.println("j = "+j+"i = "+i);
// 将插入的元素不小于此原有数组中的元素时候,将数据插入到后面
arr[j] = temp;
for(int ii = 0 ; ii < arr.length; ii++){
System.out.print(arr[ii]+" ");
}
System.out.println("");
}
System.out.println("--------------------");
}

**单例模式**
    
    线程安全懒汉写法
    class Single{
        private static Single s;
        private Single(){}
        public static Single getInstance(){
            System.out.println("s = "+s);
            if(s == null) {
                s = new Single();
                return s;
            }
            else
                return s;
        }
    }
    
# native
-------
     java 可以和c或者其他语言联合编程
    通过javah 编译java文件,使其生成.h 文件将其头信息复制到c语言文件中,在通过gcc生成动态链接库,然后使用java命令编译,运行

面试题

**SpringMVC工作原理**
    
    首先用户请求DispatcherServlet
    然后DispatcherServlet查询一个多个HandlerMapping,
    HandleMapping提交到Controller,返回ModelAndView,
    DispatcherServlet根据ModelAndView查询其对应的ViewResoler视图解析器找到指定的视图
    将结果显示到页面上。

**文件的输入输出流,字节流,字符流**
    
    字节输入流:InputStream
    字节输出流: OutputSream
    字符输入流:Writer
    字符输出流:Reader
    
    字节输出(输入)流是已byte为单位:图片,视频,压缩包,音频,安装包
    
    字符输出(输入)流是已char为单位:txt,json,xml,html,css,javascript

**手动写jdbc原生程序**    
    
    1.   注册驱动 Class.forName("驱动包权限类名");
    2.   获取数据库的链接,DriverManager.getConnection(url,root,password);
    3.   创建数据库语句,用于执行,(Connection).createStatement();
    4.   将结果集存在resultSet里面,其中使用其next()方法可以跳转到下一个结果上,通过getObject(**String()**)通过其数据库对应的字段名,来获取结果
    5.   释放开启的资源

**sql语句注入问题解决**
    
    使用期预处理对象PreparedStatement来处理sql语句,将其中的需要对应的参数替换掉
    
    - 前面同样的注册,获取数据库连接
    - 在通过连接获取其预处理语句执行
    - 编写数据库的语句,需要参数的则是使用?代替
    - 在预处理语句中设置其各个参数
    - 执行,将结果放入ResultSet中

    String sqlP = "select * from employee where id = ? or id = ?";
PreparedStatement ps = con.prepareStatement(sqlP);
ps.setString(1,"11");
ps.setString(2,"18");
boolean execute1 = ps.execute();
System.out.println("预处理:"+execute);
ResultSet resultSet1 = ps.executeQuery();
while (resultSet1.next())
System.out.println(resultSet1.getObject("address"));

字符串反转:StringBuilder中有一个方法可以直接反转
        reverse().toString()

String str = "abcdef";
        char[] chars = str.toCharArray();
        for(int i = 0; i < chars.length/2;i++){
            char temp = chars[i];
            chars[i] = chars[chars.length-i-1];
            chars[chars.length-i-1] = temp;
        }

**切割字符串**

1. spilt 效率低,简单
    2. StringTokenizer专门的切分字符串类
    3. 使用String的subString(,)查分字符,处理好其字符串的溢出问题

**对jvm的工作原理的简单理解**
    
    jvm的字符码的工作是由字符解释器来解释的
    1. 代码装入
    2. 代码校验
    3. 代码进行

**将一个小数四舍五入 保留两位有效数字**
    
    设置其中需要保留的小数
    BigDecimal 中有个方法,setScale(保留位数,BidDecimal.ROUND_HELF_DOWN)

**instanceof**

result = Object instanceof class
    result : Boolean
    Object : 继承类或者是实现类
    class: 继承那个类的class

**最常见的runtime exception**

     ArithmeticException
ArrayStoreException
BufferOverflowException
BufferUnderflowException
CannotRedoException
CannotUndoException
ClassCastException
CMMException
ConcurrentModificationException
DOMException
EmptyStackException
IllegalArgumentException
IllegalMonitorStateException
IllegalPathStateException,
IllegalStateException
ImagingOpException
IndexOutOfBoundsException,
MissingResourceException
NegativeArraySizeException
NoSuchElementException
NullPointerException
ProfileDataException
ProviderException
RasterFormatException,
SecurityException
SystemException
UndeclaredThrowableException
UnmodifiableSetException
UnsupportedOperationException

**局部变量前面不能放置任何访问修饰符**

**字符串容器的选择是**
    
    选择StringBuffer 或者StringBuilder 可改变字符串,比String速度快

**当复制大量数据时,使用System.arraycopy()命令。**

**IO流复习**

 转换流
    
    inputSteamReader
    outputStreamWriter
    将字节流转换成字符流
对象流
    
    ObjectOutputStream
    ObjectInputStream
    将对象序列化到文件中,需要读出来的时候,在反序列化,其中对象需要实现Serializable

缓冲流
    
    BufferedReader
    BufferedWrite

字符流
        
    FileReader
    FileWriter

字节流
    
    FileInputStream
    FileOutputStream    
    (转换流(缓冲流(字符、字节流、文件输入/输出、键盘读写)))

打印流
    
    PrintWrite
    PrintStream

**反射**

    1. 获取class文件:
1. new 对象 , 在使用其getClass()方法
2. 每个对象都有个class静态字段,获取后再使用期getClassLoader()
3. 通过forName(需要反射类的权限类名) 2. 获取其反射类的构造方法用来创建其对象实例
其中构造方法有私有的,共有的
getConstructors() 获取所有共有的构造方法
getDeclaredConstructors() 获取私有的,受保护的,默认的构造方法
获取单个构造方法
getConstructor(class...parameterTypes)传入其对应参数的.class属性
3. newInstance()获取其无参构造方法
newInstance(...)获取其指定参数的构造方法 4. 获取其方法、属性、执行等等
5. 取消java类型检查机制 其构造方法后有setAccesible(true)

优点: 降低类之间的耦合性,在类运行时加载器类,可以实现动态创建对象和编译,灵活性提高。
缺点:速度降低,反射是一种解释性的操作,总是慢于直接执行的java代码

**多线程**

创建线程的方式:
    1. 继承Thread类
    2. 试下Runnable接口

wait()和sleep()的异同

    反对使用stop(),是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处于一种不连贯状态,
那么其他线程能在那种状态下检查和修改它们。结果很难检查出真正的问题所在。suspend()方法容易发生死锁。
调用suspend()的时候,目标线程会停下来,但却仍然持有在这之前获得的锁定。此时,其他任何线程都不能访问锁定的资源,
除非被"挂起"的线程恢复运行。对任何线程来说,如果它们想恢复目标线程,同时又试图使用任何一个锁定的资源,就会造成死锁。
所以不应该使用suspend(),而应在自己的Thread类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应该挂起,便
用wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()重新启动线程。

请说出你所知道的线程同步的方法。

    wait():使一个线程处于等待状态,并且释放所持有的对象的lock。
sleep():使一个正在运行的线程处于睡眠状态,是一个静态方法,调用此方法要捕捉InterruptedException异常。
notify():唤醒一个处于等待状态的线程,注意的是在调用此方法的时候,并不能确切的唤醒某一个等待状态的线程,而是由JVM确定唤醒哪个线程,而且不是按优先级。
Allnotity():唤醒所有处入等待状态的线程,注意并不是给所有唤醒线程一个对象的锁,而是让它们竞争。

Java中的线程有四种状态分别是:运行、就绪、挂起、结束

轻量级数据安全机制
    volatile,不将数据缓存到cpu中,每次直接从cpu中读取新的数据,每次刷新数据时候,数据都是最新的。

**jsp**

实现servlet的单线程模式
    <%@page isThreadsafe="false"%>
页面间的对象传递方式
    request session application cookie

**XML解析技术**

DOM、SAX、STAX

**多态**

        public class A {
public String show(D obj) {
return ("A and D");
} public String show(A obj) {
return ("A and A");
} } public class B extends A{
public String show(B obj){
return ("B and B");
} public String show(A obj){
return ("B and A");
}
} public class C extends B{ } public class D extends B{ } public class TestP {
public static void main(String[] args) {
A a1 = new A();
A a2 = new B();
B b = new B();
C c = new C();
D d = new D(); System.out.println("1--" + a1.show(b));
System.out.println("2--" + a1.show(c));
System.out.println("3--" + a1.show(d));
System.out.println("4--" + a2.show(b));
System.out.println("5--" + a2.show(c));
System.out.println("6--" + a2.show(d));
System.out.println("7--" + b.show(b));
System.out.println("8--" + b.show(c));
System.out.println("9--" + b.show(d));
}
}
result: 1--A and A
2--A and A
3--A and D
4--B and A
5--B and A
6--A and D
7--B and B
8--B and B
9--A and D

  

-------------------------
-------------------------
# sql语句相关(mysql)
...未完待续

面试小记---java基础知识的更多相关文章

  1. [Java面试二]Java基础知识精华部分.

    一:java概述(快速浏览): 1991 年Sun公司的James Gosling等人开始开发名称为 Oak 的语言,希望用于控制嵌入在有线电视交换盒.PDA等的微处理器: 1994年将Oak语言更名 ...

  2. 【面试】-Java基础知识

    1.Java的工作原理 1) Java源程序(.java)须要通过编译器编译成字节码(.class)文件; 2) Java程序的跨平台主要指字节码能够在不论什么具有Java虚拟机的设备上运行: 3) ...

  3. 面试:Java基础知识(一)

    1.面向对象的特征有哪些方面  1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节.抽 ...

  4. 构造方法和一般方法的区别(面试)-----java基础知识总结

    构造方法:对象创建时,就会调用与之对应的构造方法,对对象进行初始化: 一般方法:对象创建后,需要方法功能时才会调用. 构造方法,在对象创建时,会调用且只调用一次. 一般方法,对象创建后,可以被调用多次 ...

  5. Java基础知识总结(超级经典)

    Java基础知识总结(超级经典) 写代码: 1,明确需求.我要做什么? 2,分析思路.我要怎么做?1,2,3. 3,确定步骤.每一个思路部分用到哪些语句,方法,和对象. 4,代码实现.用具体的java ...

  6. 毕向东—Java基础知识总结(超级经典)

    Java基础知识总结(超级经典) 写代码: 1,明确需求.我要做什么? 2,分析思路.我要怎么做?1,2,3. 3,确定步骤.每一个思路部分用到哪些语句,方法,和对象. 4,代码实现.用具体的java ...

  7. 沉淀,再出发:Java基础知识汇总

    沉淀,再出发:Java基础知识汇总 一.前言 不管走得多远,基础知识是最重要的,这些知识就是建造一座座高楼大厦的基石和钢筋水泥.对于Java这门包含了编程方方面面的语言,有着太多的基础知识了,从最初的 ...

  8. 大话java基础知识一之为什么java的主函数入口必须是public static void

    为什么java的主函数入口必须是public static void main (String[] args); 很多写javaEE好几年的程序员经常会记得java的主函数就是这么写的,但实际上为什么 ...

  9. 【Java面试题系列】:Java基础知识常见面试题汇总 第一篇

    文中面试题从茫茫网海中精心筛选,如有错误,欢迎指正! 1.前言 ​ 参加过社招的同学都了解,进入一家公司面试开发岗位时,填写完个人信息后,一般都会让先做一份笔试题,然后公司会根据笔试题的回答结果,确定 ...

随机推荐

  1. 如何print 输出不换行(2 和 3 处理方式 不一样)

    2.7    正常情况下print输出的时候会自动进行换行处理,我们肯定有时候会有输出不换行的需求, 下面开始介绍如何不换行输出: 例子: print("hello world") ...

  2. SVN 服务器端权限管理

    创建用户 点击菜单上的Users可以在右侧窗口区域中看见已经创建的用户 创建组 同样也可以修改组:  分配权限 示例一:开发人员拥有读写权限(组权限) 进入权限分配界面: 添加组或用户: 在添加页面可 ...

  3. Nginx的upstream反向代理、负载均衡详解

    这篇文章的前提是已经配置好了NGINX,而且tomcat已经配置好了,而且能能够访问了. 说反向代理之前,我们先看看正向代理,正向代理也是大家最常接触的到的代理模式. 正向代理最大的特点是客户端非常明 ...

  4. 操作系统与cpu

  5. webpack摸索笔记

    上一个链接,入门webpack看这篇文章最好:https://segmentfault.com/a/1190000006178770 1.先安装好node 2.建个项目文件 3,.window+r,打 ...

  6. Linux系统(四)LVS集群负载均衡NAT模式

    序言 提到LVS,就从章文嵩博士开始吧,反正也不知道如何下笔来写这一篇.章大博士,读博时候创建这个lvs软件项目,但是他提倡开源精神,在用户的建议和反馈中,这个花了他两周时间开发的开源软件不断得到改建 ...

  7. 2018DDCTF misc1

    一.题目: (╯°□°)╯︵ ┻━┻ d4e8e1f4a0f7e1f3a0e6e1f3f4a1a0d4e8e5a0e6ece1e7a0e9f3baa0c4c4c3d4c6fbb9e1e6b3e3b9e ...

  8. 测试12.2.0.1RAC PDB级别的Failover

    关键步骤:手工添加服务名A并启动(已验证默认的服务名测试验证无法实现Failover) [oracle@db90 ~]$ srvctl add service -db orcl -service A ...

  9. 常用SQL语法

    1.替換A表中B字段中第二个字符 ,), 2.根据 Score 字段 排序 并分页 * from (select row_number() over(order by Score DESC) as r ...

  10. 前端学习历程--vue

    ---恢复内容开始--- 一.对比其他框架 1.react: 共同点: 使用 Virtual DOM 提供了响应式(Reactive)和组件化(Composable)的视图组件. 将注意力集中保持在核 ...