我看到几个类似的问题,如:
但我觉得我的问题不同了.
首先我使用:
机器人:sharedUserId = "android.uid.system"
所以我需要用平台密钥签署我的应用程序.我能用这种方式做到这一点:
cd $ANDROID_ROOT/out/host/linux-x86/framework
java -Djava.library.path=$ANDROID_ROOT/out/host/linux-x86/lib64 -jar signapk.jar $ANDROID_ROOT/build/target/product/security/platform.x509.pem $ANDROID_ROOT/build/target/product/security/platform.pk8 $APP_DIR/app/build/outputs/apk/debug/app-debug.apk $APP_DIR/MyApp-signed.apk
Run Code Online (Sandbox Code Playgroud)
但是我想从gradle进行签名,所以我用这种方式生成了jks文件:
./keytool-importkeypair -k my_keystore.jks -p my_password -pk8 $ANDROID_ROOT/build/target/product/security/platform.pk8 -cert $ANDROID_ROOT/build/target/product/security/platform.x509.pem -alias platform
Run Code Online (Sandbox Code Playgroud)
我已经修改app/build.gradle了:
signingConfigs {
release {
storeFile file("my_keystore.jks")
storePassword "my_password"
keyAlias "platform"
keyPassword "my_password"
}
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
signingConfig signingConfigs.release
}
}
Run Code Online (Sandbox Code Playgroud)
我已经检查过my_keystore.jks有平台别名:
keytool -list -v -keystore my_keystore.jks | grep Alias
Alias name: platform
Run Code Online (Sandbox Code Playgroud)
但是当我尝试做的时候:
./gradlew …
Run Code Online (Sandbox Code Playgroud) 它困扰了我一段时间,但我还没有找到任何令人信服的答案,那么为什么hashCode
Java String 中的函数没有任何大小限制呢?以下是我在这里找到的实现:
public int hashCode() {
int h = hash;
if (h == 0 && value.length > 0) {
char val[] = value;
for (int i = 0; i < value.length; i++) {
h = 31 * h + val[i];
}
hash = h;
}
return h;
}
Run Code Online (Sandbox Code Playgroud)
首先,我了解临时变量的用法h
,这在多线程中使用字符串时很有意义。其次,我们都知道上述实现无法避免哈希冲突(没有 hashCode 实现可以),所以基本上我们应该仅将此函数视为“性能改进”,这对于哈希表或类似结构很有用。
如果是这样,那么为什么允许我们有 100 MB 字符串并且我们基于所有它的字符计算哈希的情况?添加一些限制不是更有意义吗?32 / 128 甚至 1024 个字符,但不是整个 value.length?是的,如果我们有两个具有相同前缀的不同字符串,只要我们的限制那么长,那么我们就会发生哈希冲突,但无论如何我们都无法避免冲突,所以从性能的角度来看,我个人会将 for 循环更改为如下所示:
int limit = value.length …
Run Code Online (Sandbox Code Playgroud)