iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >利用Apache Common将java对象池化的问题
  • 686
分享到

利用Apache Common将java对象池化的问题

2024-04-02 19:04:59 686人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

什么是对象池化? 对象被创建后,使用完毕不是立即销毁回收对象,而是将对象放到一个容器保存起来,下次使用的时候不用创建对象,而是从容器中直接获取。 什么样的对象需要池化? 一般需要池化

什么是对象池化?

对象被创建后,使用完毕不是立即销毁回收对象,而是将对象放到一个容器保存起来,下次使用的时候不用创建对象,而是从容器中直接获取。

什么样的对象需要池化?

一般需要池化的对象往往都是比"重量级"较的对象,创建和销毁都比较耗时,比如我们的"线程","数据库链接对象","tcp链接对象", "FTP链接对象" 等等。

对象池化的好处?

这些对象池化后,之后使用的时候不用创建,直接使用即可,可以大大缩短程序的运行时间,以及创建对象时对CPU资源的消耗,以及对系统资源的控制(池化的对象数量有限,不会一直创建对象,导致系统资源耗尽,或者造成程序OOM的情况)进而提高系统的稳定性。

对象池化后需要注意什么?

这些被池化的对象都有一个特点,都是"活的",比如数据库链接对象内部一般保存了一个TCP链接,所以,这个对象"能用"的前提是这个TCP链接是有效的,线程对象"能用"的前提是线程的状态不是"凋亡"状态,所以我们有必要定期对对象的"健康状态"进行检查,剔除掉"不能用"的对象,并填充新的对象给"对象池"。

使用apache-common-pool池化对象

  • 引入依赖
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
            <version>2.9.0</version>
        </dependency>
  • 需要池化的对象示例
public class Foo {
    private final String username;
    public Foo(String username) {
        this.username = username;
    }
    public String getUsername() {
        return username;
    }
}
  • 构建对象创建工厂

可以直接实现org.apache.commons.pool2.PooledObjectFactory<T>接口实现创建、销毁、钝化、取消等接口,也可以使用他的抽象类,实现创建和包装方法即可。

public class FooPoolObjectFactory extends BasePooledObjectFactory<Foo> {
    @Override
    public Foo create() throws Exception {
        return new Foo(String.valueOf(RandomUtils.randomInt(0, 10)));
    }
    @Override
    public PooledObject<Foo> wrap(Foo obj) {
        return new DefaultPooledObject<>(obj);
    }
}
  • 实现驱逐策略

一般数据库链接对象,要定期进行心跳,确保链接可用,如果链接断开,需要销毁对象,并重新创建新的对象。common-pool中,我们可以实现驱逐策略,对对象进行定期检查

public class FooEvictionPolicy implements EvictionPolicy<Foo> {
    @Override
    public boolean evict(EvictionConfig config, PooledObject<Foo> underTest, int idleCount) {
        // todo  定期检查对象某些功能是否可用
        return true;
    }
}
  • 构建&配置对象池
    public GenericObjectPool<Foo> fooGenericObjectPool() {
        GenericObjectPoolConfig<Foo> poolConfig = new GenericObjectPoolConfig<>();
        poolConfig.setEvictionPolicy(new FooEvictionPolicy());
        poolConfig.setBlockWhenExhausted(true);
        poolConfig.setJmxEnabled(false);
        poolConfig.setMaxWaitMillis(1000 * 10);
        poolConfig.setTimeBetweenEvictionRunsMillis(60 * 1000);
        poolConfig.setMinEvictableIdleTimeMillis(20 * 1000);
        poolConfig.setTestWhileIdle(true);
        poolConfig.setTestOnReturn(true);
        poolConfig.setTestOnBorrow(true);
        poolConfig.setMaxTotal(3);
        // 设置抛弃策略
        AbandonedConfig abandonedConfig = new AbandonedConfig();
        abandonedConfig.setRemoveAbandonedOnMaintenance(true);
        abandonedConfig.setRemoveAbandonedOnBorrow(true);
        return new GenericObjectPool<>(new FooPoolObjectFactory(), poolConfig, abandonedConfig);
    }

如果我们使用的是spring容器,一般我们需要将该对象交由spring管理。

  • 获取&归还对象
    private final GenericObjectPool<Foo> fooGenericObjectPool = fooGenericObjectPool();
    public Foo borrowFoo () throws Exception {
        return fooGenericObjectPool.borrowObject();
    }
    public void returnObject(Foo foo){
        fooGenericObjectPool.returnObject(foo);
    }

到此这篇关于利用Apache Common将java对象“池化”的文章就介绍到这了,更多相关Apache Common java对象池化内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 利用Apache Common将java对象池化的问题

