2011-11-15 96 views
4

我有一個選項可以用不同的語言查看我的應用程序 - 英語,泰米爾語和印地語。我已經使用customtextview來設置字體,這取決於用戶想要的語言。內存不足異常android

當應用程序使用了一段時間後,我的內存異常即將消失。設置字體是否對應用程序中的所有文字視圖有直接影響?

粘貼了CustomTextView中的哪一個擴展TextView的代碼片段:

public L10nTextView(Context context, AttributeSet attrs) { 
    super(context, attrs); 
    this.ttfName = ttfFileName; 
    init(); 
} 

private void init() { 
    if (ttfName != null) { 
     setTypeface(MyApplication.typeFace); 
    } else { 
     setTypeface(null); 
    } 

} 

錯誤日誌:

11-15 20:08:50.527: ERROR/AndroidRuntime(2731): FATAL EXCEPTION: main 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731): java.lang.OutOfMemoryError: bitmap size exceeds VM budget 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:460) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:336) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:697) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.content.res.Resources.loadDrawable(Resources.java:1709) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.content.res.Resources.getDrawable(Resources.java:581) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at com.android.internal.policy.impl.PhoneWindow.generateLayout(PhoneWindow.java:2226) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at com.android.internal.policy.impl.PhoneWindow.installDecor(PhoneWindow.java:2261) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:203) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.app.Activity.setContentView(Activity.java:1657) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at com.techjini.tvguide.android.activity.BaseActivity.setContentView(BaseActivity.java:94) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at com.techjini.tvguide.android.activity.ProgramNextAiringActivity.onCreate(ProgramNextAiringActivity.java:23) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.os.Handler.dispatchMessage(Handler.java:99) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.os.Looper.loop(Looper.java:130) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at android.app.ActivityThread.main(ActivityThread.java:3683) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at java.lang.reflect.Method.invokeNative(Native Method) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at java.lang.reflect.Method.invoke(Method.java:507) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
11-15 20:08:50.527: ERROR/AndroidRuntime(2731):  at dalvik.system.NativeStart.main(Native Method) 

沒有定位功能,我的應用程序工作正常,並不會崩潰。

base_layout.xml:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:id="@+id/header_bar_layout" android:visibility="visible" 
android:layout_width="fill_parent" android:layout_height="fill_parent" 
android:orientation="vertical"> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/header_bar" android:visibility="visible" 
    android:layout_width="fill_parent" android:layout_height="wrap_content"> 
    <ImageView android:id="@+id/header_click" 
     android:layout_width="wrap_content" android:layout_height="wrap_content" 
     android:src="@drawable/before" android:layout_alignParentRight="true" /> 
    <ProgressBar android:id="@+id/prg_bar" 
     android:layout_toLeftOf="@id/header_click" android:layout_width="25dip" 
     android:layout_height="25dip" android:layout_centerVertical="true" 
     android:visibility="gone" /> 
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
     android:id="@+id/logo_layout" android:orientation="horizontal" 
     android:layout_alignParentLeft="true" android:layout_width="wrap_content" 
     android:layout_height="wrap_content" android:visibility="visible"> 
     <ImageView android:id="@+id/logo_bar" 
      android:layout_alignParentLeft="true" android:layout_height="wrap_content" 
      android:src="@drawable/logo_bar" android:layout_width="wrap_content" /> 
    </LinearLayout> 
    <LinearLayout android:id="@+id/rating" 
     android:orientation="horizontal" android:layout_alignParentLeft="true" 
     android:layout_width="wrap_content" android:layout_height="wrap_content" 
     android:visibility="invisible"> 
     <ImageView android:id="@+id/rate_us" android:layout_width="wrap_content" 
      android:layout_height="wrap_content" android:src="@drawable/rate_us" /> 
     <ImageView android:id="@+id/like_us" android:layout_width="wrap_content" 
      android:layout_height="wrap_content" android:src="@drawable/fb_like_us" /> 
     <ImageView android:id="@+id/follow_us" 
      android:layout_width="wrap_content" android:layout_height="wrap_content" 
      android:src="@drawable/twitter_follow_us" /> 
    </LinearLayout> 
    </RelativeLayout> 
</LinearLayout> 

當語言發生了變化重新啓動我的申請,我設置的語言環境。但是內存不會被釋放,每當我的應用程序打開時,它只會在最終由於內存不足而崩潰時增加。

的setLocale方法來改變區域:

public void setLocale(String languageLocaleToLoad) { 
    Locale locale = new Locale(languageLocaleToLoad); 

    Locale.setDefault(locale); 

    android.content.res.Configuration config = new android.content.res.Configuration(); 

    config.locale = locale; 

    getResources().updateConfiguration(config, 
      getResources().getDisplayMetrics()); 

} 

我還發現,本機堆的大小不斷增加每當語言發生了變化,最後是應用程序崩潰。

+1

你能發佈錯誤日誌嗎? – user370305

+0

你可以發佈你的BaseActivity的佈局或者你的BaseActivity的第94行加載的佈局嗎? –

+0

我懷疑你的問題實際上是在別的地方,即與字體無關。語言環境變化只是將低內存問題引起您的注意。你還記得什麼?你可以使用DDMS找出。 –

回答

0

內存分析工具(MAT)可以幫助您找出內存的位置。通常情況下,碰撞不會發生在真正問題的地方。

http://eclipse.org/mat/

您可以從Eclipse中的DDMS視圖(使用「更新堆」按鈕,然後觸發垃圾收集)直接轉儲內存。理解這個工具可能需要一點時間,但是在你的武器庫中這是一個重要的工具。

順便說一句,我有一個與語言環境有關的內存不足的異常問題。我的問題是我重新加載活動來改變語言環境,並且在一個實例中,它無法加載新的語言環境,並一直重新加載直到內存不足。

+0

我有幾個listviews。當設置語言時,我正在使用以下命令重新啓動應用程序: 意圖i = getBaseContext()。getPackageManager() .getLaunchIntentForPackage(getBaseContext()。getPackageNam()); i.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); startActivity(i); 但是,即使重新加載應用程序,也不會釋放先前分配的內存。 – Maggi

+0

你需要去努力嗎?我只是這樣做:Intent restartIntent = new Intent(this,this.getClass()); restartIntent.setAction(意圖。ACTION_CONFIGURATION_CHANGED); startActivity(restartIntent); finish(); – ProjectJourneyman