变量泄露问题

经典的案例

let arr = []
for(var i =0;i<=5;i++){
  arr[i]= function fn(){
       console.log(i)
   }
} 
arr[0]() //6

解析:我们的想法是arr[0]的函数应该是打印0的,而且每个元素的函数都能打印出自己的索引才对,可结果出乎意料。实际上为啥是6,我们先逐步分析。


1.js没有块级作用域

for(var i =0;i<=5;i++){
     b=3
     console.log(i)
  } 
  {var a =1}
console.log('结果:',a,b)  //结果: 1 3

也就是说,在大括号中声明的变量在大括号外部能拿到。这些变量是全局变量。


2.函数操作的变量值是函数调用时的而非函数声明时的

var a = 1
var fn = function(){
    console.log('a:',a)
}
a=2
fn() //a:2

函数声明时变量a的值是1,声明后a的值变成了2,此时再调用fn函数,取得的a是2.


3.for循环的变量泄漏

let arr =
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的ThreadLocal变量是一种线程本地变量,它提供了一种在多线程环境下保持变量的独立副本的机制。每个线程都可以独立地修改自己的副本,而不会影响其他线程的副本。这种机制可以避免线程安全问题,并且在某些情况下可以提高性能。 然而,如果在使用ThreadLocal变量时不小心处理,可能会导致内存泄漏。内存泄漏是指在程序中不再使用的对象仍然占用内存空间,无法被垃圾回收器回收,从而导致内存的浪费。 为了避免ThreadLocal变量的内存泄漏,我们需要注意以下几点: 1. 及时清理:在使用完ThreadLocal变量后,应该及时调用remove()方法将其从当前线程中移除。这样可以避免变量的副本一直存在于线程中,占用内存。 2. 使用try-finally块:为了确保在任何情况下都能正确地清理ThreadLocal变量,可以使用try-finally块来确保在使用完后进行清理操作。 下面是一个示例代码,演示了如何正确使用ThreadLocal变量并避免内存泄漏: ```java public class ThreadLocalExample { private static ThreadLocal<String> threadLocal = new ThreadLocal<>(); public static void main(String[] args) { try { threadLocal.set("Hello, ThreadLocal!"); // 使用ThreadLocal变量 System.out.println(threadLocal.get()); } finally { // 清理ThreadLocal变量 threadLocal.remove(); } } } ``` 在上面的示例中,我们使用了try-finally块来确保在使用完ThreadLocal变量后进行清理操作。在finally块中调用remove()方法将变量从当前线程中移除,以避免内存泄漏。 总结一下,为了避免ThreadLocal变量的内存泄漏,我们需要在使用完后及时清理,并且可以使用try-finally块来确保清理操作的执行。这样可以保证ThreadLocal变量的副本不会一直存在于线程中,从而避免内存泄漏的问题

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值