【JAVA面试题-基础篇(九)】

synchronized和Lock的区别

1.synchronized可以给类、方法、代码块加锁;而lock只能给代码块加锁。
2.synchronized不需要手动获取锁和释放锁,使用简单,发生异常会自动释放锁,不会造成死锁;而lock需要自己加锁和释放锁,如果使用不当没有unLock()去释放锁就会造成死锁。
3.通过Lock可以知道有没有成功获取锁,而synchronized却无法办到。

线程之间如何进行通信?

1.使用synchronized锁的wait和notify进行等待和唤醒
2.使用lock锁的condition的await和signal进行等待唤醒

什么导致线程阻塞

阻塞状态的线程的特点是:该线程放弃CPU的使用,暂停运行,只有等到导致阻塞的原因消除之后才恢复运行。或者是被其他的线程中断,该线程也会退出阻塞状态。
1.线程执行了Thread.sleep(intmillsecond)方法,当前线程放弃CPU,睡眠一段时间,然后在恢复执行
2.线程执行一段同步代码,但是尚且无法获得相关的同步锁,只能进入阻塞状态,等到获取了同步锁,才能回复执行。
3.线程执行一个对象的wait()方法,直接进入阻塞状态,等待其他线程执行notify()或者notifyAll()方法。
4.线程执行某些IO操作,因为等待相关的资源而进入了阻塞状态。

什么是死锁如何防止死锁

当线程A持有独占锁a,并尝试去获取独占锁b的同时,线程B持有独占锁b,并尝试获取独占锁a的情况下,就会发生AB两个线程由于互相持有对方需要的锁,而发生的阻塞现象,我们称为死锁。简单来说,就是两个线程为了争抢资源而发生的相互等待的线程阻塞现象。
1、尽量使用tryLock的方法,设置超时时间,超时可以退出防止死锁。
2、尽量使用Java.util.concurrent并发类代替自己手写锁
3、尽量降低锁的使用粒度,尽量不要几个功能用同一把锁。
4、尽量减少同步的代码块。

内存中堆和栈的区别

功能方面:堆是用来存放对象的,栈是用来执行程序的。
共享性:堆是线程共享的,栈是线程私有的。
空间大小:堆大小远远大于栈

Java当中IO流的分类

字节流:
InputStream(抽象类) OutputStream
FileInputStream FileOutputStream(实现类)
装饰者模式对传统的字节流进行了封装,增加了缓冲区功能。
BufferedInputStream BufferedOutputStream(带有缓冲区的字节流)

字符流:
Reader writer
FileReader FileWriter
BufferedReader BufferedWriter

什么是反射机制?

Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为Java语言的反射机制。
静态编译和动态编译
静态编译:在编译时确定类型,绑定对象
动态编译:运行时确定类型,绑定对象

反射机制优缺点

优点:运行期类型的判断,动态加载类,提高代码灵活度。
缺点:性能瓶颈:反射相当于一系列解释操作,通知JVM要做的事情,性能比直接的Java代码要慢很多。

反射机制的应用场景有哪些?

反射是框架设计的灵魂。
在我们平时的项目开发过程中,基本上很少会直接使用到反射机制,但这不能说明反射机制没有用,实际上有很多设计、开发都与反射机制有关,例如模块化的开发,通过反射去调用对应的字节码;动态代理设计模式也采用了反射机制,还有我们日常使用的Spring / Hibernate等框架也大量使用到了反射机制。
举例:1、我们在使用JDBC连接数据库时使用Class.forName()通过反射加载数据库的驱动程序;2、Spring框架也用到很多反射机制,最经典的就是xml的配置模式。Spring通过XML配置模式装载Bean的过程:1)将程序内所以XML或Properties配置文件加载入内存中;2)Java类里面解析XML或Properties里面的内容,得到对应实体类的字节码字符串以及相关的属性信息;3)使用反射机制,根据这个字符串获得某个类的Class实例;4)动态配置实例的属性。

Java获取反射的三种方法

1.通过new对象实现反射机制。2.通过路径实现反射机制。3.通过类名实现反射机制

public class Student{
	private int id;
	String name;
	protected boolean sex;
	public float score;
}
public class Get{
	//获取反射机制三种方式
	  public static void main(String[] args) throws ClassNotFoundException {
        //方式一(通过建立对象)
        Student stu = new Student();
        Class classobj1 = stu.getClass();
        System.out.println(classobj1.getName());
        //方式二(所在通过路径-相对路径)
        Class classobj2 = Class.forName("fanshe.Student");
        System.out.println(classobj2.getName());
        //方式三(通过类名)
        Class classobj3 = Student.class;
        System.out.println(classobj3.getName());
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值