Android Studio在API < 17上运行时出现验证错误

3

我正在将一个应用从Eclipse迁移到Android Studio,但在尝试在API小于17的模拟器上运行应用程序时遇到了验证错误。希望能得到任何有关如何处理此类问题的指导。以下是在API 8模拟器上logcat中显示的内容:

12-27 01:48:27.189 431-431/com.zigzagworld.icjl.tanachbible W/dalvikvm: VFY: register1 v10 type 12, wanted 10
12-27 01:48:27.189 431-431/com.zigzagworld.icjl.tanachbible W/dalvikvm: VFY:  rejecting opcode 0x70 at 0x005e
12-27 01:48:27.189 431-431/com.zigzagworld.icjl.tanachbible W/dalvikvm: VFY:  rejected Lcom/zigzagworld/fonts/GlyphMetrics;.<init> (SSS[S)V
12-27 01:48:27.189 431-431/com.zigzagworld.icjl.tanachbible W/dalvikvm: Verifier rejected class Lcom/zigzagworld/fonts/GlyphMetrics;

这紧接着就会导致应用程序崩溃并出现java.lang.VerifyError错误,这并不奇怪。同样的.apk文件在API 17及以上版本上运行良好。虽然在API 17及以上版本中有不同的代码路径,但无论API级别如何,GlyphMetrics类都会被使用。 (如果不同的代码路径可以影响一个类是否在加载时生成验证错误,请告诉我!)
GlyphMetrics类是一个非常简单的容器,用于存储我们在应用程序中使用的自制位图字体的一些度量信息:
package com.zigzagworld.fonts;

import static com.zigzagworld.fonts.Diacritics.LOWER_DIACRITIC;
import static com.zigzagworld.fonts.Diacritics.UPPER_DIACRITIC;

/**
 * Represents the layout metrics for a glyph.
 * 
 * @author Ted Hopp
 */
public final class GlyphMetrics {

    public static final short[] EMPTY_EXCLUSION = new short[0];
    public static final short[][] EMPTY_EXCLUSIONS = { EMPTY_EXCLUSION, EMPTY_EXCLUSION };
    /** The width of the glyph image, in pixels. */
    public short width;
    /** The height of the glyph image, in pixels. */
    public short height;
    /**
     * The distance in pixels between the top of the glyph image and the
     * baseline of the line. A positive value means that the top of the glyph
     * should be above the baseline of the line; a negative value means that the
     * top of the glyph should be below the baseline of the line.
     */
    public short baseline;
    /**
     * The upper and lower axes for placement of diacriticals. Each axis is the
     * distance from the left of the glyph image at which diacriticals should be
     * centered. (The formatting algorithm for the font may move diacriticals
     * from this position to avoid interference between glyphs.)
     */
    public short[] axes;
    /**
     * The upper and lower exclusion zone arrays. If there are <i>n</i> upper
     * (say) zones, the upper array has length length 2*<i>n</i>. The array has
     * the left edge of the first zone, the right edge of the first zone, the
     * left edge of the second zone, etc. The lower zone data are organized in
     * the same way.
     */
    public short[][] zones;

    public GlyphMetrics(short width, short height, short baseline, short[] layoutData) {
        this.width = width;
        this.height = height;
        this.baseline = baseline;
        axes = new short[2];
        width >>= 1; // for the rest of this, we need the half-width
        if (layoutData == null || layoutData.length == 0) {
            axes[UPPER_DIACRITIC] = axes[LOWER_DIACRITIC] = width;
            zones = EMPTY_EXCLUSIONS;
        } else {
            axes[UPPER_DIACRITIC] = layoutData[0];
            if (layoutData.length < 2) {
                axes[LOWER_DIACRITIC] = width;
            } else {
                axes[LOWER_DIACRITIC] = layoutData[1];
            }
            if (layoutData.length < 5) {
                zones = EMPTY_EXCLUSIONS;
            } else {
                int nUpper = layoutData[2] << 1;
                zones = new short[2][];
                zones[UPPER_DIACRITIC] = new short[nUpper];
                System.arraycopy(layoutData, 3, zones[UPPER_DIACRITIC], 0, nUpper);

                int lowerStart = 3 + nUpper;
                if (layoutData.length < 2 + lowerStart) {
                    zones[LOWER_DIACRITIC] = EMPTY_EXCLUSION;
                } else {
                    int nLower = layoutData[lowerStart++] << 1;
                    zones[LOWER_DIACRITIC] = new short[nLower];
                    System.arraycopy(layoutData, lowerStart, zones[LOWER_DIACRITIC], 0, nLower);
                }
            }
        }
    }
}

(导入的常量UPPER_DIACRITICLOWER_DIACRITIC分别是0和1。)我正在使用Android Studio 2.0 Preview 4和Gradle插件com.android.tools.build:gradle:2.0.0-alpha3以及JDK 1.7.0_80来构建这个项目。以下为.apk模块的build.gradle文件:
apply plugin: 'com.android.application'

android {
    compileSdkVersion 23
    buildToolsVersion '23.0.2'
    defaultConfig {
        applicationId "com.zigzagworld.icjl.tanachbible"
        minSdkVersion 8
        targetSdkVersion 23
        versionCode 10800310
        versionName "3.1.0"
        manifestPlaceholders = [
                appName: "App",
                v8TOCActivityName: "BaseTOCActivity",
                v8PurchaseActivityName: "PurchaseActivity",
                v17TOCActivityName: "TOCActivity",
                v17PurchaseActivityName: "PurchaseActivity",
        ]
    }
    signingConfigs {
        // redacted for this post
    }
    buildTypes {
        release {
            minifyEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            //noinspection GroovyAssignabilityCheck
            signingConfig // redacted
        }
    }
    flavorDimensions "market"
    productFlavors {
        google {
            dimension "market"
            manifestPlaceholders = [
                appName: "App_Google",
                v8TOCActivityName: "TOCActivity_Google",
                v8PurchaseActivityName: "GooglePurchaseActivity",
                v17TOCActivityName: "TOCActivity_Google",
                v17PurchaseActivityName: "GooglePurchaseActivity"
            ]
        }
        amazon {
            dimension "market"
            manifestPlaceholders = [
                appName: "App_Amazon",
                v8TOCActivityName: "BaseTOCActivity",
                v8PurchaseActivityName: "PurchaseActivity",
                v17TOCActivityName: "TOCActivity",
                v17PurchaseActivityName: "PurchaseActivity"
            ]
        }
        sideLoad {
            dimension "market"
            manifestPlaceholders = [
                    appName: "App_Unlicensed",
                    v8TOCActivityName: "BaseTOCActivity",
                    v8PurchaseActivityName: "PurchaseActivity",
                    v17TOCActivityName: "TOCActivity",
                    v17PurchaseActivityName: "PurchaseActivity"
            ]
        }
    }
}

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:23.1.1'
    compile 'com.android.support:support-annotations:23.1.1'
    compile project(':Tanach Data')
    googleCompile project(':Google Vending')
    amazonCompile project(':Amazon Vending')
}

