У меня есть некоторые проблемы с моим приложением. В отчетах по рынку часто появляется репостр ANR с ошибками HttpClient. Есть
java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2016) в org.apache.http.impl.conn.tsccm.WaitingThread.await(WaitingThread.java:159) в org.apache.http. impl.conn.tsccm.ConnPoolByRoute.getEntryBlocking(ConnPoolByRoute.java:339) в org.apache.http.impl.conn.tsccm.ConnPoolByRoute$1.getPoolEntry(ConnPoolByRoute.java:238) в org.apache.http.impl.conn .tsccm.ThreadSafeClientConnManager$1.getConnection(ThreadSafeClientConnManager.java:175) в org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:325) в org.apache.http.impl.client.AbstractHttpClient.execute( AbstractHttpClient.java:580) в org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:512) в org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:490)
java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2022) в java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:413) в java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor. java:1014) в java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1074) в java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:574) в java.lang.Thread.run(Thread .java:1020)
ПОТОКИ DALVIK: (мьютексы: tll=0 tsl=0 tscl=0 ghl=0 hwl=0 hwll=0) "main" prio=5 tid=1 NATIVE | group="main" sCount=1 dsCount=0 obj=0x40027550 self=0xcfc0 | sysTid=2557 nice=0 sched=0/0 cgrp=дескриптор по умолчанию=-1345006240 | schedstat=( 6440246597 181026702867 12047 ) в org.apache.harmony.luni.platform.OSNetworkSystem.connect(собственный метод) в dalvik.system.BlockGuard$WrappedNetworkSystem.connect(BlockGuard.java:357) в org.apache.harmony.luni .net.PlainSocketImpl.connect(PlainSocketImpl.java:207) на org.apache.harmony.luni.net.PlainSocketImpl.connect(PlainSocketImpl.java:440) на java.net.Socket.connect(Socket.java:1013) на org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119) в org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:143) в org.apache.http.impl. conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) в org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) в org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector. java:359) в org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttp Client.java:555) в org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) в org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465
Есть ли способ избежать этой ошибки? Может быть, есть лучшая практика работы с httpClient? В моем приложении я использую:
public ApiImpl() {
this.httpClient = new DefaultHttpClient();
ClientConnectionManager mgr = httpClient.getConnectionManager();
HttpParams params = httpClient.getParams();
this.httpClient = new DefaultHttpClient(new ThreadSafeClientConnManager(params, mgr.getSchemeRegistry()), params);
}
public class Client {
private static Api api;
private static Client instance = null;
public static Client getInstance() {
if (instance == null) {
instance = new Client();
}
return instance;
}
private Client() {
api = new ApiImpl();
}
}
то в коде я использую следующее
Client client = Client.getInstance();
client.do();