面试 java编译过程,Java开发面试过程中的问题整理一

一、Java基础

7172fab2d504213e84413a695578af29.png

1、Java中两种数据类型(为后面进一步提问做铺垫)

(1)基本数据类型,分为boolean、byte、int、char、long、short、double、float;

(2)引用数据类型 ,分为数组、类、接口。

扩展:Java中引入了基本数据类型,但是为了能够将这些基本数据类型当成对象操作,Java为每一个基本数据类型都引入了对应的包装类型(wrapper class),int的包装类就是Integer,从Java 5开始引入了自动装箱/拆箱机制,使得二者可以相互转换。

基本数据类型: boolean,char,byte,short,int,long,float,double

封装类类型: Boolean,Character,Byte,Short,Integer,Long,Float,Double

2、java中==和eqauls()的区别

==分两类分析,既可以比较基本类型也可以比较引用类型,对于基本类型来说是比较的数值。对于引用类型来说比较的内存地址值;equals是属于java.lang.Object类里面的方法,Object里的equals里默认的是双等于==。分两种情况讨论:一种是自定义类,看自定义类有没有重写equals方法,通常情况下,如果重写了equals则比较的是类中相应属性是否相等。如果没有重写equals方法,则仍然使用==比较的是地址。

总结、:

== :

基本类型:比较值是否相等

引用类型:比较的就是内存地址是否相同

equals :

引用类型:默认情况下,比较的是地址值。可以进行重写,使其比较对象的值是否相等。

3、说说int和Integer有何区别

(1)Integer是int的包装类;int是基本数据类型;

(2)Integer变量必须实例化后才能使用;int变量不需要;

(3)Integer实际是对象的引用,指向此new的Integer对象;int是直接存储数据值 ;

(4)Integer的默认值是null;int的默认值是0。

4、switch中能否使用string类型的参数作为变量(涉及到jdk版本的理解)

在JDK1.7之前,switch只能支持byte、short、char、int、float、double或者其对应的封装类以及Enum类型。JDK1.7开始支持String。当字符串不会频繁改变时可以用枚举来代替String。

5、说明ArrayList和LinkedList的区别和优缺点,在哪些场景会使用?

区别:

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

(2)对于随机访问的get和set方法,ArrayList要优于LinkedList,因为LinkedList要移动指针;

(3)对于新增和删除操作add和remove,LinkedList比较占优势,因为ArrayList要移动数据;

各自优缺点:

(1)对ArrayList和LinkedList而言,在列表末尾增加一个元素所花的开销都是固定的。对ArrayList而言,主要是在内部数组中增加一项,指向所添加的元素,偶尔可能会导致对数组重新进行分配;而对LinkedList而言,这个开销是 统一的,分配一个内部Entry对象。

(2)在ArrayList集合中添加或者删除一个元素时,当前的列表移动元素后面所有的元素都会被移动。而LinkedList集合中添加或者删除一个元素的开销是固定的。

(3)LinkedList集合不支持 高效的随机随机访问(RandomAccess),因为可能产生二次项的行为。

(4)ArrayList的空间浪费主要体现在在list列表的结尾预留一定的容量空间,而LinkedList的空间花费则体现在它的每一个元素都需要消耗相当的空间。

应用场景:

ArrayList使用在查询比较多,但是插入和删除比较少的情况,而LinkedList用在查询比较少而插入删除比较多的情况

6、实现多线程的几种方式,多线程的应用场景有哪些?

(1)、继承Thread类,重写run方法

(2)、实现Runnable接口,重写run方法。【可以避免由于Java的单继承特性而带来的局限。适合多个线程去处理同一资源的情况】

(3)、实现Callable接口,重写call方法。【有返回值,允许抛出异常】

(4)、使用线程池【减少创建新线程的时间,重复利用线程池中线程,降低资源消耗,可有返回值】

7、${}和#{}的区别

使用#{}:

(1)、传入参数,sql在解析的时候会加上" ",当成字符串来解析,如 id = "id";

(2)、#{}能够很大程度上防止sql注入;

使用${}:

(1)、传入数据直接显示在生成的sql中,sql在解析的时候值为id = id。

(2)、${}方式无法防止sql注入

最后:能用#{}时尽量用#{},但有些场合需要使用$。

注意MyBatis排序时使用order by 动态参数时需要注意,用$而不是#(#会自动拼接符号)

8、描述一下JVM加载class文件的原理机制和特点。

Java中的所有类,都需要由类加载器装载到JVM中才能运行。JVM中类的加载是由类加载器(ClassLoader)和它的子类来实现的。在我们使用一个类之前,JVM需要先将该类的字节码文件(.class文件)从磁盘、网络或其他来源加载到内存中(加载Class文件到JVM),并对字节码进行解析生成对应的Class对象,这就是类加载器的功能。我们可以利用类加载器,实现类的动态加载。在写程序的时候,我们几乎不需要关心类的加载,因为这些都是隐式装载的,除非我们有特殊的用法,像是反射,就需要显式的加载所需要的类。