问题出现在调试构建类型中,因此此时ProGuard不涉及其中。

也许这个链接的答案可以帮到你,这是我第一次看到VerifyError,所以我想尝试帮忙:https://dev59.com/TXVD5IYBdhLWcg3wE3Ro - JRowan
@JRowan - 我之前没有看到过那个特定的链接,但我看到了许多类似的链接。那里没有我没有尝试过的东西(清理项目,在build.gradle中添加sourceCompatibility JavaVersion.VERSION_1_7targetCompatibility JavaVersion.VERSION_1_7compileOptions块中,检查库版本,重新启动IDE等)。无论如何,还是谢谢。 - Ted Hopp
哦,我只是想把它放上来。我仍在使用 Eclipse,还没有切换到 Android Studio。我认为由于它仍然相对较新,也许这不是编程错误,而是 IDE 的问题。很抱歉这不是一个确定的线索 :( - JRowan
我注意到你有com.zigzagworld.fonts和com.zigzagworld.icjl.tanachbible,它们中有一个是库吗? - JRowan
1
在经过数天的努力后,我终于发现将Gradle插件从2.0.0-alpha3降级到1.5.0可以解决这个问题。 - Androiderson
显示剩余3条评论
1个回答

7

在花费多日的时间后,我终于发现将gradle插件版本从2.0.0-alpha3降级到1.5.0可以解决这个问题。

这就是我们尝试保持前沿技术所付出的代价。


谢谢!我想应该已经付清全款了。 :-/ - Ted Hopp

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接