我正在编写一个应用程序,它有一个带有数字的文本字段的表单。为了检查输入是否有效,我决定使用 Hamcrest Matchers。我定义:
public static <T> boolean checkThat(T actual, Matcher<? super T> matcher) {
return matcher.matches(actual);
}
Run Code Online (Sandbox Code Playgroud)
这样我就可以使用以下内容:
if(checkThat(doubleFromText,greaterThan(0.0)) doSomething();
Run Code Online (Sandbox Code Playgroud)
现在这在调试模式下工作得很好,但是当我为生产版本启用 proguard 时,应用程序立即崩溃并显示以下消息(通过回溯获得):
java.lang.Error: Cannot determine correct type for matchesSafely() method.
at org.hamcrest.internal.ReflectiveTypeFinder.findExpectedType(Unknown Source)
canObtainExpectedTypeFrom
at org.hamcrest.TypeSafeMatcher.<init>(Unknown Source)
at org.hamcrest.TypeSafeMatcher.<init>(Unknown Source)
at org.hamcrest.number.OrderingComparison.<init>(Unknown Source)
at org.hamcrest.number.OrderingComparison.greaterThan(Unknown Source)
matchesSafely
at org.hamcrest.Matchers.greaterThan(Unknown Source)
Run Code Online (Sandbox Code Playgroud)
我怎样才能解决这个问题?
我做了一个最小的例子来演示这个问题:https : //github.com/burgerga/HamcrestMatchersWithProguard
笔记:
-dontwarn java.beans.**到我的 proguard 规则中以使其编译。在你开始告诉我我应该使用之前if(doubleFromText > 0),我给出的例子已经简化了。在我的代码中,我使用类似的东西
checkThat(textIn(myEditText),parsesToDouble(greaterThan(0.0)));
Run Code Online (Sandbox Code Playgroud)
parsesToDouble我写的一个简单的匹配器在哪里。我认为这是一种非常灵活和清晰的方式来表达我的意图,我只是对如何让它与 proguard 一起工作感兴趣。
在其中一个关于如何在C中将int转换为字符串的答案(及其注释)中, 给出了以下解决方案
char str[ENOUGH];
sprintf(str, "%d", 42);
Run Code Online (Sandbox Code Playgroud)
在评论CAF提到,ENOUGH可以在编译时间确定:
#define ENOUGH ((CHAR_BIT * sizeof(int) - 1) / 3 + 2)
Run Code Online (Sandbox Code Playgroud)
我得到了+ 2因为你需要能够显示减号和空终止符但是其他部分背后的逻辑是什么?特别CHAR_BIT?