三分钟让你学会如何使用 apache-common-pool2 创建自己的资源池

需要 commons-pool2-2.3.jar 包,大家可以去官网下载

1:定义资源对象,即保存在资源池中的资源

public class User {
    //姓名
    private String name;
    //年龄
    private int age;
    //身高
    private String height;

    public User(String name, int age, String height) {
        super();
        this.name = name;
        this.age = age;
        this.height = height;
    }

    @Override
    public String toString() {
        StringBuilder str = new StringBuilder(super.toString());
        str.append(" ");
        str.append("name:" + name);
        str.append(",age:" + age);
        str.append(",height:" + height);
        return str.toString();
    }

}

2:创建一个poolfactory 实现接口 org.apache.commons.pool2.PooledObjectFactory

import org.apache.commons.pool2.PooledObject;
import org.apache.commons.pool2.PooledObjectFactory;
import org.apache.commons.pool2.impl.DefaultPooledObject;

public class LpPoolFactory implements PooledObjectFactory {

/**
 * 功能描述:激活资源对象
 * 
 * 什么时候会调用此方法
 * 1:从资源池中获取资源的时候
 * 2:资源回收线程,回收资源的时候,根据配置的 testWhileIdle 参数,判断 是否执行 factory.activateObject()方法,true 执行,false 不执行
 * @param arg0 
 */
@Override
public void activateObject(PooledObject<User> arg0) throws Exception {
    System.out.println("activate Object");
}

@Override
public void destroyObject(PooledObject<User> arg0) throws Exception {
    System.out.println("destroy Object");
    User user = arg0.getObject();
    user = null;
}

@Override
public PooledObject<User> makeObject() throws Exception {
    System.out.println("make Object");
    User user = new User(Thread.currentThread().getName(), 26, "178cm");
    return new DefaultPooledObject<User>(user);
}

/**
 * 功能描述:钝化资源对象
 * 
 * 什么时候会调用此方法
 * 1:将资源返还给资源池时,调用此方法。
 */
@Override
public void passivateObject(PooledObject<User> arg0) throws Exception {
    System.out.println("passivate Object");
}

/**
 * 功能描述:判断资源对象是否有效,有效返回 true,无效返回 false
 * 
 * 什么时候会调用此方法
 * 1:从资源池中获取资源的时候,参数 testOnBorrow 或者 testOnCreate 中有一个 配置 为 true 时,则调用  factory.validateObject() 方法
 * 2:将资源返还给资源池的时候,参数 testOnReturn,配置为 true 时,调用此方法
 * 3:资源回收线程,回收资源的时候,参数 testWhileIdle,配置为 true 时,调用此方法
 */
@Override
public boolean validateObject(PooledObject<User> arg0) {
    System.out.println("validate Object");
    return true;
}

}

3:对一个资源池来说,应该有一些参数配置,apache-common-pool2的参数配置都在 org.apache.commons.pool2.impl.GenericObjectPoolConfig 中

点击查看

4:创建池,并从池中获取资源对象,使用完后,将资源对象返还给资源池

使用池的第一种方式
//使用默认的 config配置
LpPoolFactory factory = new LpPoolFactory();
GenericObjectPool<User> objectPool = new GenericObjectPool<User>(factory);

使用池的第二种方式
//使用 自己的  config配置
LpPoolFactory factory = new LpPoolFactory();
GenericObjectPoolConfig poolConfig = new GenericObjectPoolConfig();
poolConfig.setMinIdle(2);
GenericObjectPool<User> objectPool = new GenericObjectPool<User>(factory,poolConfig);

测试代码 以及 测试结果

public static void main(String[] args) throws Exception{
    //工厂
    LpPoolFactory factory = new LpPoolFactory();
    //资源池配置
    GenericObjectPoolConfig poolConfig = new GenericObjectPoolConfig();
    poolConfig.setMinIdle(2);
    //创建资源池
    GenericObjectPool<User> objectPool = new GenericObjectPool<User>(factory,poolConfig);   

    for(int i=0; i<3; i++) {
        Thread.sleep(1000);
        //获取资源对象
        User user = objectPool.borrowObject();
        //将获取的资源对象,返还给资源池
        objectPool.returnObject(user);
        //输出资源对象
        System.out.println(user);
        System.out.println();
    }

}

测试结果
make Object
activate Object
passivate Object
com.lp.User@63f7d32f name:main,age:26,height:178cm

activate Object
passivate Object
com.lp.User@63f7d32f name:main,age:26,height:178cm

activate Object
passivate Object
com.lp.User@63f7d32f name:main,age:26,height:178cm

通过测试结果,可以看出 每次获取的都是一个对象。

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
好的,@Mapper注解是Mybatis框架中用于标识数据访问层接口的注解,用于告诉Spring容器将该接口类实例化并注入到其他Bean中。其使用步骤如下: 1. 在Spring Boot项目中引入Mybatis和Mybatis-Spring的依赖 2. 在配置文件中配置数据源和Mybatis的相关属性 3. 创建一个数据访问层接口,使用@Mapper注解标识该接口 4. 在该数据访问层接口中定义需要操作的数据库方法 5. 在Service或Controller中注入该数据访问层接口的实例,并调用其中的方法 下面是一个示例: 1. 在pom.xml中添加Mybatis和Mybatis-Spring的依赖: ```xml <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.6</version> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.1</version> </dependency> ``` 2. 在application.properties中配置数据源和Mybatis的相关属性: ```properties spring.datasource.url=jdbc:mysql://localhost:3306/test spring.datasource.username=root spring.datasource.password=123456 mybatis.type-aliases-package=com.example.demo.entity mybatis.mapper-locations=classpath:mapper/*.xml ``` 3. 创建一个数据访问层接口UserMapper,使用@Mapper注解标识该接口: ```java @Mapper public interface UserMapper { User selectByPrimaryKey(Integer id); int insert(User record); int updateByPrimaryKey(User record); int deleteByPrimaryKey(Integer id); } ``` 4. 在mapper目录下创建UserMapper.xml,定义需要操作的数据库方法: ```xml <mapper namespace="com.example.demo.mapper.UserMapper"> <resultMap id="BaseResultMap" type="com.example.demo.entity.User"> <id column="id" property="id" jdbcType="INTEGER"/> <result column="username" property="username" jdbcType="VARCHAR"/> <result column="password" property="password" jdbcType="VARCHAR"/> </resultMap> <select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer"> select * from user where id = #{id,jdbcType=INTEGER} </select> <insert id="insert" parameterType="com.example.demo.entity.User" useGeneratedKeys="true" keyProperty="id"> insert into user (username, password) values (#{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR}) </insert> <update id="updateByPrimaryKey" parameterType="com.example.demo.entity.User"> update user set username = #{username,jdbcType=VARCHAR}, password = #{password,jdbcType=VARCHAR} where id = #{id,jdbcType=INTEGER} </update> <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer"> delete from user where id = #{id,jdbcType=INTEGER} </delete> </mapper> ``` 5. 在Service或Controller中注入UserMapper的实例,并调用其中的方法: ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public User selectByPrimaryKey(Integer id) { return userMapper.selectByPrimaryKey(id); } @Override public int insert(User user) { return userMapper.insert(user); } @Override public int updateByPrimaryKey(User user) { return userMapper.updateByPrimaryKey(user); } @Override public int deleteByPrimaryKey(Integer id) { return userMapper.deleteByPrimaryKey(id); } } ``` 这就是使用@Mapper注解的基本步骤,希望对你有所帮助。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值