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

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 本文通过案例向同学们阐明检测数据库更新的两个误区以及连接池实现原理。

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

检测数据库更新


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

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

image.png

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

连接池实现原理


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

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

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

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

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

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

相关文章
|
11天前
|
安全 架构师 Java
Java大厂面试高频:Collection 和 Collections 到底咋回答?
Java中的`Collection`和`Collections`是两个容易混淆的概念。`Collection`是集合框架的根接口,定义了集合的基本操作方法,如添加、删除等;而`Collections`是一个工具类,提供了操作集合的静态方法,如排序、查找、同步化等。简单来说,`Collection`关注数据结构,`Collections`则提供功能增强。通过小王的面试经历,我们可以更好地理解这两者的区别及其在实际开发中的应用。希望这篇文章能帮助你掌握这个经典面试题。
30 4
|
4天前
|
人工智能 监控 数据可视化
提升开发效率:看板方法的全面解析
随着软件开发复杂度提升,并行开发模式下面临资源分配不均、信息传递延迟及缺乏全局视图等瓶颈问题。看板工具通过任务状态实时可视化、流量效率监控和任务依赖管理,帮助团队直观展示和解决这些瓶颈。未来,结合AI预测和自动化优化,看板工具将更高效地支持并行开发,成为驱动协作与创新的核心支柱。
|
11天前
|
监控 Dubbo Java
Java Dubbo 面试题
Java Dubbo相关基础面试题
|
11天前
|
SQL Java 数据库连接
Java MyBatis 面试题
Java MyBatis相关基础面试题
|
11天前
|
存储 监控 算法
Java JVM 面试题
Java JVM(虚拟机)相关基础面试题
|
11天前
|
SQL 监控 druid
Java Druid 面试题
Java Druid 连接池相关基础面试题
|
11天前
|
缓存 安全 算法
Java 多线程 面试题
Java 多线程 相关基础面试题
|
17天前
|
JSON 供应链 搜索推荐
淘宝APP分类API接口:开发、运用与收益全解析
淘宝APP作为国内领先的购物平台,拥有丰富的商品资源和庞大的用户群体。分类API接口是实现商品分类管理、查询及个性化推荐的关键工具。通过开发和使用该接口,商家可以构建分类树、进行商品查询与搜索、提供个性化推荐,从而提高销售额、增加商品曝光、提升用户体验并降低运营成本。此外,它还能帮助拓展业务范围,满足用户的多样化需求,推动电商业务的发展和创新。
44 5
|
1月前
|
Java
Java社招面试题:& 和 && 的区别,HR的套路险些让我翻车!
今日分享的主题是如何区分&和&&的区别,提高自身面试的能力。主要分为以下四部分。 1、自我面试经历 2、&amp和&amp&amp的不同之处 3、&对&&的不同用回答逻辑解释 4、彩蛋
|
1月前
|
存储 关系型数据库 MySQL
double ,FLOAT还是double(m,n)--深入解析MySQL数据库中双精度浮点数的使用
本文探讨了在MySQL中使用`float`和`double`时指定精度和刻度的影响。对于`float`,指定精度会影响存储大小:0-23位使用4字节单精度存储,24-53位使用8字节双精度存储。而对于`double`,指定精度和刻度对存储空间没有影响,但可以限制数值的输入范围,提高数据的规范性和业务意义。从性能角度看,`float`和`double`的区别不大,但在存储空间和数据输入方面,指定精度和刻度有助于优化和约束。
175 5

热门文章

最新文章

推荐镜像

更多