jdbc.postgresql源码分析

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

clipboard.png
clipboard.png

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

clipboard.png

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值