【发布时间】:2014-11-12 10:23:46
【问题描述】:
小问题: Resources.Theme.resolveAttibute(attrId, typVal, true) 返回 typVal.resourceId 是 0,导致该异常。这个ResourceReader.getResourceId() 在整个应用程序的所有地方都运行良好。但随机,应用更新或多次重启后出现此异常,因为 TypedValue.resourceId 为 0。
长问题: 我在应用 restart 上收到 ResourcesNotFoundException 很遗憾,我无法确定何时发生此错误。当我在一分钟内多次重新启动(关闭、终止、重新启动、更新、设置)我的应用程序时,我的应用程序最终在第一个资源读取行提供了这个 RNFE。
堆栈跟踪:
Caused by: android.content.res.Resources$NotFoundException: Resource ID #0x0
at android.content.res.Resources.getValue(Resources.java:2331)
at android.content.res.Resources.getColor(Resources.java:2013)
at com.my.app.navi.NavigationFragment.setUp(NavigationDrawerFragment.java:570)
at com.my.app.main.MainActivity.onCreate(MainActivity.java:1071)
很难生成该异常,但在 Google Play 开发者控制台中,我可以看到很多其他设备生成的异常。
我为该异常查找了很多答案,但也没有重建,String.ValueOf(int),资源添加解决了我的问题。
我为不同风格和特色的应用程序提供了几种构建风格。因此,我使用 attr 样式参考作为资源。所有口味都有不同的 res 文件夹。主要 res 文件夹有 attrs.xml 用于参考颜色、drawables 和图像。所有其他代码和 xml 布局文件都有 R.attrs 引用
为了清楚地解释我的情况,这是主要 res attrs.xml
<declare-styleable name="Colors">
<!--<<<<<<<<<<<<<<<<<<<<< COLORS >>>>>>>>>>>>>>>>>>>>>>>>>>>>-->
<attr name="c_pressed_button_back" format="color"/>
<attr name="c_window_back" format="color"/>
<attr name="c_navigation_drawer_back" format="color"/>
flavor_one style.xml
<!--<<<<<<<<<<<<<<<<<<<<<<<<< COLORS >>>>>>>>>>>>>>>>>>>>>>>>>>>>>-->
<item name="c_pressed_button_back">@color/c_theme_pressed_button_back</item>
<item name="c_window_back">@color/c_theme_window_back</item>
<item name="c_navigation_drawer_back">@color/c_theme_navigation_drawer_back</item>
flavor_one colors.xml
<color name="c_theme_pressed_button_back">@color/c_theme_red</color>
<color name="c_theme_window_back">@color/c_theme_green</color>
<color name="c_theme_navigation_drawer_back">@color/c_theme_blue</color>
通过这些设置,我编写了这个类用于资源阅读。
public class ResourceReader
{
public static int getResourceId(Resources.Theme thm, int attrId)
{
int returnValue = 0;
TypedValue typedValue = new TypedValue();
try {
thm.resolveAttribute(attrId, typedValue, true);
returnValue = typedValue.resourceId;
}
catch (Exception ex) // Resource cannot resolved
{
ex.printStackTrace();
}
if(returnValue == 0)
{
Log.e("yucel", "Resource resolved result is 0 @thm:" + thm + " attrid:" + attrId + " typdata:" + typedValue.data + " typtyp:" + typedValue.type + " ");
}
return returnValue;
}
}
最后我使用了类似的资源
int back_color_id = ResourceReader.getResourceId(appData.appContext.getTheme(), R.attr.c_navigation_drawer_back);
int back_color= appData.appRes.getColor(back_color_id);
mDrawerLayout.setColor(back_color);
getColor(back_color_id) 行会抛出异常。因为 back_color_id 等于 0。在资源阅读器thm.resolveAttribute(attrId, typedValue, true);
我认为整个代码语句看起来还不错。因为整个应用程序和 99% 的用户使用这种结构都很好。几次重新启动后出现问题,并且在资源读取时随机出现。在这种情况下必须改变一些东西。有什么方法可以检查资源是否处于正确状态,例如Context.isResourceLoading() 或Resoureces.isLoaded()?
随机、多次重启或更新后是否存在资源读取问题?
【问题讨论】:
标签: android exception resources