zoukankan      html  css  js  c++  java
  • java get all threadlocal from thread

    public void mytest() {
    long start = System.currentTimeMillis();
    Thread thread = Thread.currentThread();

    Field threadLocalsField = null;
    try {
    threadLocalsField = Thread.class.getDeclaredField("threadLocals");

    threadLocalsField.setAccessible(true);

    Class threadLocalMapKlazz = Class.forName("java.lang.ThreadLocal$ThreadLocalMap");
    Field tableField = threadLocalMapKlazz.getDeclaredField("table");
    tableField.setAccessible(true);

    Object table = tableField.get(threadLocalsField.get(thread));

    int threadLocalCount = Array.getLength(table);
    StringBuilder sb = new StringBuilder();
    StringBuilder classSb = new StringBuilder();


    int leakCount = 0;

    for (int i = 0; i < threadLocalCount; i++) {
    Object entry = Array.get(table, i);
    if (entry != null) {
    Field valueField = entry.getClass().getDeclaredField("value");
    valueField.setAccessible(true);
    Object value = valueField.get(entry);
    if (value != null) {
    classSb.append(value.getClass().getName()).append(", ");

    } else {
    classSb.append("null, ");
    }
    leakCount++;
    }
    }

    sb.append("possible ThreadLocal leaks: ")
    .append(leakCount)
    .append(" of ")
    .append(threadLocalCount)
    .append(" = [")
    .append(classSb.substring(0, classSb.length() - 2))
    .append("] ");

    log.warn(sb.toString());
    } catch (Exception e) {
    e.printStackTrace();
    }
    long end = System.currentTimeMillis();
    long cost = end - start;
    log.info("获取ThreadLocal耗时:{}", cost);



    结果: possible ThreadLocal leaks: 9 of 16 = [java.util.Collections$SynchronizedMap, null,
    java.lang.Boolean, java.lang.Boolean, null, java.lang.Integer, java.lang.Boolean, brave.propagation.TraceContext, null] 
  • 相关阅读:
    selenium---元素定位(find_element)
    selenium---八种定位元素方法
    selenium---环境配置
    vue el-table 自适应表格内容宽度
    另类的开发环境搭建
    基于Django+celery二次开发动态配置定时任务 ( 二)
    基于datax的数据同步平台
    mysql常用日期、时间查询
    MySQL数据库管理
    mysql5.7.20多实例编译安装
  • 原文地址:https://www.cnblogs.com/zhangzhi19861216/p/12152973.html
Copyright © 2011-2022 走看看