内存泄漏和内存溢出简述

1.内存泄漏(memory leak )

内存泄漏是指程序在申请内存后,无法释放已申请的内存空间,一次内存泄漏似乎不会有大的影响,但内存泄漏堆积后的后果就是内存溢出,就会影响代码的正常执行(没有足够的内存供程序使用)

2.什么情况发生?

代码示例:

虽说javascript是自动实现垃圾回收机制的,但是如果我们的代码写法不当,会让变量一直处于被引用的状态,无法被垃圾回收机制回收,下面列出几种内存泄露的情况:

  • 全局变量引起的内存泄漏

function leaks(){  
    leak = 'xxxxxx';   //leak 成为一个全局变量,一直处于被引用的状态,不会被回收
}
  • 闭包引起的内存泄漏

var leaks = (function(){  
    var leak = 'xxxxxx';     // 被闭包所引用,不会被回收
    return function(){
        console.log(leak);
    }
})()
  • dom清空或删除时,事件未清除导致的内存泄漏

<div id="container">  </div>
$('#container').bind('click', function(){
    console.log('click');
}).remove();
// zepto 和原生 js下,#container dom 元素,还在内存里jquery的empty和remove会帮助开发者避免这个问题

//正确的方法是在清空dom元素时,要先将其身上绑定的事件清除掉,如下所示
<div id="container">  </div>
$('#container').bind('click', function(){
    console.log('click');
}).off('click').remove();
//把事件清除了,即可从内存中移除

3.怎样避免?

  尽量不要写上边的类似代码

4.内存泄漏和内存溢出的区别和介绍

  • 内存泄漏的堆积最终会导致内存溢出

  • 内存溢出就是你要的内存空间超过了系统实际分配给你的空间,此时系统相当于没法满足你的需求,就会报内存溢出的错误。

  • 内存泄漏是指你向系统申请分配内存进行使用(new),可是使用完了以后却不归还(delete),结果你申请到的那块内存你自己也不能再访问(也许你把它的地址给弄丢了),而系统也不能再次将它分配给需要的程序。就相当于你租了个带钥匙的柜子,你存完东西之后把柜子锁上之后,把钥匙丢了或者没有将钥匙还回去,那么结果就是这个柜子将无法供给任何人使用,也无法被垃圾回收器回收,因为找不到他的任何信息。

  • 内存溢出:一个盘子用尽各种方法只能装4个果子,你装了5个,结果掉倒地上不能吃了。这就是溢出。比方说栈,栈满时再做进栈必定产生空间溢出,叫上溢,栈空时再做退栈也产生空间溢出,称为下溢。就是分配的内存不足以放下数据项序列,称为内存溢出。说白了就是我承受不了那么多,那我就报错

5.内存溢出代码示例

    function test(){
        setTimeout(test,1);
    }
    test();

 

 

 

通用型哈希表,最早发出的哥们儿已经不知去向(感谢他),目前的更新和优化好像都是酷宝贝在做,不过我经常要导入模块,所以一直想用一个不需要类直接复制粘贴程序集就能用的版本,经过一段时间打磨,总算自己写了一个,调试过程还是有不少曲折的,但是考虑到 易语言 都过了二十年了,知名度依旧不高,所以没什么好吝啬的,分享出来,人海茫茫,你能碰到的都是兄弟,不是竞争对手。 碰巧写TCP组包,考虑用哈希表存储数据,这也引出了 将原先的哈希读写拆分出 取指针 和 指针操作  的需求。 这个程序集的特点: ' 分层次展现 ' 中文函数(公开)为哈希表主要函数 ' 中文函数(未公开)为哈希表扩展功能函数 ' 英文函数为独立的工具函数 ' 带_的英文函数是哈希表的附属函数 ' 1.对于取 哈希值的算法 进行了扩展,变成4种 ' 2.增加了 CRC32_PTR 汇编算法,使用查表方式计算,速度与按字节计算的传统哈希相近,比RtlComputeCrc32快且兼容性强,比传统的哈希算法碰撞率低 ' 3.增加了 hash_PTR 汇编算法,按字节计算哈希结果和之前一样,按字和按3字计算可用于文本key(但要注意对齐,比如Unicode是字对齐) ' 4.增加了 哈希_更改  子程序,这是 将key作为handle使用,用于快速管理资源 的一种理解方式 ' 5.在哈希取值之前分离出 哈希_取指针 ,返回数据的内存地址,同时让哈希_取值命令更加简单易读 ' 6.增加了 取素数不小于 的函数,用于创建和扩展链表,最早的创建方式不科学,遇到有规律的数会产生严重碰撞 ' 7.修复了内存泄露的bug,具体位置在 哈希_添加 中找到相同key数据之后,补充了heapfree命令 ' 8.更改取值方式,这个我看到酷宝贝也改了,取值直接返回指针,而不是再度申请内存(该操作同样会泄露) 阐述一下CRC32_PTR,综合考量了 速度、资源占用 ,将表作为数据置入,用CALL/POP取出,比API快,已对比过各易论坛、资源网、目前是最快最稳定的,欢迎高手拍砖!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值