Java类的加载是动态的,它并不会一次性将所有类全部加载后再运行,而是保证程序运行的基础类(像是基类)完全加载到jvm中,至于其他类,则在需要的时候才加载。这当然就是为了节省内存开销。

进一步提问:类加载的方式有几种?区别是什么?

类装载方式有两类:隐式装载和显示装载,其中显示装载又分2种方式。

(1)、隐式装载,程序在运行过程中当碰到通过new 等方式生成对象时,隐式调用类装载器加载对应的类到jvm中,比如

Dog dog = new Dog();【第一种方式】

(2)、显式装载,

【第二种方式】使用Class.forName()通过反射加载类型,并创建对象实例,比如

Class clazz = Class.forName(“Dog”);

Object dog =clazz.newInstance();

如果无法找到Dog,则抛出ClassNotFoundException。

【第三种方式】使用某个ClassLoader实例的loadClass()方法

Class clazz = classLoader.loadClass("Dog");

Object dog=clazz.newInstance();

如果无法找到Dog,则抛出ClassNotFoundException。

区别:

方式1和2使用的类加载器是相同的,都是当前类加载器(即:this.getClass.getClassLoader)。

方式3由用户指定类加载器。如果需要在当前类路径以外寻找类,则只能采用方式3。即第3种方式加载的类与当前类分属不同的命名空间。

方式1是静态加载,方式2和3是动态加载。

进一步提问:java内置的类加载器(ClassLoader)有哪些,简述一下类加载器工作原理

Java的类加载器有三个:

第一种是Bootstrap Loader(引导类加载器)。它的实现依赖于底层操作系统,由C编写而成,没有继承于ClassLoader类。根类加载器从系统属性sun.boot.class.path所指定的目录中加载类库。默认为jre目录下的lib目录下的class文件,该加载器没有父加载器。负责加载虚拟机的核心类库,如java.lang.*。Object类就是由根类加载器加载的。

第二种是Extended Loader(标准扩展类加载器)。它的父加载器为根类加载器。由java编写而成,是ClassLoader的子类。它从java.ext.dirs中加载类库,或者从JDK安装目录jre\lib\ext子目录下加载类库。如果把用户创建的jar文件放在该目录下,也会自动由扩展类加载器加载。

第三种是AppClass Loader(应用程序类路径类加载器)。它的父加载器为扩展类加载器。由java编写而成,是ClassLoader的子类,它从环境变量classpath或者系统属性java.class.path所指定的目录中加载类,是用户自定义的类加载器的默认父加载器。

加载类时,会以Bootstrap Loader→Extended Loader→AppClass Loader的顺序来寻找类,如果找不到,就会丢出NoClassDefFoundError。

473a08fc1c4597401fb45a085b68eba4.png

9、在一个类中,声明了若干个static方法和非static方法,声明的static方法能否直接访问声明的非static方法?

static方法不能直接访问非static方法,因为static方法是属于这个类本身的一个方法,在编译期间就已经确定了;而非static方法是属于这个类的对象的方法,需要在实例化之后才能访问到。即:static方法调用时不需要创建对象,可以直接调用,非static方法是要与对象关联在一起的,必须创建一个对象后,才可以在该对象上进行方法调用,若在static方法中访问非static方法,非static方法不知道关联到哪个对象上,将不能通过编译。

进一步提问:说一下静态方法和非静态方法都是在什么时候被装载到内存中的?

静态方法(Static Method)与静态成员变量一样,属于类本身,在类装载的时候被装载到内存(Memory),不自动进行销毁,会一直存在于内存中,直到JVM关闭。

非静态方法(Non-Static Method)又叫实例化方法,属于实例对象,实例化后才会分配内存,必须通过类的实例来引用。不会常驻内存,当实例对象被JVM 回收之后,也跟着消失。

进一步提问:静态方法怎样访问非静态方法?

静态方法不能直接使用本类的非静态方法

解决方式有三种

(1)、两个方法都改成非静态

(2)、两个方法都改成静态

(3)、先创建类的实例,然后静态方法再调用这个实例的非静态方法

10、在Java中,对象什么时候可以被垃圾回收?

Java垃圾回收不是实时的,垃圾回收器的作用是查找和回收(清理)无用的对象。以便让JVM更有效的使用内存。垃圾回收器的运行时间是不确定的,由JVM决定,在运行时是间歇执行的。也可以通过System.gc()来强制回收垃圾,但是这个命令下达后JVM不一定会立即响应执行,但间隔一小段时间基本都会执行。

11、一个汉字占几个字节

