2018.3.29 青旅半醒 2022-05-28 07:06 86阅读 0赞 ### 1. **PreparedStatement和Statement的一些知识:** ### PreparedStatement是继承Statement接口的,PreparedStatement的实例包含已经编译的sql语句,所以其执行速度要大于Statement。 PreparedStatement是最大可能提高性能,语句在被 DB 的编译器编译后的执行代码被缓存下来 ,那么下次调用时只要是相同的预编译语句就不需要编译 , 只要将参数直接传入编译过的语句执行代码中,而如果你使用预编译语句 . 你传入的任何内容就不会和原来的语句发生任何匹配的关系 . 只要全使用预编译语句 , 你就用不着对传入的数据做任何过虑 . 而如果使用普通的 statement, 有可能要对 drop,; 等做费尽心机的判断和过虑 。 因为preparedstatement是带有预编译的(也就是有占位符的),所谓占位符就是可能会是很多种条件,与statement相比,statement只是固定条件,就一个,所以preparedstatement的检索范围肯定大。 ### 2. **abstract class和interface有什么区别** ### 抽象类可以有构造方法,接口中不能有构造方法。 抽象类中可以有普通成员变量,接口中没有普通成员变量。 抽象类中可以包含非抽象的普通方法,接口中的所有方法必须都是抽象的,不能有非抽象的普通方法。 抽象类中的抽象方法的访问类型可以是public,protected,但接口中的抽象方法只能是public类型的,并且默认即为public abstract类型。 抽象类中可以包含静态方法,接口中不能包含静态方法。 抽象类和接口中都可以包含静态成员变量,抽象类中的静态成员变量的访问类型可以任意,但接口中定义的变量只能是public static final类型,并且默认即为public static final类型。 call by value不会改变实际参数的数值。 call by reference不能改变实际参数的参考地址。 call by reference能改变实际参数的内容。 ### 3. **集合对象中哪几个是线程安全的** ### Vector Hashtable Stack
还没有评论,来说两句吧...