jackson如何关闭USE_THREAD_LOCAL_FOR_BUFFER_RECYCLING

为什么要关闭?

如果不关闭,框架会将数据放到Tomcat的线程里的threadLocal里。由于Tomcat的线程正常情况不会回收,所以这个占用会一直存在

如何关闭?

如果是自己定义的ObjectMapper,其实关闭还是比较容易的

private static ObjectMapper objMapper = new ObjectMapper();

    static {
        //虽然提示过期了,但是还是生效的
        objMapper.getFactory().disable(JsonFactory.Feature.USE_THREAD_LOCAL_FOR_BUFFER_RECYCLING);
    }

最最关键的上面的代码只是关闭了我们自己定义的ObjectMapper。别忘了,springboot本身的序列化也是由jackson完成的,如果你也想关掉这个参数,这个就需要下面这样操作。

@Configuration
public class CustomerJackson {
 
    @Bean
    @Primary
    @ConditionalOnMissingBean(ObjectMapper.class)
    public ObjectMapper objectMapper(Jackson2ObjectMapperBuilder builder) {
        ObjectMapper objMapper = builder.createXmlMapper(false).build();
        objMapper.getFactory().disable(JsonFactory.Feature.USE_THREAD_LOCAL_FOR_BUFFER_RECYCLING);

        return objMapper;

    }
}

如何验证是否关闭成功

通过debug的方式进行验证。

这2个地方都会用到springboot内置的序列化,也就是Jackson。将断点打在如下图所示位置

方法是com.fasterxml.jackson.core.JsonFactory#_getBufferRecycler

看看1709行的条件是真是假,如果不进入1710行就表示关闭成功了,如果进入了就表示关闭没有成功

然后再将dump文件分析一下,你会发现threadLocal内已经没有数据了。

小结

其实一开始我关掉了ObjectMapper后分析dump文件,发现SoftReference<BufferRecycler>还是存在。然后就怀疑是不是disable这个命令没起作用。现在看,其实是起作用了,之所以还会在dump文件看到是springboot内置的ObjectMapper放的。所以只有把所有的ObjectMapper里的这个参数关掉在threadLocal中就看不见SoftReference<BufferRecycler>了

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是CPLEX代码实现: ```python # 创建模型 model = cpx.Model() # 创建变量 recycling_centers = model.binary_var(name="recycling_centers") dismantling_centers = model.binary_var(name="dismantling_centers") processing_centers = model.binary_var(name="processing_centers") # 创建约束条件 model.add_constraint(recycling_centers + dismantling_centers + processing_centers >= 1, ctname="at_least_one_center") model.add_constraint(recycling_centers >= 1, ctname="at_least_one_recycling_center") model.add_constraint(dismantling_centers >= 1, ctname="at_least_one_dismantling_center") model.add_constraint(processing_centers >= 1, ctname="at_least_one_processing_center") # 回收中心能力约束 for city in cities: model.add_constraint(cpx.sum(recycling_centers[i] * products[i][city] for i in range(num_products)) >= city_production[city], ctname="recycling_capacity_city_{}".format(city)) # 拆解中心能力约束 for product in products: model.add_constraint(cpx.sum(dismantling_centers[i] * product[i] for i in range(num_cities)) >= product_production[product], ctname="dismantling_capacity_product_{}".format(product)) # 再处理中心能力约束 for resource in resources: model.add_constraint(cpx.sum(processing_centers[i] * resource[i] for i in range(num_resources)) >= resource_production[resource], ctname="processing_capacity_resource_{}".format(resource)) # 每个城市产生的废旧产品必须运送到回收中心 for city in cities: model.add_constraint(cpx.sum(recycling_centers[i] * products[i][city] for i in range(num_products)) == city_production[city], ctname="send_to_recycling_center_city_{}".format(city)) # 最大化目标函数 model.maximize(cpx.sum(recycling_centers) + cpx.sum(dismantling_centers) + cpx.sum(processing_centers)) # 求解模型 model.solve() # 输出结果 print("Objective value: ", model.objective_value) print("Recycling centers: ", [recycling_centers[i].solution_value for i in range(num_centers)]) print("Dismantling centers: ", [dismantling_centers[i].solution_value for i in range(num_centers)]) print("Processing centers: ", [processing_centers[i].solution_value for i in range(num_centers)]) ``` 其中,cities表示城市列表,products表示废旧产品列表,resources表示再生资源列表,city_production表示每个城市产生的废旧产品数量,product_production表示每种废旧产品的产量,resource_production表示每种再生资源的产量。num_products、num_cities、num_resources、num_centers分别表示废旧产品数量、城市数量、再生资源数量和中心数量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值