多线程环境下 java.io.IOException: Mark has been invalidated.

来源:互联网 发布:内核优化 编辑:程序博客网 时间:2024/05/29 14:22


[java] view plaincopy
  1. bitmap = BitmapFactory.decodeStream(uc.getInputStream());   
[java] view plaincopy
  1. 12-15 15:25:47.275: W/System.err(2303): java.io.IOException: Mark has been invalidated.  
  2. 12-15 15:25:47.295: W/System.err(2303):     at java.io.BufferedInputStream.reset(BufferedInputStream.java:425)  
  3. 12-15 15:25:47.335: W/System.err(2303):     at android.graphics.BitmapFactory.nativeDecodeStream(Native Method)  
  4. 12-15 15:25:47.345: W/System.err(2303):     at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:505)  
  5. 12-15 15:25:47.365: W/System.err(2303):     at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:566)  
  6. 12-15 15:25:47.385: W/System.err(2303):     at org.droid.util.view.BitmapUtils.loadBitmapFromNet(BitmapUtils.java:50)  
  7. 12-15 15:25:47.395: W/System.err(2303):     at org.droid.util.AsyncLoader.doInBackground(AsyncLoader.java:39)  
  8. 12-15 15:25:47.405: W/System.err(2303):     at android.os.AsyncTask$2.call(AsyncTask.java:216)  
  9. 12-15 15:25:47.425: W/System.err(2303):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:336)  
  10. 12-15 15:25:47.435: W/System.err(2303):     at java.util.concurrent.FutureTask.run(FutureTask.java:168)  
  11. 12-15 15:25:47.445: W/System.err(2303):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1099)  
  12. 12-15 15:25:47.465: W/System.err(2303):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:592)  
  13. 12-15 15:25:47.485: W/System.err(2303):     at java.lang.Thread.run(Thread.java:1127


究其原因 主要是 多个线程操作了 HttpUrlConnection 这个对象。。

解决办法 。 把 static方法改成非static的了。然后每次都重新撞见一个对象 问题解决

0 0
原创粉丝点击