面试疑难点解析——Java数据库开发(六)

简介: 本文通过案例向同学们阐明检测数据库更新的两个误区以及连接池实现原理。

7月9日 19:00-21:30 阿里云开发者社区首场“Offer 5000”直播开启!14位团队技术大牛在线招人,更有《阿里云技术面试红宝书》助你拿下Offer!戳下图或链接马上投递简历:
图片无法显
点击图片或戳我查看详情和投简历

检测数据库更新


本案例的需求在于:数据库有可能会被更改,一旦里面的内容发生了改变,程序可以做出一些反应,但在这种实现里面会有一个误区:触发器。触发器只能在数据库层次上存在,一旦出现了更新问题,直接的影响就是,触发器只能够调用一些过程处理,这样一来如果在分布式的数据库开发环境之中根本就不可取(触发器绝对不可能用)。

另外一个误区:定期进行数据库的检测,例如:1秒查询一次数据库,做一次比对,这就相当于额外追加了数据库的负荷。

image.png

如果你的系统每秒更新十次,劝你别用了,干脆就直接将更新在业务中处理完成。

连接池实现原理


如果想要实现一个连接池,本质的实现思想就是一个Connection的对象数组,这个对象数组并不是无限开辟的,是有上限的,最初的数据库手工连接池的实现可以采用Map集合完成。在进行处理的时候,Map集合里面保存有全部连接池的可用连接(最小维持数、最大可打开数,最大等待时间),实现思路:

- 所有的连接对象被Map集合所管理,但是这个Map集合受到最大连接数的控制,如果现在需要获取数据库连接,发现已经没有可用的连接了,这个时候应该开辟新的连接,同时需要保证连接池是有上限的。

- 在获取连接的时候如果发现连接已经满了,这个时候应该追加一个等待唤醒机制,对于连接池的控制,如果发现没有连接,则等待新的连接到来,就可以采用线程的等待与唤醒机制来完成。

- 连接池中的连接使用完成后一定要关闭,这个关闭并不是彻底关闭数据库的连接,而是说将这个连接的可用性重新放回到连接池中,也就是说为连接池里设置一个标记(标记为true,就表示该连接可用,如果没有true的连接了,就表示连接池满了,当把连接放回去之后将这个标记设置为false,就表示有空余连接了)。

- 如果现在要去考虑连接池的实现,最好的做法就是使用ConcurrentHashMap子类来实现,这个类考虑到了并发性,并且也可以有很好的同步处理效果。

更多专业知识,面试技巧就在面试一点通,持续更新中……
感谢浏览~
本内容来源于阿里云大学-Java面试技巧

相关文章
|
8月前
|
机器学习/深度学习 JSON Java
Java调用Python的5种实用方案:从简单到进阶的全场景解析
在机器学习与大数据融合背景下,Java与Python协同开发成为企业常见需求。本文通过真实案例解析5种主流调用方案,涵盖脚本调用到微服务架构,助力开发者根据业务场景选择最优方案,提升开发效率与系统性能。
1961 0
|
8月前
|
Java
Java的CAS机制深度解析
CAS(Compare-And-Swap)是并发编程中的原子操作,用于实现多线程环境下的无锁数据同步。它通过比较内存值与预期值,决定是否更新值,从而避免锁的使用。CAS广泛应用于Java的原子类和并发包中,如AtomicInteger和ConcurrentHashMap,提升了并发性能。尽管CAS具有高性能、无死锁等优点,但也存在ABA问题、循环开销大及仅支持单变量原子操作等缺点。合理使用CAS,结合实际场景选择同步机制,能有效提升程序性能。
|
8月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
587 100
|
9月前
|
存储 缓存 Java
Java数组全解析:一维、多维与内存模型
本文深入解析Java数组的内存布局与操作技巧,涵盖一维及多维数组的声明、初始化、内存模型,以及数组常见陷阱和性能优化。通过图文结合的方式帮助开发者彻底理解数组本质,并提供Arrays工具类的实用方法与面试高频问题解析,助你掌握数组核心知识,避免常见错误。
|
8月前
|
存储 JSON 数据建模
鸿蒙 HarmonyOS NEXT端云一体化开发-云数据库篇
云数据库采用存储区、对象类型、对象三级结构,支持灵活的数据建模与权限管理,可通过AGC平台或本地项目初始化,实现数据的增删改查及端侧高效调用。
423 1
|
7月前
|
存储 安全 Java
《数据之美》:Java集合框架全景解析
Java集合框架是数据管理的核心工具,涵盖List、Set、Map等体系,提供丰富接口与实现类,支持高效的数据操作与算法处理。
|
8月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
8月前
|
安全 Java API
Java SE 与 Java EE 区别解析及应用场景对比
在Java编程世界中,Java SE(Java Standard Edition)和Java EE(Java Enterprise Edition)是两个重要的平台版本,它们各自有着独特的定位和应用场景。理解它们之间的差异,对于开发者选择合适的技术栈进行项目开发至关重要。
1431 1
|
7月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
9月前
|
存储 缓存 算法
Java数据类型与运算符深度解析
本文深入解析Java中容易混淆的基础知识,包括八大基本数据类型(如int、Integer)、自动装箱与拆箱机制,以及运算符(如&与&&)的使用区别。通过代码示例剖析内存布局、取值范围及常见陷阱,帮助开发者写出更高效、健壮的代码,并附有面试高频问题解析,夯实基础。

推荐镜像

更多
  • DNS