Java基础,面试整理(三)

Java基础(三)

1、阐述JDBC操作数据库的步骤

  1. 加载驱动
  2. 创建连接
  3. 创建语句
  4. 执行语句
  5. 处理结果
  6. 关闭资源

2、JDBC中,Statement和PreparedStatement之间的关系和区别

关系:PreparedStatement接口继承于Statement接口
区别

  1. PreparedStatement是预编译的,可以减少SQL的编译错误并增加SQL的安全性(即减少SQL注射攻击的可能性)。
  2. PreparedStatement中的SQL语句是可以带参数的,避免了用字符串连接拼接SQL语句的麻烦和不安全。
  3. 当批量处理SQL或频繁执行相同的查询时,PreparedStatement的性能更高。

总之,Statement对象代表一个静态的SQL语句,只能执行一次。PreparedStatement对象代表一个预编译的SQL语句,可以被多次执行,效率更高。

3、Java中守护线程和本地线程的区别

在JVM启动时候会调用main函数,main函数所在的线程是一个用户线程,这个是我们可以看到的线程,其实JVM内部同时还启动了好多守护线程,比如垃圾回收线程。那么守护线程和用户线程有什么区别那?区别之一是当最后一个非守护线程结束时候,JVM会正常退出,而不管当前是否有守护线程,也就是说守护线程是否结束并不影响JVM的退出。言外之意是只要有一个用户线程还没结束正常情况下JVM就不会退出。
如果想在主线程结束后JVM进程马上结束,那么创建线程的时候可以设置线程为守护线程;反之,如果希望主线程结束后子线程继续工作,等子线程结束后再让JVM进程结束,那么就设置子线程为用户线程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值