我计划从 ABI 拆分迁移到 App Bundle 功能。目前我正在使用这段代码:
def versionCodesAbi = ['x86': 1, 'x86_64': 2, 'armeabi-v7a': 3, 'arm64-v8a': 4]
splits {
abi {
enable true
reset()
include "x86", "x86_64", "armeabi-v7a", "arm64-v8a"
// "armeabi", "mips", "mips64" last three not needed and not supported currently
universalApk true
}
}
android.applicationVariants.all { variant ->
variant.outputs.each { output ->
def abi = versionCodesAbi.get(output.getFilter(OutputFile.ABI))
if (abi != null) {
output.versionCodeOverride =
abi * 1000 + variant.versionCode
}
}
}
每个 ABI 提供 4 个 APK(+ 通用 APK)。使用此代码的原因是为了减小应用程序大小,因为 PanoWidget (使用 NDK)和
renderscriptTargetApi 28
renderscriptSupportModeEnabled true
删除拆分配置(+4001 到 versionCode)并构建 Bundle 后,我得到了 .aab 文件,该文件转换为 .apks(使用 bundletool )包含文件夹 standalones/。我在里面有四种“类型”的 APK,分别用于 x86、x86_64、armeabi-v7a 和 arm64-v8a ABI。现在一切看起来都很好。
现在我注意到应用程序代码根本没有使用 RenderScript,所以我认为使用 supportMode 和 targetApi 是多余的.我已经删除了这两行,在设备/模拟器上进行了测试,一切正常。所以接下来我正在制作 Bundle,现在它在 .apks 存档中没有 x86_64 APK 版本......如果没有 RenderScript 支持,它应该被省略吗?我仍在使用 VrPanoramaView,它可能为每个 ABI 提供一些特定的 NDK 代码(在 GitHub 上看不到)...遗憾的是我没有用于测试的 x86(32 或 64)设备不,我害怕发布这个 bundle ...我是否缺少 smth,我什至需要 _64 版本吗?
最佳答案
编辑:
在 build.gradle 中删除这两个选项将删除 RenderScript 使用的 native 库:librsjni.so 和 libRSSupport.so。将为所有 ABI 删除这两个库。
由于禁用 RenderScript 后,您仍然有 3 个 ABI,看起来您的应用程序依赖于其他使用 native 代码的库,但不提供 x86_64 架构的库,这就是 x86_64 目录消失的原因。这可能意味着您的应用程序以前从未在 x86_64 上正常运行,因为平台会加载 x86_64 目录,但会丢失一些 native 库。
最终,您应该确定哪个库带来了这些 native 库,看看它们是否也可以构建 64 位版本,但在短期内,不会有任何问题,因为 x86_64 设备也支持 x86(32 位)库。
上一篇:
如果您的 APK 中有任何 *.bc 文件,64 位库将从 APK 中删除,因为这些 RenderScript 文件仅为 32 位,无法在 64 位中加载过程。
如果您迁移到更新版本的 RenderScript,将不会生成 *.bc 文件,并且 64 位 native 库将再次出现在 APK 中。或者,如果您根本不需要 RenderScript,则完全删除这些文件。
关于Android ABI 拆分迁移到 App Bundle,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54627154/
我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"
我从ui中得到日期范围为-approved_between"=>"2013-03-17-2013-03-18"我需要拆分此approved_start_date="2013-03-17"和approved_end_date="2013-03-18"...我希望使用它在mysql中查询,因为mysql中的日期格式是created_at:2012-07-2810:35:01.我正在做的是:approved=approved_between.split("")approved_start_date=approved[0]approved_end_date=approved[2]很确定这不是处
@locations=Location.all#currentlistingall@locations=Location.slice(5)orLocation.split(5)使用Ruby,我试图将我的列表分成4列,每列限制为5个;然而,切片或拆分似乎都不起作用。知道我可能做错了什么吗?任何帮助是极大的赞赏。 最佳答案 您可能想使用in_groups_of:http://railscasts.com/episodes/28-in-groups-of这是RyanBates在railscast中的示例用法:
我想在格式化数字时每隔三个字符放置一个空格。根据这个规范:it"shouldformatanamount"dospaces_on(1202003).should=="1202003"end我想出了这段代码来完成这项工作defspaces_onamountthousands=amount/1000remainder=amount%1000ifthousands==0"#{remainder}"elsezero_padded_remainder='%03.f'%remainder"#{spaces_onthousands}#{zero_padded_remainder}"endend所以我
给定一个数组:arr=[['a','1'],['b','2'],['c','3']]将它分成两个数组的最佳方法是什么?例如我想从上面的数组中得到以下两个数组:first=['a','b','c']second=['1','2','3']我可以使用collect来做到这一点吗? 最佳答案 好吧,我只是偶然发现了arr.transposearr=[['a','1'],['b','2'],['c','3']].transposefirst=arr[0]second=arr[1]与上面的答案arr.zip、arr.map、foreach相比
给定一个字符串:s="Good\r\nDay\r\n\r\n\r\nStack\r\n\r\nOverflow\r\n"我愿意:用(\r\n)+拆分,即我想得到:["Good","Day","Stack","Overflow"]我尝试了s.split(/(\r\n)+/)但它没有给我预期的结果。为什么?我怎样才能得到预期的结果?获取数组中\r\n的个数,即预期结果为:[1,3,2]你会怎么做?我使用Ruby1.9.2。 最佳答案 差不多了,试试这个:s.split/[\r\n]+/s.scan(/[\r\n]+/).map{|e|e
我有以下数组:a=["CH3","CH2"]我想使用正则表达式将其拆分为两个大写字母以显示:a=["C","H3","C","H2"]怎么做你这样做吗?到目前为止我已经尝试过:a.each{|array|x=array.scan(/[A-Z]*/)putsa}returns:CHCH提前致谢! 最佳答案 你可以试试这个:s.scan(/[A-Z][^A-Z]*/) 关于ruby-如何拆分两个大写字母?,我们在StackOverflow上找到一个类似的问题: h
我正在尝试找出最好的方法...给定一个字符串s="ifsomeBool||x==1&&y!=22314"我想用Ruby来分隔语句和bool运算符..所以我想把它分成["if","someBool","||","x","==","1","&&","y","!=","22314"]我可以使用s.split(),但这只会以空格作为分隔符进行拆分..但我也希望x!=y也被拆分(它们是有效的bool语句,它们之间没有空格可读性好)。当然,最简单的方法是要求用户在bool运算符和变量之间放置空格,但是还有其他方法可以做到这一点吗? 最佳答案 按
我有一个字符串:"hello\tWorld\nbla"我想把它拆分成:["hello\t","World\n","bla"]我如何在Ruby中执行此操作? 最佳答案 >>"hello\tWorld\nbla".scan/\S+\s*/=>["hello\t","World\n","bla"] 关于ruby-如何在ruby中拆分字符串并在拆分中维护空格,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com
我有一段代码试图用nokogiri解析,看起来像这样:Link1(info1),Blah1,Link2(info1),Blah1,Link3(info2),Blah1Foo2,我可以使用如下方式访问td.j的源代码:data_items=doc.css("td.j")我的目标是将每一行拆分成一个哈希数组。我能看到的唯一合乎逻辑的拆分点是拆分BR,然后在字符串上使用一些正则表达式。我想知道是否有更好的方法来做到这一点,也许只使用nokogiri?即使我可以使用nokogiri来提取3个行项目,它也会使我的事情变得更容易,因为我可以对.content结果进行一些正则表达式解析。但不确定如何