一、谈谈你对java的理解

1、平台无关性,一次编译到处运行

2、GC

3、语言特性

4、面向对象

5、类库

6、异常处理

二、Java如何做到一次编译到处运行?(如何做到平台无关性)

首先我们先来编写一个java程序:

public class ByteCodeSimple {
public static void main(String[] args) {
int i = 1, j = 5;
i++;
++j;
System.out.println(i);
System.out.println(j);
}
}

首先我们先对这段程序使用javac 命令进行编译:

可以看到得到了对应ByteCodeSimple.class

之后再src目录下,用java命令加上包名执行class文件,我们可以看到他的执行是符合预期的。

我们如何查看.class文件呢,可以通过Idea打开,就可以自动进行反编译。

下面我们使用javap命令来进行反编译-c的意义代表反编译,如果想查询帮助指令,可以输入javap -help进行查询。

一次编译到处运行如何实现?

java文件->.class文件

Java源码首先被编译成字节码,再由不同平台的JVM进行解析,Java语言在不同的平台上运行时不需要重新进行编译,Java虚拟机在执行字节码时,把字节码转换成具体平台的机器指令。

三、JVM如何加载.class文件

JVM最值得学习:jvm内存模型,GC

Class Loader(类加载器):依据特定格式,加载class文件到内存

Execution Engine(执行引擎):对命令进行解析。

Native Interface(本地方法借口):融合不同开发语言的原生库为Java所用。

Runtime Data Area(内存模型):JVM内存空间结构模型。

结论:首先是由ClassLoader加载.class文件,之后通过Execution Engine命令进行执行。

四、什么是反射?

首先新建一个Robot类

public class Robot {
private String name; public void hello1(String content) {
System.out.println(content + name);
} private String hello2(String content) {
return "hello2" + content + name;
}
}

使用反射去调用Robot类中的方法:

public class ReflectSample {
public static void main(String[] args) throws ClassNotFoundException, IllegalAccessException, InstantiationException, NoSuchMethodException, InvocationTargetException, NoSuchFieldException {
//根据类名获取Class对象
Class rc = Class.forName("com.interview.reflect.Robot");
//根据类类型,去创建Robot对象
Robot robot = (Robot) rc.newInstance();
//调用方法hello1
robot.hello1("123"); //这个方法可以获得道类内部的所有方法包含公有和私有方法,却不能获得器父类继承的方法,和接口实现的方法
Method method = rc.getDeclaredMethod("hello2", String.class);
//在反射私有方法时要设置这个方法的值为true
method.setAccessible(true);
//执行方法并获得返回值
String result = (String) method.invoke(robot, "wzy");
//输出结果
System.out.println("result:" + result); //这个方法可以获取类内的公有方法,和父类继承公有的方法;
Method method1 = rc.getMethod("hello1", String.class);
//调用方法hello1
method1.invoke(robot, "welcome"); //获取私有成员变量
Field name = rc.getDeclaredField("name");
//设置允许方法私有属性
name.setAccessible(true);
//设置私有对象的值
name.set(robot, "yuan"); //调用hello1方法
method1.invoke(robot, "123");
}
}

运行结果:

五、谈谈ClassLoader

类从编译到执行的过程

编译器将Robot.java源文件编译为Robot.class字节码文件

ClassLoader将字节码转换为JVM中的Class<Robot>对象

JVM利用Class<Robot>对象实例化为Robot对象。

ClassLoader在Java中有着非常重要的作用,它主要工作在Class的装载的加载阶段,其主要作用是从系统外部获得Class的二进制数据流,它是Java的核心组件,所有的

Class都是由ClassLoader进行加载的,ClassLoader负责通过将Class文件里的二进制数据流装载进系统,让后交给java虚拟机进行连接、初始化等操作。

通过查看源码我们可以发现,ClassLoader是一个抽象类:

其中最重要的方法就是ClassLoader中的loadClass(String name)方法

我们还可以发现ClassLoader类当中有parent成员变量,是另一个ClassLoader说名ClassLoader的种类不止一种。

ClassLoader的种类:

BootStrapClassLoader:C++编写,加载核心库java.*

ExtClassLoader:Java编写,加载扩展库javax.*(用户看的到的ClassLoader)(C:\Java\jdk\jre\lib\ext;C:\Windows\Sun\Java\lib\ext)

AppClassLoader:Java编写,加载程序所在的目录

自定义ClassLoader:Java编写,定制加载

通过查看ExtClassLoader源码,可以看到它的class的加载路径,用到才会去加载

我们对这个路径进行打印得到:

通过查看AppClassLoader源码,我们可以看到其对应的加载路径:

对这个路径进行打印,得到结果,其中就包含了我们项目本身的.class文件输出路径out.加载类路径(classpath)最重要的路径:E:\project\javabasic\out\production\javabasic;

实现自定义ClassLoader:

首先我们先创建一个类:

 public class Wali {
static {
System.out.println("Hello Wali");
}
}

之后单独对这个类使用javac进行编译,而不通过IDE,注意这个Wali类中没有定义package,否则执行的时候需要带着包名

创建一个MyClassLoader类

 public class MyClassLoader extends ClassLoader {
/**
* 加载类的路径
*/
private String path;
/**
* 类加载器的名称
*/
private String classLoaderName; /**
* 定义构造方法
* @param path 加载类的路径
* @param classLoaderName 类加载器的名称
*/
public MyClassLoader(String path, String classLoaderName) {
this.path = path;
this.classLoaderName = classLoaderName;
} /**
* 用于寻找类文件
* @param name
* @return
*/
@Override
public Class findClass(String name) {
byte[] b = loadClassData(name);
return defineClass(name, b, 0, b.length );
} /**
* 将文件转换为字节流
* @param name
* @return
*/
private byte[] loadClassData(String name) {
//拼接出文件的名字
name = path + "\\" + name + ".class";
InputStream in = null;
ByteArrayOutputStream bos = null; try {
in = new FileInputStream(name);
bos = new ByteArrayOutputStream();
int i = 0;
//对文件进行读取
while ((i = in.read()) != -1) {
bos.write(i);
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
in.close();
bos.close();
} catch (IOException e) {
e.printStackTrace();
}
}
//返回字节数组
return bos.toByteArray();
}
}

