Statement和PreparedStatement有什么区别?哪个性能更好?
与Statement相比
- PreparedStatement接口代表预编译的语句,它主要的优势在于可以减少SQL的编译错误并增加SQL的安全性(减少SQL注入攻击的可能性)
- PreparedStatement中的SQL语句是可以带参数的,避免了用字符串连接拼接SQL语句的麻烦和不安全
- 当批量处理SQL或频繁执行相同的查询时,preparedStatement有明显的性能上的优势,由于数据库可以将编译优化后的SQL语句缓存起来,下次执行相同结构的语句是就会很快(不用再次编译和生成执行计划)
Java中的基本数据类型及包装类
数据类型 | 大小 | 包装类 |
---|---|---|
boolean()布尔型) | 1(位) | Boolean(布尔型) |
byte(字节) | 8(位) | Byte(字节) |
char(字符型) | 16(位) | Character(字符型) |
shot(短整型) | 16(位) | Shot(短整型) |
int(整型) | 32(位) | Integer(整型) |
long(长整型) | 32(位) | Logn(长整型) |
float(浮点型) | 32(位) | Float(浮点型) |
double(双精度) | 64(位) | Double(双精度) |
ArrayList和LinkedList有什么区别
- 因为Array是基于索引(index)的数据结构,它使用索引在数组中搜索和读取数是很快的。Array获取数据的时间复杂度是O(1),但是要删除数据缺失开销很大的,因为这需要重排数组中的所有数据
- 相对于ArrayList,LinkedList插入是更快的。因为LinkedList不想ArrayList一样,不需要改变数组的大小,也不需要再数组装满的时候要将所有的数据重新装入一个新的数组,这是ArrayList最坏的一种情况,时间复杂度是O(n),而LinkedList中插入或删除的时间复杂度金为O(1)。ArrayList在插入数据是还需要更新索引(除了插入数组的尾部)。
- 类似于插入数据,删除数据时,LinedList也优于ArrayList。
- LinkedList需要更多的内存,因为ArrayList的每个索引的位置是实际的数据,而LinkedList中的每个节点中存储的是实际的数据和前后节点的位置。
面向对象的特征有哪些方面
- 继承
继承是一种联结类的层次模型,并且允许和鼓励类的中庸,它提供了一种明确表达共性的方法。
对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类,而原始类称为新类的基类。派生类可以从他的基类哪里继承方法和实例变量,并且类可以修改或增加新的方法使之更合适特殊的需求 - 封装
封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。
面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。 - 多态
多态是值允许不同类的对象堆同一消息做出响应
多态包括参数化多态和包含多态性。
多态语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题
主要有两种表现方式:重载和重写
线程的五种状态
- 创建状态
在生成线程对象,并没有调用该对象的start方法,这是线程处于创建状态。 - 就绪状态
当调用了线程对象的start方法之后,该线程就进入就进入了就绪状态,但是此时线程调度程序还没有把该线程设置为当前线程,此时处于就绪状态,在线程运行之后,从等待或者睡眠中回来之后,也会处于就绪状态。 - 运行状态
线程调度程序处于就绪状态的线程设置为当前线程,此时线程就进入了运行状态,开始运行run函数当中的代码。 - 阻塞状态
线程正在运行的时候,被暂停,通常是为了等待某个时间的发生之后再继续运行,sleep、susped、wait等方法都可以导致线程阻塞。 - 死亡状态
如果一个想成的run方法执行结束或者调用stop方法后,该线程就会死亡。对于已经死亡的线程,无法在使用start方法令其进入就绪