Java基础(三)
1、阐述JDBC操作数据库的步骤
- 加载驱动
- 创建连接
- 创建语句
- 执行语句
- 处理结果
- 关闭资源
2、JDBC中,Statement和PreparedStatement之间的关系和区别
关系:PreparedStatement接口继承于Statement接口
区别:
- PreparedStatement是预编译的,可以减少SQL的编译错误并增加SQL的安全性(即减少SQL注射攻击的可能性)。
- PreparedStatement中的SQL语句是可以带参数的,避免了用字符串连接拼接SQL语句的麻烦和不安全。
- 当批量处理SQL或频繁执行相同的查询时,PreparedStatement的性能更高。
总之,Statement对象代表一个静态的SQL语句,只能执行一次。PreparedStatement对象代表一个预编译的SQL语句,可以被多次执行,效率更高。
3、Java中守护线程和本地线程的区别
在JVM启动时候会调用main函数,main函数所在的线程是一个用户线程,这个是我们可以看到的线程,其实JVM内部同时还启动了好多守护线程,比如垃圾回收线程。那么守护线程和用户线程有什么区别那?区别之一是当最后一个非守护线程结束时候,JVM会正常退出,而不管当前是否有守护线程,也就是说守护线程是否结束并不影响JVM的退出。言外之意是只要有一个用户线程还没结束正常情况下JVM就不会退出。
如果想在主线程结束后JVM进程马上结束,那么创建线程的时候可以设置线程为守护线程;反之,如果希望主线程结束后子线程继续工作,等子线程结束后再让JVM进程结束,那么就设置子线程为用户线程。