MyClassLoader测试类:

 public class MyClassLoaderChecker {
public static void main(String[] args) throws IllegalAccessException, InstantiationException {
MyClassLoader myClassLoader = new MyClassLoader("E:\\project\\javabasic\\src\\com\\interview\\reflect", "myClassLoader");
Class aClass = myClassLoader.findClass("Wali");
//创建对象触发执行静态块代码
Object o = aClass.newInstance();
}
}

运行结果:

Java面试01的更多相关文章

  1. Java面试01|JVM相关

    1.JVM内存查看与分析,编写内存泄露实例 堆区.栈区.方法区.本机内存都有可能内存溢出.在这里编写堆区内存溢出实例.如下(来自<深入理解Java虚拟机>一书. // -Xms20m -X ...

  2. Java面试----01.JavaSE

    1.面向对象和面向过程的区别 面向过程:面向过程性能比面向对象高. 因为类调用时需要实例化,比较消耗资源,所以当性能是最重要的考虑因素时,比如单片机.嵌入式开发.Linux/Unix等一般采用面向对象 ...

  3. Java面试系列

    如果你的面试简历是如下这样写的,请务必准备回答下面的所有问题. 面试职位:Java高级工程师 专业技能: (1)牢固掌握Java基础知识,如集合.并发.I/O等,并对Java源码有一定的研究. (2) ...

  4. Java 面试宝典-2017

    http://www.cnblogs.com/nelson-hu/p/7190163.html Java面试宝典-2017   Java面试宝典2017版 一. Java基础部分........... ...

  5. Java面试宝典-2017

    Java面试宝典2017版 一. Java基础部分........................................................................... ...

  6. Java 面试知识点解析(四)——版本特性篇

    前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...

  7. Java面试宝典2018

    转 Java面试宝典2018 一. Java基础部分…………………………………………………………………………………….. 7 1.一个“.java”源文件中是否可以包括多个类(不是内部类)?有什么限制 ...

  8. Java面试知识点之线程篇(一)

    前言:在Java面试中,一定会遇到线程相关问题,因此笔者在这里总结Java中有关线程方面知识点,多数从网上得来(文中会贴出主要参考链接),有些也是笔者在面试中所遇到的问题,如有错误,请不吝指正.主要参 ...

  9. Java面试,如何在短时间内做突击

    面试前很有必要针对性的多刷题,大部分童鞋实战能力强,理论不行,面试前不做准备很吃亏.这里整理了很多常考面试题,希望对你有帮助.   面试技术文 Java岗 面试考点精讲(基础篇01期) Java岗 面 ...

随机推荐

  1. 多线程分配线程的实现方案:CountDownLatch类

    需求:假如我们本地有4个文件需要解析,每个文件的内容为20万行.为了提高效率我们要创建4个线程进行处理.等4个线程处理完,要在文件日志表中记录处理状态. 一般的的解决方法是使用join,join用于让 ...

  2. net.sf.json.JSONObject处理 "null" 字符串的一些坑

    转: net.sf.json.JSONObject处理 "null" 字符串的一些坑 2018年05月02日 16:41:25 大白能 阅读数:7026   版权声明:本文为博主原 ...

  3. Nova Conductor 与 Versioned Object Model 机制

    目录 文章目录 目录 Nova Conductor 数据库访问代理机制 Versioned Object Model 机制 Nova Conductor Conductor 服务作为 Nova 核心部 ...

  4. Mycat读写分离 + 主从复制(Gtid)

    大概架构如下: IP 主机名   OS192.168.1.177 mycat   CentOS7.4.1708192.168.1.184   master CentOS7.4.1708192.168. ...

  5. Jmeter实现WebSocket协议的接口

    1.下载websocket插件的jar包 网盘链接:https://pan.baidu.com/s/1FDcTHdQcDo6izgROMgB96w 密码:uags 该包下载完成后直接放在jmeter的 ...

  6. 【WPF】非UI线程操作UI

    在线程中添加下面两行,把操作UI的命令放到一个新函数中 Action 起个名 = new Action(操作UI的函数名);要操作的控件名.Dispatcher.BeginInvoke(起个名);

  7. Python学习之认知(二)

    第二章(二) 2.1.5 变量 ​ 变量:将运算的中间结果暂存到内存,以便后续程序调⽤. 变量的命名规则: ​ 1.变量由字母, 数字,下划线搭配组合⽽成 ​ 2.不可以⽤数字开头,更不能是全数字 ​ ...

  8. HR,OA,CRM,DRP,ERP什么意思?电商行业的特点?电商行业模式?专业术语?

    HR,OA,CRM,DRP,ERP HR----Human Resource人力资源管理 OA----Office Automation办公自动化 CRM---Customer Relationshi ...

  9. Leetcode之动态规划(DP)专题-64. 最小路径和(Minimum Path Sum)

    Leetcode之动态规划(DP)专题-64. 最小路径和(Minimum Path Sum) 给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. ...

  10. cisco三层交换为vlan配置dhcp

        dhcp(config)#vlan 2 dhcp(config-vlan)#name sales dhcp(config-vlan)#vlan 3 dhcp(config-vlan)#name ...