jdbc.postgresql源码分析

还没接触源码的时候,对jdbc的执行过程一头雾水,不知道他是如何执行crud操做的。可是,我在使用的时候发现Class.forNmae(Driver).这个代码。这时候我猜测它是使用反射机制。查看源码果真是这样。Driver类经过静态代码块在Driver类被加载进内存的时候执行register()方法,将驱动进行注册。它在注册以前先检查是否已经注册,存在的话抛出异常。反之,使用DriverManager类将驱动注册。java

clipboard.png
clipboard.png

PgConnection使用经过DriverManger.getConnection()方法得到,这其实时调用PGConnection的构造方法进行初始化,而后调用Driver类的connect()方法返回实例。sql

clipboard.png

同理,PgStatement也是在createPgStatemnt方法中对PgStatement实例进行初始化。具体图片不在展现,它们都调用System.getDefaultProperties()方法获取链接参数,设置具体的执行过程。数据库

jdbc中采用javaSPI机制,也就是它们给予java.sql包中的接口执行具体实现,所谓spi机制个人理解就是声明一系列接口,或者说制定好标准,而后由具体类去实现。我猜jdbc的其它数据库驱动应该也是这种模式。在resource的meta-info下有个service文件夹,里面创建接口的文件,名字是包名到接口名称。文件内容是实现类的包名到类名。而后,经过serviceloader类进行加载,加载后的类进行打印获得每个实现类。学习

源码具体分析,在接下来的学习中将持续更新。spa

相关文章
相关标签/搜索