解决方案 »

  1.   

    问题太长,logcat后半部分放到 这里   
    java.lang.reflect.InvocationTargetException
    at java.lang.reflect.Constructor.constructNative(Native Method)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at android.view.LayoutInflater.createView(LayoutInflater.java:597)
    at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
    at android.view.LayoutInflater.onCreateView(LayoutInflater.java:672)
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:697)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:472)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:400)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
    at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:290)
    at android.app.Activity.setContentView(Activity.java:1946)
    at com.snscity.member.WelcomeActivity.onCreate(WelcomeActivity.java:78)
    at android.app.Activity.performCreate(Activity.java:5248)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2162)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2247)
    at android.app.ActivityThread.access$800(ActivityThread.java:141)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1210)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:136)
    at android.app.ActivityThread.main(ActivityThread.java:5050)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:515)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:807)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:623)
    at dalvik.system.NativeStart.main(Native Method)
    Caused by: java.lang.OutOfMemoryError
    at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
    at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:597)
    at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:432)
    at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:840)
    at android.content.res.Resources.createFromResourceStream(Resources.java:2477)
    at android.content.res.Resources.loadDrawable(Resources.java:2136)
    at android.content.res.MiuiResources.loadDrawable(MiuiResources.java:359)
    at android.content.res.TypedArray.getDrawable(TypedArray.java:602)
    at android.view.View.<init>(View.java:3558)
    at android.view.View.<init>(View.java:3488)
    at android.view.ViewGroup.<init>(ViewGroup.java:464)
    at android.widget.RelativeLayout.<init>(RelativeLayout.java:236)
    ... 26 more
    java.lang.OutOfMemoryError
    at android.graphics.BitmapFactory.nativeDecodeAsset(Native Method)
    at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:597)
    at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:432)
    at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:840)
    at android.content.res.Resources.createFromResourceStream(Resources.java:2477)
    at android.content.res.Resources.loadDrawable(Resources.java:2136)
    at android.content.res.MiuiResources.loadDrawable(MiuiResources.java:359)
    at android.content.res.TypedArray.getDrawable(TypedArray.java:602)
    at android.view.View.<init>(View.java:3558)
    at android.view.View.<init>(View.java:3488)
    at android.view.ViewGroup.<init>(ViewGroup.java:464)
    at android.widget.RelativeLayout.<init>(RelativeLayout.java:236)
    at java.lang.reflect.Constructor.constructNative(Native Method)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at android.view.LayoutInflater.createView(LayoutInflater.java:597)
    at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
    at android.view.LayoutInflater.onCreateView(LayoutInflater.java:672)
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:697)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:472)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:400)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
    at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:290)
    at android.app.Activity.setContentView(Activity.java:1946)
    at com.snscity.member.WelcomeActivity.onCreate(WelcomeActivity.java:78)
    at android.app.Activity.performCreate(Activity.java:5248)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2162)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2247)
    at android.app.ActivityThread.access$800(ActivityThread.java:141)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1210)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:136)
    at android.app.ActivityThread.main(ActivityThread.java:5050)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:515)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:807)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:623)
    at dalvik.system.NativeStart.main(Native Method)
      

  2.   

    android:background="@drawable/welcome_bg" 这个图片很大么? 去掉试试。
      

  3.   

    welcome_bg 这个最好控制在几百K以内
      

  4.   

       这个bug也不是必现
      

  5.   

    OutOfMemory并不一定是当前图片的问题,这就好比你有一个桶里面装了水,一开始你放一块很大的石头导致水马上要溢出了,这时候你再放一块很小的石头就导致水溢出了,你的这张图片很有可能就是这块小石头。
    排除方法可以借助Android studio最新版的Memory Monitor功能监控你的APP内存情况,当然也可以dump一下然后利用Memory Analyzer排除了。
      

  6.   

    bitmap不用了要及时手动 recycle
      

  7.   

    图片很大有两个意思,一个是图片本身的大小,就是你说的46.9KB,另外就是图片的像素,也是就长度和宽度,这个很大程度上回决定占用内存大小,一般是图片的长像素数*宽像素*4,也就是说如果你的图片是1024*1024宽和高,那么占用内存就是4M。