Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 4075994
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 20, 20262026-05-20T17:22:08+00:00 2026-05-20T17:22:08+00:00

I have gotten some reports from users of crashes when try use my application

  • 0

I have gotten some reports from users of crashes when try use my application on Verizon’s 4G/LTE.

Looking at the stack trace, it looks like Android’s HttpClient.execute() implementation is throwing an OOM. This happens only on 4G/LTE devices, specifically HTC Thunderbolt, and only when on 4G/LTE. WiFi, 3G, UMTS are OK. Also works fine on Sprint’s WiMax 4G stuff works fine.

Two questions:

  • What’s the best way to get the attention of Android devs about this? Any better options than reporting on http://code.google.com/p/android/issues?

  • Any ideas on how I can work around this? I don’t have a 4G device myself and I can’t get this happen in the emulator so I need to make some educated guesses here. I can try to catch the OOM in my code and attempt to cleanup and force GC, but I’m not sure if that’s a good idea. Comments or other suggestions?

Here’s what my code’s doing:

    HttpParams params = this.getHttpParams(); // returns params
    ClientConnectionManager cm = new ThreadSafeClientConnManager(params, this.getHttpSchemeRegistry() );
    DefaultHttpClient httpClient = new DefaultHttpClient( cm, params );

    HttpResponse response = null;
    request = new HttpGet( url );

    try {

        response = httpClient.execute(request); // <-- OOM on 4G/LTE. OK otherwise
        int statusCode = response.getStatusLine().getStatusCode();
        Log.i("fetcher", "execute returned, http status " + statusCode );

    ...

Here’s the crashing stack trace:

E/dalvikvm-heap(11639): Out of memory
on a 2055696-byte allocation.
I/dalvikvm(11639): “Thread-16″ prio=5
tid=9 RUNNABLE I/dalvikvm(11639): |
group=”main” sCount=0 dsCount=0 s=N
obj=0x48563070 self=0x3c4340
I/dalvikvm(11639): | sysTid=11682
nice=0 sched=0/0 cgrp=default
handle=3948760 I/dalvikvm(11639): |
schedstat=( 208709711 74005130 214 )

I/dalvikvm(11639): at
org.apache.http.impl.io.AbstractSessionInputBuffer.init(AbstractSessionInputBuffer.java:~79)
I/dalvikvm(11639): at
org.apache.http.impl.io.SocketInputBuffer.(SocketInputBuffer.java:93)
I/dalvikvm(11639): at
org.apache.http.impl.SocketHttpClientConnection.createSessionInputBuffer(SocketHttpClientConnection.java:83)
I/dalvikvm(11639): at
org.apache.http.impl.conn.DefaultClientConnection.createSessionInputBuffer(DefaultClientConnection.java:170)
I/dalvikvm(11639): at
org.apache.http.impl.SocketHttpClientConnection.bind(SocketHttpClientConnection.java:106)
I/dalvikvm(11639): at
org.apache.http.impl.conn.DefaultClientConnection.openCompleted(DefaultClientConnection.java:129)
I/dalvikvm(11639): at
org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:173)
I/dalvikvm(11639): at
org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
I/dalvikvm(11639): at
org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
I/dalvikvm(11639): at
org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:348)
I/dalvikvm(11639): at
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
I/dalvikvm(11639): at
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
I/dalvikvm(11639): at
org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
I/dalvikvm(11639): at
com.myapplication.Fetcher.trySourceFetch(Fetcher.java:205)
I/dalvikvm(11639): at
com.myapplication.Fetcher.run(Fetcher.java:298)
I/dalvikvm(11639): at
java.lang.Thread.run(Thread.java:1102)
I/dalvikvm(11639): E/dalvikvm(11639):
Out of memory: Heap Size=24171KB,
Allocated=23142KB, Bitmap Size=59KB,
Limit=21884KB E/dalvikvm(11639): Extra
info: Footprint=24327KB, Allowed
Footprint=24519KB, Trimmed=348KB
W/dalvikvm(11639): threadid=9: thread
exiting with uncaught exception
(group=0x40025b38)

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-20T17:22:09+00:00Added an answer on May 20, 2026 at 5:22 pm

    Looking at the stack trace, it looks like Android’s HttpClient.execute() implementation is throwing an OOM.

    That is not indicated by the stack trace you have on the issue. Of course, you didn’t provide the whole stack trace on the issue.

    What’s the best way to get the attention of Android devs about this? Any better options than reporting on http://code.google.com/p/android/issues?

    The odds of this being a pure Android bug are small, though not zero.

    Here are some other possibilities, in no particular order:

    1. There is no problem with execute() per se, but that you are simply running out of memory, and the stack traces you have encountered are simply demonstrating that execute() is stressing your heap.

    2. The problem is in some modifications that HTC made to Android for the Thunderbolt, possibly only taking effect when on the LTE network.

    3. The problem is somehow caused by the Verizon LTE network itself (e.g., some proxy of theirs sending back screwball information that is causing HttpClient to have a conniption).

    Any ideas on how I can work around this?

    First, I’d use existing tools (e.g., dumping HPROF and examining with Eclipse MAT) to confirm that you don’t have a memory leak in general that the Thunderbolt/LTE combo just seems to be tripping over.

    Next, I recommend that you come up with some way to consistently reproduce the error. That could be your existing app with a series of steps to follow, or it could be a dedicated app (e.g., log the URL that triggers the OOM, then create a tiny app that just does that HttpClient request). I wish DeviceAnywhere had a Thunderbolt, but it doesn’t look like it. I’ll put some feelers out and see if I can get some help on that front.

    In terms of working around it, as a stopgap, you can detect that you’re running on a Thunderbolt via android.os.Build data, and perhaps that you’re on LTE via ConnectivityManager (I’m guessing LTE would list as WiMAX, but that’s just a guess), and warn users about the problems with that combo.

    Beyond that, you can try changing up your HttpClient usage a bit and see if it has an effect, such as:

    • If you are only supporting API Level 8 or higher, you could give AndroidHttpClient a shot as a drop-in replacement
    • Disable multi-threaded access (in general or Thunderbolt-specific) and get rid of the ThreadSafeClientConnManager

    I’m sorry that I don’t have a “magic bullet” answer for you here.


    UPDATE

    Now that I have the full stack trace, looking through the source code is…illuminating, somewhat.

    The problem appears to be that:

    HttpConnectionParams.getSocketBufferSize(params);
    

    is returning that 2MB or so value that is triggering the OOM. That’s an awfully big buffer, particularly for the Dalvik GC engine, which can get fragmented (yes, there’s that word again).

    params here is the HttpParams. You seem to be creating those yourself via getHttpParams(). For example, AndroidHttpClient sets that to 8192:

    HttpConnectionParams.setSocketBufferSize(params, 8192);
    

    If you are setting the socket buffer size yourself, try reducing it. If not, try setting it to 8192 and see if that helps.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have gotten everything working for my class in which I am using Tomcat
I have been searching everywhere for the following functionality in Lisp, and have gotten
I am working on Conway's Game of Life currently and have gotten stuck. My
I've searched for this a little but I have not gotten a particularly straight
I guess the topic says it. I have tried googling this, but havent gotten
Have you used VS.NET Architect Edition's Application and System diagrams to start designing a
I have a script that appends some rows to a table. One of the
i have a input tag which is non editable, but some times i need
Have just started using Google Chrome , and noticed in parts of our site,
Have you ever seen any of there error messages? -- SQL Server 2000 Could

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.