我是靠谱客的博主 甜甜荷花,最近开发中收集的这篇文章主要介绍android图片压缩之图片和内存基础,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1.堆(HEAP)是VM中占用内存最多的部分,通常是动态分配的。堆的大小不是一成不变的,通常有一个分配机制来控制它的大小。比如初始的HEAP是4M大,当4M的空间被占用超过75%的时候,重新分配堆为8M大;当8M被占用超过75%,分配堆为16M大。倒过来,当16M的堆利用不足30%的时候,缩减它的大小为8M大。重新设置堆的大小,尤其是压缩,一般会涉及到内存的拷贝,所以变更堆的大小对效率有不良影响

2.安卓系统对每个程序的堆内存上限限定为Max Heap Size,是堆内存的上限值,老版本Android的缺省值是16M,后来逐渐增大,但是都会有一个限制(要确定这个限制,可以new一个byte数组,看多大时会oom),app申请的堆内存大于堆内存,就会造成内存溢出(oom)

3.堆内存的大小一般是不能更改的,VMRuntime.getRuntime().setMinimumHeapSize(NewSize);这个方法其实只是改变了堆的下限值,它可以防止过于频繁的堆内存分配(根据第1点,如果开始就设置堆为8m,当内存为7m的时候,是不会重新分配内存大小的,如果是默认的4m,就会重新分配一次,可能引发内存拷贝,影响效率),当设置最小堆内存大小超过上限值时仍然采用堆的上限值,对于内存不足没什么作用。

4.默认情况下,bitmap每个像素点占用4个字节(ARGB_8888),一张3543×3503的图片差不多在内存中占用44M(3543×3503*4byte,加载这个bitmap时,还要申请其他空间,所以实际要申请的堆内存还远远大于这个值)的空间(存放在磁盘也是压缩后的,比如jpg图片,就是jpg算法压缩后存放到磁盘的),这样用bitmap加载大图片的时候,就会引发oom

5.ARGB_4444:每个像素占四位,即A=4,R=4,G=4,B=4,那么一个像素点占4+4+4+4=16位 

6.Runtime.getRuntime().maxMemory() 可以获取app堆内存的最大大小

最后

以上就是甜甜荷花为你收集整理的android图片压缩之图片和内存基础的全部内容,希望文章能够帮你解决android图片压缩之图片和内存基础所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部