图片过多造成内存溢出,这个是最不容易解决的,要想一些好的缓存策略,比如大图片使用LRU缓存策略或懒加载缓存策略。今天首先介绍一下本地缓存图片,可参考 首先看一下异步加载缓存本地代码 工具类: publi cclass AsyncBitmapLoader { /** *内存图片软引用缓冲 */ private HashMap<String,SoftReference<Bitmap> >imageCache=null; public AsyncBitmapLoader() { imageCache=new HashMap<String,SoftReference<Bitmap>>(); } public Bitmap loadBitmap(finalImageViewimageView,finalStringimageURL,finalImageCallBackimageCallBack) { //在内存缓存中,则返回Bitmap对象 if(imageCache.containsKey(imageURL)) { SoftReference<Bitmap> reference=imageCache.get(imageURL); Bitmap bitmap=reference.get(); if(bitmap!=null) { returnbitmap; } } else { /** *加上一个对本地缓存的查找 */ String bitmapName=imageURL.substring(imageURL.lastIndexOf("/")1); File cacheDir=newFile("/mnt/sdcard/test/"); File[] cacheFiles=cacheDir.listFiles(); inti=0; if(null!=cacheFiles){ for(;i<cacheFiles.length;i) { if(bitmapName.equals(cacheFiles[i].getName())) { break; } } if(i<cacheFiles.length) { return BitmapFactory.decodeFile("/mnt/sdcard/test/"bitmapName); } } } final Handler handler=new Handler() { /*(non-Javadoc) *@seeandroid.os.Handler#handleMessage(android.os.Message) */ @Override publi cvoid handleMessage(Messagemsg) { //TODOAuto-generatedmethodstub imageCallBack.imageLoad(imageView,(Bitmap)msg.obj); } }; //如果不在内存缓存中,也不在本地(被jvm回收掉),则开启线程下载图片 newThread() { /*(non-Javadoc) *@seejava.lang.Thread#run() */ @Override public void run() { //TODOAuto-generatedmethodstub InputStream bitmapIs=HttpUtils.getStreamFromURL(imageURL); Bitmap bitmap=BitmapFactory.decodeStream(bitmapIs); imageCache.put(imageURL,newSoftReference<Bitmap>(bitmap)); Message msg=handler.obtainMessage(0,bitmap); handler.sendMessage(msg); File dir=newFile("/mnt/sdcard/test/"); if(!dir.exists()) { dir.mkdirs(); } FilebitmapFile=newFile("/mnt/sdcard/test/" imageURL.substring(imageURL.lastIndexOf("/")1)); if(!bitmapFile.exists()) { try { bitmapFile.createNewFile(); } catch(IOExceptione) { //TODOAuto-generatedcatchblock e.printStackTrace(); } } FileOutputStreamfos; try { fos=new FileOutputStream(bitmapFile); bitmap.compress(Bitmap.CompressFormat.PNG, ,fos); fos.close(); } catch(FileNotFoundExceptione) { //TODOAuto-generatedcatchblock e.printStackTrace(); } catch(IOExceptione) { //TODOAuto-generatedcatchblock e.printStackTrace(); } } }.start(); return null; } public interface ImageCallBack { public void imageLoad(ImageViewimageView,Bitmapbitmap); } } 这是一个封装好的异步加载图片类,缓存了两份,一份是使用软引用缓存到内存中,一份是缓存到本地sd卡,如果内存中没有,则从本地查找,如果本地没有则从网络获取图片。 public class HttpUtils{ public static InputStreamgetStreamFromURL(StringimageURL){ InputStream in=null; try{ URLurl=newURL(imageURL); HttpURLConnection connection=(HttpURLConnection)url.openConnection(); in=connection.getInputStream(); }catch(Exceptione){ //TODOAuto-generatedcatchblock e.printStackTrace(); } returnin; }
推荐整理分享Android 图片缓存整理(安卓图片缓存太占空间),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:android 图片缓存框架,安卓手机的缓存图片在哪个文件夹,安卓手机相册缓存图片,android 图片缓存框架,android图片缓存机制,android 图片缓存框架,安卓图片缓存太占空间,android 图片缓存框架,内容如对您有帮助,希望把文章链接给更多的朋友!
}
这是一个访问网络获取类。不细说了。
下面看一下如何使用封装好的异步加载图片的类:
public class ImageCacheActivityextendsActivity{ /**Called when thea ctivity isfirst created.*/ private ListView listview; @Override public void onCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.main); listview=(ListView)findViewById(R.id.listView_list); MyAdapter adapter=newMyAdapter(); listview.setAdapter(adapter); } private class MyAdapter extends BaseAdapter{ private AsyncBitmapLoader asyncBitmapLoader; public MyAdapter(){ asyncBitmapLoader=new AsyncBitmapLoader(); } @Override public int getCount(){ //TODOAuto-generatedmethodstub return ; } @Override public Object getItem(intposition){ //TODOAuto-generatedmethodstub return null; } @Override public long getItemId(intposition){ //TODOAuto-generatedmethodstub return 0; } @Override public View getView(intposition,ViewconvertView,ViewGroupparent){ //TODOAuto-generatedmethodstub if(convertView==null){ convertView=LayoutInflater.from(getApplicationContext()).inflate(R.layout.list_item,null); } ImageView image=(ImageView)convertView.findViewById(R.id.addexam_list_icon); String imageURL=" Bitmap bitmap=asyncBitmapLoader.loadBitmap(image,imageURL,newImageCallBack(){ @Override public void imageLoad(ImageViewimageView,Bitmapbitmap){ //TODOAuto-generatedmethodstub imageView.setImageBitmap(bitmap); } }); if(bitmap==null) { image.setImageResource(R.drawable.ic_launcher); } else { image.setImageBitmap(bitmap); } return convertView; } } } 这样就完成了,网络获取不到bitmap则显示默认图片
androidのEclipse中设置NDK编译设置 androidのEclipse中设置NDK编译build设置1、启动eclipse,我们找到上一篇介绍下载后的ndk安装路径,使用选择hello-jni已经存在的案例;import进去即可,,会出
androidの搭建NDK开发环境 1.下载NDK官网下载页:
(翻译)Bytecode for the Dalvik VM -General Design BytecodefortheDalvikVM-GeneralDesign以下所述的machinemodel和调用约定采用了一般架构和C语言调用约定来表述:Dalvi虚拟机是基于寄存器的,函数帧在创建时有固