中文在不同编码下占不定长的 2~4个字节。注意在utf-16中占用两个字节,在java 运行时用UTF-16编码在转码的时候会在前面加上表示字节顺序的字符,这个字符称为”零宽度非换行空格”(ZERO WIDTH NO-BREAK SPACE),用FEFF表示。FEFF占用两个字节。

65f5e856ff5a9f2494e511e8ce043163.png

12、项目中使用Maven进行构建,有哪些优势?你使用过哪些maven命令?说一下maven中本地仓库和远程仓库的区别和联系。

优点:

(1)创建项目,自动关联和下载依赖的jar包,统一维护jar包

(2)升级框架版本方便

常用 Maven 命令:

(1)、安装项目到本地仓库:mvn install

(2)、创建maven项目:mvn archetype:generate

(3)、验证项目是否正确:mvn validate

(4)、maven 打包:mvn package

(5)、只打jar包:mvn jar:jar

(6)、生成源码jar包:mvn source:jar

(7)、产生应用需要的任何额外的源代码:mvn generate-sources

(8)、编译源代码: mvn compile

(9)、编译测试代码:mvn test-compile

(10)、运行测试:mvn test

(11)、运行检查:mvn verify

(12)、清理maven项目:mvn clean

Maven仓库关系:

maven的仓库只有两大类:1.本地仓库 2.远程仓库,在远程仓库中又分成了3种:2.1 中央仓库 2.2 私服 2.3 其它公共库

运行Maven的时候,Maven所需要的任何构件都是直接从本地仓库获取的。如果本地仓库没有,它会首先尝试从远程仓库下载构件至本地仓库,然后再使用本地仓库的构件。

3e8bc7fa895ccfd361c57b597e7debc8.png

13、Thread.sleep(0)有没有实际作用

触发操作系统立刻重新进行一次CPU竞争,操作系统重新计算线程的优先级(包括当前线程)。竞争的结果也许是当前线程仍然获得CPU控制权,也许会换成别的线程获得CPU控制权。

二、前端框架

1、在项目中使用过哪些前端框架?

Vue(用于构建用户界面的 渐进式框架,特点:轻量级、双向数据绑定、组件化)、

React(构建用户界面的 JAVASCRIPT 库,特点:只负责显示、声明式框架、数据驱动DOM)、

Angular(前端JS框架,核心:MVVM、模块化、自动化双向数据绑定、语义化标签、依赖注入等)、

QucikUI(企业级web前端开发解决方案)、

Layui(前端 UI 框架)、

Avalon(前端MVVM框架)、

还有Dojo、Ember、Aurelia等

2、js中如何查看某变量的数据类型?可以查看的数据类型有哪些?

使用typeof查看变量的数据类型。

javascript共有6种数据类型:

基本类型5种:number、string、boolean、null、undefined。引用类型1种:object

typeof检测返回6种:undefined、boolean、string、number、object、function

3d0367dce6d2d3d758dbb35931548e89.png

3、前端进行文件下载时,能不能用ajax向后端发起请求?

Ajax不能实现文件下载功能

原因:ajax的返回值是json,text,html,xml类型,或者可以说ajax的接收类型只能是String字符串,不是流类型,所以无法实现文件下载。但用aja仍然可以获得文件的内容(可以读取到返回的response,但只是读取而已),该文件将被保留在内存中,无法将文件保存到磁盘,这是因为javascript无法和磁盘进行交互,否则这会是一个严重的安全问题,js无法调用浏览器的下载处理机制和程序,会被浏览器阻塞。

4、如何解决前后端交互过程中特殊字符的传参(比如中文、特殊符号等)?

(这个问题属于送分题,有一定项目经验的人,都会注意到在前后端进行交互时,需要进行decoder编码-Encoder解码的过程,防止乱码)

进一步提问:前后端数组传参如何处理?

前端:数据使用JSON.stringify(str)处理

后端:数据转换:List objectList = JSONObject.parseArray(str, Object.class)

5、FreeMarker、jsp、html 三者的区别

先说说freemarker和jsp的不同,运行机制就不大一样,jsp是编译成继承自servlet的class文件,运行jsp就是运行一个servlet(Java文件编译后会产生一个class文件,最终执行的就是这个class文件,JSP也一样,它也要编译成class文件。JSP不止要编译,它还得要转译,首先把JSP转译成一个Servlet文件,然后再编译成class文件。当用户访问JSP时就执行了class文件)。

而freemarker就是套模板,通过模板+内容直接生成HTML然后输出。

HTML(Hypertext Markup Language)文本标记语言,它是静态页面,和JavaScript一样是解释性语言。

JSP(Java Server Page)Java服务端的页面,它是动态页面,它是需要经过JDK编译后把内容发给客户端去显示。

6、vue实例内部和外部分别怎么调用vue中的方法?

内部调用: this.operate();

外部调用:vm.operate(); (vm是vue实例名)

举报/反馈

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值