UnsupportedOperationException: Failed to resolve attribute xxx系列的问题

最近开发的时候遇到这么一个崩溃,找了半天原因终于找到问题的原因。

Caused by: android.view.InflateException: Binary XML file line #33: Error inflating class com.qmuiteam.qmui.widget.dialog.QMUIDialogView                                                                    
Caused by: java.lang.reflect.InvocationTargetException                                                                                                                                                      
    at java.lang.reflect.Constructor.newInstance0(Native Method)                                                                                                                                            
    at java.lang.reflect.Constructor.newInstance(Constructor.java:334)                                                                                                                                      
    at android.view.LayoutInflater.createView(LayoutInflater.java:647)                                                                                                                                      
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:790)                                                                                                                               
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:730)                                                                                                                               
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:863)                                                                                                                                        
    at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:824)                                                                                                                                
    at android.view.LayoutInflater.inflate(LayoutInflater.java:515)                                                                                                                                         
    at android.view.LayoutInflater.inflate(LayoutInflater.java:423)                                                                                                                                         
    at android.view.LayoutInflater.inflate(LayoutInflater.java:374)                                                                                                                                         
    at com.qmuiteam.qmui.widget.dialog.QMUIDialogBuilder.create(QMUIDialogBuilder.java:318)                                                                                                                 
    at com.easy.easycan.me.ProfileFragment.contactService(ProfileFragment.java:224)                                                                                                                         
    at com.easy.easycan.me.ProfileFragment.access$100(ProfileFragment.java:63)                                                                                                                              
    at com.easy.easycan.me.ProfileFragment$5.accept(ProfileFragment.java:177)                                                                                                                               
    at io.reactivex.internal.observers.LambdaObserver.onNext(LambdaObserver.java:63)                                                                                                                        
    at io.reactivex.observers.SerializedObserver.onNext(SerializedObserver.java:111)                                                                                                                        
    at io.reactivex.internal.operators.observable.ObservableThrottleFirstTimed$DebounceTimedObserver.onNext(ObservableThrottleFirstTimed.java:82)                                                           
    at com.jakewharton.rxbinding2.view.ViewClickObservable$Listener.onClick(ViewClickObservable.java:39)                                                                                                    
    at android.view.View.performClick(View.java:6294)                                                                                                                                                       
    at android.view.View$PerformClick.run(View.java:24770)                                                                                                                                                  
    at android.os.Handler.handleCallback(Handler.java:790)                                                                                                                                                  
    at android.os.Handler.dispatchMessage(Handler.java:99)                                                                                                                                                  
    at android.os.Looper.loop(Looper.java:164)                                                                                                                                                              
    at android.app.ActivityThread.main(ActivityThread.java:6494)                                                                                                                                            
    at java.lang.reflect.Method.invoke(Native Method)                                                                                                                                                       
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)                                                                                                                    
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)                                                                                                                                         
Caused by: java.lang.UnsupportedOperationException: Failed to resolve attribute at index 13: TypedValue{t=0x2/d=0x7f0302a9 a=2}                                                                             
    at android.content.res.TypedArray.getDrawableForDensity(TypedArray.java:944)                                                                                                                            
    at android.content.res.TypedArray.getDrawable(TypedArray.java:928)                                                                                                                                      
    at android.view.View.<init>(View.java:4768)                                                                                                                                                             
    at android.view.ViewGroup.<init>(ViewGroup.java:597)                                                                                                                                                    
    at android.widget.LinearLayout.<init>(LinearLayout.java:234)                                                                                                                                            
    at android.widget.LinearLayout.<init>(LinearLayout.java:230)                                                                                                                                            
    at com.qmuiteam.qmui.alpha.QMUIAlphaLinearLayout.<init>(QMUIAlphaLinearLayout.java:39)                                                                                                                  
    at com.qmuiteam.qmui.layout.QMUILinearLayout.<init>(QMUILinearLayout.java:45)                                                                                                                           
    at com.qmuiteam.qmui.widget.dialog.QMUIDialogView.<init>(QMUIDialogView.java:48)                                                                                                                        
    at com.qmuiteam.qmui.widget.dialog.QMUIDialogView.<init>(QMUIDialogView.java:44)                                                                                                                        
    ... 27 more                                                                                                                                                                                                
                                                                                                                                                                                                            

主要的问题是这个

Caused by: java.lang.UnsupportedOperationException: Failed to resolve attribute at index 13: TypedValue{t=0x2/d=0x7f0302a9 a=2}

这个错误是TypedArray代码抛出的
frameworks/base/core/java/android/content/res/TypedArray.java

    public ColorStateList getColorStateList(int index) {
        if (mRecycled) {
            throw new RuntimeException("Cannot make calls to a recycled instance!");
        }
 
        final TypedValue value = mValue;
        if (getValueAt(index*AssetManager.STYLE_NUM_ENTRIES, value)) {
            if (value.type == TypedValue.TYPE_ATTRIBUTE) {
                throw new UnsupportedOperationException(
                        "Failed to resolve attribute at index " + index + ": " + value);
            }
            return mResources.loadColorStateList(value, value.resourceId, mTheme);
        }
        return null;
    }

上边的源码可以看出是TypedValue.TYPE_ATTRIBUTE类型就会抛出这个exception
可以看出TypedValue{t=0x2/d=0x1010351 a=1}其中的t=0x2就是指类型为2,其它含义参见代码

    public String toString()
    {
        StringBuilder sb = new StringBuilder();
        sb.append("TypedValue{t=0x").append(Integer.toHexString(type));
        sb.append("/d=0x").append(Integer.toHexString(data));
        if (type == TYPE_STRING) {
            sb.append(" \"").append(string != null ? string : "<null>").append("\"");
        }
        if (assetCookie != 0) {
            sb.append(" a=").append(assetCookie);
        }
        if (resourceId != 0) {
            sb.append(" r=0x").append(Integer.toHexString(resourceId));
        }
        sb.append("}");
        return sb.toString();
    }

其中的"a="只对string有意义,这个获取的是color,所以“a=1”没啥含义

    /** Additional information about where the value came from; only
     *  set for strings. */
    public int assetCookie;

其中的d是资源id,framework中的资源id是预先指定好的,app的编译时动态确定。
frameworks/base/core/res/res/values/public.xml

 <public type="attr" name="background" id="0x7f0302a9" />

其中的0x7f0302a9就是指background,报错的原因就是background最终没有确认成一个确定的值。
出现这个原因主要是因为引用了Qmui的ui库,但是activity的theme没有继承QMUI.Compat.NoActionBar,所以导致设置背景的时候找不到对应的资源出现的这个问题。绕了很大一圈,这里记录一下问题。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,723评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,080评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,604评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,440评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,431评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,499评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,893评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,541评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,751评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,547评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,619评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,320评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,890评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,896评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,137评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,796评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,335评论 2 342