内存异常android

时间:2011-11-15 11:56:49

标签: android

我可以选择以不同的语言查看我的应用程序 - 英语,泰米尔语和印地语。我使用了customtextview,其中根据用户想要的语言设置字体。

当应用程序使用一段时间后,我出现了内存不足的问题。设置字体对应用程序中的所有textview有直接影响吗?

附加了正在扩展Textview的CustomTextView的代码片段:

  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 个答案:

答案 0 :(得分:0)

Memory Analyzer Tool(MAT)有助于找出你的记忆力。通常,崩溃不会发生在真正问题所在的地方。

http://eclipse.org/mat/

您可以直接从Eclipse中的DDMS视图转储内存(使用“更新堆”按钮,然后触发垃圾回收)。可能需要一点时间来理解这个工具,但这对你的武器库来说是一个重要的工具。

顺便说一下,我也遇到了与语言环境相关的内存异常问题。我的问题是我重新加载了活动以更改语言环境,并且在一个实例中,它无法加载新语言环境并继续重新加载,直到内存不足为止。