不工作的时候使用的ProGuard [英] Does not work when use ProGuard

查看:299
本文介绍了不工作的时候使用的ProGuard的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

在logcat中如下。什么是错?

  

10月7日至24号:54:13.529:E / AndroidRuntime(12130):致命异常:AsyncTask的#3

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):java.lang.RuntimeException的:执行doInBackground()时发生错误

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在android.os.AsyncTask $ 3.done(AsyncTask.java:299)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.util.concurrent.FutureTask中$ Sync.innerSetException(FutureTask.java:273)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.util.concurrent.FutureTask.setException(FutureTask.java:124)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.util.concurrent.FutureTask中$ Sync.innerRun(FutureTask.java:307)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.util.concurrent.FutureTask.run(FutureTask.java:137)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.util.concurrent.ThreadPoolExecutor中的$ Worker.run(ThreadPoolExecutor.java:569)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.lang.Thread.run(Thread.java:856)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):java.lang.AssertionError:产生的原因非法类型变量引用

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在org.apache.harmony.luni.lang.reflect.ImplForVariable.resolve(ImplForVariable.java:113)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在org.apache.harmony.luni.lang.reflect.ImplForVariable.getGenericDeclaration(ImplForVariable.java:127)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在org.apache.harmony.luni.lang.reflect.ImplForVariable.hash code(ImplForVariable.java:46)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.util.Arrays.hash code(Arrays.java:1260)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在com.google.gson.internal $ GSON $类型$ ParameterizedTypeImpl.hash code(的SourceFile:475)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在com.google.gson.reflect.TypeToken(的SourceFile:64)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在com.gaozhi.wh.asynctask.MyAsyncTask $ 2 $ 1(的SourceFile:78)。

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在com.gaozhi.wh.asynctask.MyAsyncTask $ 2.call(的SourceFile:78)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在com.gaozhi.wh.asynctask.MyAsyncTask $ 2.call(的SourceFile:1)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在com.gaozhi.wh.utils.async.AsyncTaskUtils $ 2.doInBackground(的SourceFile:114)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在com.gaozhi.wh.utils.async.AsyncTaskUtils $ 2.doInBackground(的SourceFile:1)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在android.os.AsyncTask $ 2.call(AsyncTask.java:287)

     

10月7日至24号:54:13.529:E / AndroidRuntime(12130):在java.util.concurrent.FutureTask中$ Sync.innerRun(FutureTask.java:305)   10月七号至24日:54:13.529:E / AndroidRuntime(12130)... 4个

我发现,是造成这一行code误差

信息= GsonUtils.getMutileBean(因此,新TypeToken< JsonResult< T>>(){} .getType());

 公共静态< T>牛逼getMutileBean(字符串jsonData,型型)
        抛出异常{
    返回新GSON()fromJson(jsonData,类型)。
}
 

但我不得不添加的ProGuard配置GSON

  

#GSON使用带有字段时,存储在一个类文件泛型类型的信息。 Proguard的

     

#删除默认情况下这些信息,因此其配置,以保持它的全部。

     

-keepattributes签名

     

#对于使用GSON @expose注释

     

-keepattributes的注释

     

#GSON特定的类

     

-keep类sun.misc.Unsafe {*; }

     

# - 保留类com.google.gson.stream ** {*。 }

     

这将被序列化#应用程序类/解串过GSON

     

-keep类com.google.gson.examples.android.model ** {*。 }

解决方案

您可能需要添加

  -keepattributes EnclosingMethod
 

The logcat is below. what is wrong?

07-24 10:54:13.529: E/AndroidRuntime(12130): FATAL EXCEPTION: AsyncTask #3

07-24 10:54:13.529: E/AndroidRuntime(12130): java.lang.RuntimeException: An error occured while executing doInBackground()

07-24 10:54:13.529: E/AndroidRuntime(12130): at android.os.AsyncTask$3.done(AsyncTask.java:299)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask.setException(FutureTask.java:124)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask.run(FutureTask.java:137)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.lang.Thread.run(Thread.java:856)

07-24 10:54:13.529: E/AndroidRuntime(12130): Caused by: java.lang.AssertionError: illegal type variable reference

07-24 10:54:13.529: E/AndroidRuntime(12130): at org.apache.harmony.luni.lang.reflect.ImplForVariable.resolve(ImplForVariable.java:113)

07-24 10:54:13.529: E/AndroidRuntime(12130): at org.apache.harmony.luni.lang.reflect.ImplForVariable.getGenericDeclaration(ImplForVariable.java:127)

07-24 10:54:13.529: E/AndroidRuntime(12130): at org.apache.harmony.luni.lang.reflect.ImplForVariable.hashCode(ImplForVariable.java:46)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.Arrays.hashCode(Arrays.java:1260)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.google.gson.internal.$Gson$Types$ParameterizedTypeImpl.hashCode(SourceFile:475)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.google.gson.reflect.TypeToken.(SourceFile:64)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.asynctask.MyAsyncTask$2$1.(SourceFile:78)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.asynctask.MyAsyncTask$2.call(SourceFile:78)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.asynctask.MyAsyncTask$2.call(SourceFile:1)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.utils.async.AsyncTaskUtils$2.doInBackground(SourceFile:114)

07-24 10:54:13.529: E/AndroidRuntime(12130): at com.gaozhi.wh.utils.async.AsyncTaskUtils$2.doInBackground(SourceFile:1)

07-24 10:54:13.529: E/AndroidRuntime(12130): at android.os.AsyncTask$2.call(AsyncTask.java:287)

07-24 10:54:13.529: E/AndroidRuntime(12130): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305) 07-24 10:54:13.529: E/AndroidRuntime(12130): ... 4 more

I found that is caused by this line of code error

info = GsonUtils.getMutileBean(result,new TypeToken<JsonResult<T>>() {}.getType());

public static <T> T getMutileBean(String jsonData, Type type)
        throws Exception {
    return new Gson().fromJson(jsonData, type);
}

.

But I had add proguard configuration for Gson

# Gson uses generic type information stored in a class file when working with fields. Proguard

# removes such information by default, so configure it to keep all of it.

-keepattributes Signature

# For using GSON @Expose annotation

-keepattributes Annotation

# Gson specific classes

-keep class sun.misc.Unsafe { *; }

#-keep class com.google.gson.stream.** { *; }

# Application classes that will be serialized/deserialized over Gson

-keep class com.google.gson.examples.android.model.** { *; }

解决方案

You may need to add

-keepattributes EnclosingMethod

这篇关于不工作的时候使用的ProGuard的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