- http://blog.youkuaiyun.com/tiantangrenjian/article/details/39182293
- http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0920/3478.html
- http://blog.youkuaiyun.com/kifile/article/details/40751665
- http://android.jobbole.com/82248/
- http://blog.youkuaiyun.com/tiantangrenjian/article/details/39182293
- http://blog.youkuaiyun.com/a396901990/article/details/38904543
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------!
内存占用检测工具:
http://blog.youkuaiyun.com/xu_fu/article/details/45678373
AS自带Monitor工具使用:
http://blog.youkuaiyun.com/yutao52shi/article/details/50055669
独立 MAT工具使用:
http://www.jianshu.com/p/216b03c22bb8
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------!
原图大小285kb,宽高1354x848
直接加载到内存中,内存暴涨54M
设置ImageView宽高为100px x 100px ,内存没有任何变化,还是54M
使用下面的方法先缩放,再加载。缩放为100,100,结果内存只涨了3M!!! 千差万别啊。。。。。
public Drawable resizeImage(int width, int height) {
//获取图片宽高
BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true; //不加载bitmap到内存中
BitmapFactory.decodeResource(getResources(), R.drawable.aa, options);
int oldWidth = options.outWidth;//原图 宽度
int oldHeight = options.outHeight;//原图 高度
//得到新的缩放比例
int sampleSizeNew = 1;
if (oldWidth != 0 && oldHeight != 0 && width != 0 && height != 0) {
sampleSizeNew = (oldWidth / width + oldHeight / height) / 2;
}
//创建新的option
BitmapFactory.Options optionsNew = new BitmapFactory.Options();
optionsNew.inJustDecodeBounds = false;//加载bitmap到内存中
optionsNew.inSampleSize = sampleSizeNew;//新的缩放比例
//按照新的option加载图片
return new BitmapDrawable(BitmapFactory.decodeResource(getResources(), R.drawable.aa, optionsNew));
}------------------------------------------------------------------------------------------------------------------------------------------------------------------------------!
ctx就是整个Activity的引用。
有两个Activity,A和B。
A跳转到B,B把自己的ctx放到了另外一个类的静态变量,然后返回到A。
那么这个时候,B所有的资源,都不会被释放!因为另外一个类的静态变量,一直对它有一个引用。
我们单例的时候,传入的ctx就是这样的!!!
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------!
java一直会做内存回收的,在内存紧张的时候。
但是,但是!如果对象被引用,有引用关系在,无法回收。那么最后到达 阀值,就OOM了。
这个才是OOM的原因!!!!!!! 有东西无法被回收!!!回收不了!被引用着呢。
4245

被折叠的 条评论
为什么被折叠?