本文链接: https://www.lsjlt.com/news/151362.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 利用Apache Common将java对象池化的问题
    什么是对象池化? 对象被创建后,使用完毕不是立即销毁回收对象,而是将对象放到一个容器保存起来,下次使用的时候不用创建对象,而是从容器中直接获取。 什么样的对象需要池化 一般需要池化的...
    99+
    2024-04-02
  • Java Apache common-pool对象池介绍
    目录对象生命周期Config详解代码说明ObjectPoolPooledObjectFactoryPooledObject方案提供了三种类型的pool前言; Apache commo...
    99+
    2024-04-02
  • Java BasePooledObjectFactory 对象池化技术的使用
    Java GenericObjectPool 对象池化技术--SpringBoot sftp 连接池工具类 一个对象池包含一组已经初始化过且可以使用的对象,而可以在有需求时创建和销毁...
    99+
    2023-05-14
    Java 对象池 Java 对象池BasePooledObjectFactory
  • Java BasePooledObjectFactory对象池化技术如何使用
    本篇内容主要讲解“Java BasePooledObjectFactory对象池化技术如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java BasePooledOb...
    99+
    2023-07-05
  • Java GenericObjectPool对象池化技术怎么使用
    这篇文章主要介绍了Java GenericObjectPool对象池化技术怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java GenericObjectPool对象池化技术怎么使...
    99+
    2023-07-05
  • Java 中怎么利用SynDemo对象解决继承问题
    Java 中怎么利用SynDemo对象解决继承问题,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java SynDemo对象刚一出现的时候有很多程序员都很头痛,...
    99+
    2023-06-17
  • NPM和Apache:如何优化Java对象的性能?
    在现代软件开发中,Java已经成为了一个广泛使用的编程语言。然而,在Java应用程序中,对象的创建和销毁是一个非常耗费资源的过程。为了优化Java对象的性能,我们可以使用NPM和Apache这两个工具。 NPM是一个Node.js包管理器...
    99+
    2023-08-18
    对象 npm apache
  • Java中的对象池怎么使用
    本文小编为大家详细介绍“Java中的对象池怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java中的对象池怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1. 什么是对象池对象池,顾名思义就是一定...
    99+
    2023-07-05
  • 详谈fastjson将对象格式化成json时的两个问题
     1、 关于继承类的继承结构为class Base{ private int id; public Long getId() { return id; } public void setId(Long id) { this....
    99+
    2023-05-31
    fastjson json 对象
  • Python 同步对象:解决 Apache 并发访问的利器?
    在现代计算机应用程序中,多任务并发处理已经成为一种必要的技术。Python 作为一种高级编程语言,提供了多种方式来实现并发编程,其中同步对象就是其中一种重要的实现方式。在本文中,我们将深入探讨 Python 同步对象的概念、类型及其在解决...
    99+
    2023-10-29
    同步 对象 apache
  • C#未将对象引用设置到对象问题怎么解决
    在C#中,当你使用一个尚未被实例化的对象时,就会出现"未将对象引用设置到对象的实例"错误。要解决这个问题,你需要确保在使用对象之前对...
    99+
    2023-08-09
    C#
  • Java即将引入新对象类型来解决内存使用问题
    目录一、Valhalla二、Java类型系统的不足三、对象头四、Value Class前言: 2022年Java将有什么新的特性和改进,我相信很多Java开发者都想知道。结合Java...
    99+
    2024-04-02
  • 怎么在java中利用反射实例化对象
    怎么在java中利用反射实例化对象?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布式系...
    99+
    2023-06-14
  • 高效的Python通用对象池化库怎么使用
    本篇内容主要讲解“高效的Python通用对象池化库怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“高效的Python通用对象池化库怎么使用”吧!对象池模式主要适用于以下应用场景:资源受限的...
    99+
    2023-07-06
  • 详解Java中对象池的介绍与使用
    目录1. 什么是对象池2. 对象池解决什么问题3. 对象池的优缺点3.1 对象池的优点3.2 对象池弊端4. 对象池有什么特征5. 池的大小选择6. 对象池的使用6.1 接入6.2 ...
    99+
    2023-02-21
    Java对象池使用 Java对象池
  • 用来将对象持久化的pythonpickle模块
    目录前言一、pickle 模块下的方法1. dumps()2. loads()3. dump()4. load()二、可以被 pickle 封存/解封的对象三、pickle 与 js...
    99+
    2024-04-02
  • 关于Java中的dozer对象转换问题
    目录Java中的dozer对象转换1、dozer介绍2、依赖坐标3、创建测试工厂【dozer_demo】3.1、引入对应的依赖3.2、创建UserDTO和UserEntity3.3、...
    99+
    2024-04-02
  • 如何使用spring boot开发时java对象和Json对象转换的问题
    小编给大家分享一下如何使用spring boot开发时java对象和Json对象转换的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!将java对象转换为jso...
    99+
    2023-06-06
  • JS中的Error对象及使用JSON.stringify()序列化Error问题
    目录一. 错误对象的类型错误处理二.使用JSON.stringfy()去序列化一个 ErrorMDN 定义对象属性的 enumerableJSON.stringify() 的第二个参...
    99+
    2024-04-02
  • 如何在Java项目中利用序列化与反序列化将对象文件写入与导出
    如何在Java项目中利用序列化与反序列化将对象文件写入与导出?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java类中对象的序列化工作是通过ObjectOutp...
    99+
    2023-05-31
    java 序列化 反序列化
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作