构建不能识别产品风格的types特定的文件夹

我已经配置我的项目有多个产品口味。 我在我的模块build.gradle有以下代码: android { // Rest of the configuration omitted for clarity buildTypes { debug { // … } release { // … } } productFlavors { paid free } } 如果我在paid , free , debug或release创建了一个文件(任何文件:Java,资源……),它就被Android Studio认可了,我可以在我的项目中使用它。 但是,如果在paidDebug (或类似的文件夹)中创建了相同的文件,则在Android Studio中无法识别该文件。 我需要任何额外的配置来运作吗? 这是不支持(还)?

什么是Kotlin的“接收器”?

这与扩展function有什么关系? 为什么with 一个函数而不是一个关键字? 似乎没有这个主题的明确文件,只是关于扩展的知识假设。

为什么试图访问常量值的问题没有解决?

该应用程序在Kotlin单例对象中定义常量: @file:JvmName(“APIConstants”) package com.myapp.api object APIConstants { const val HTTP_RESPONSE_CODE_NOT_AUTHORIZED = 401 etc…. } 然后他们被用于另一个class级: import com.myapp.api.APIConstants.HTTP_RESPONSE_CODE_NOT_AUTHORIZED etc … class API { private fun returnBadResponse(response: Response, callback: ApiAuthListener) { if (response.code() == HTTP_RESPONSE_CODE_NOT_AUTHORIZED) { callback.onBadAuthToken() } else { callback.onFailure(response.message(), getServerError(response)) } } 在这个类中,Android Studio(3.0 beta)提供了一个为常量添加导入的提示,并没有给出任何问题的指示(没有红色下划线等,方法中的常量引用以紫色斜体文本显示它已经解决了)但是当我建立这个项目时,我得到了这个: Error: Unresolved reference: HTTP_RESPONSE_CODE_NOT_AUTHORIZED 我已经尝试清除IDE缓存并重新启动它,并做一个干净的构建,这没有什么区别。 我已经尝试删除@JvmName注释,甚至将常量值放在没有包含对象的文件的根目录中,但是不允许构建。 为什么类没有引用这个常量,特别是当IDE强烈建议它可以解决这个问题的时候呢?

如何通过reflection运行挂起方法?

有一个协程块可以运行暂停function。 但我通过reflectioninvoke函数。 这是java风格的调用,显然一个简单的调用是行不通的。 有没有办法异步运行reflection的方法? 如何等待这个方法? import kotlin.coroutines.experimental.* class TestClass(val InString: String) { suspend fun printString() { println(InString) } } fun launch(context: CoroutineContext, block: suspend () -> Unit) = block.startCoroutine(StandaloneCoroutine(context)) private class StandaloneCoroutine(override val context: CoroutineContext): Continuation { override fun resume(value: Unit) {} override fun resumeWithException(exception: Throwable) { val currentThread = Thread.currentThread() currentThread.uncaughtExceptionHandler.uncaughtException(currentThread, exception) } } […]

实例化新的Android Fragment的最佳做法

我已经看到了两个通用实践来在应用程序中实例化一个新的片段: Fragment newFragment = new MyFragment(); 和 Fragment newFragment = MyFragment.newInstance(); 第二个选项使用静态方法newInstance() , 通常包含以下方法。 public static Fragment newInstance() { MyFragment myFragment = new MyFragment(); return myFragment; } 起初,我认为主要的好处是,我可以重载newInstance()方法来创建一个Fragment的新实例时的灵活性 – 但是我也可以通过为Fragment创建一个重载的构造函数来实现。 我错过了什么? 一种方法比另一种方法有什么好处? 或者这只是一个好习惯?

Dart2Js,但可读

有人知道是否有一种方法来编译一个用Dart写成JS的库。 但在某种程度上,使生成的代码看起来像手写或非常接近它? 我想写一个扑翼的应用程序,并与网络团队分享业务逻辑。 我不想强迫任何人使用Dart。 现在,在我看来,JavaScript的飞镖的方式工作正常,但返回到JavaScript的方式不起作用。 我感觉就像一条单向的路。 如果有人certificate我错了,可以certificateDart可以与JS交互并向后兼容,如Kotlin与Java Thx为您的答案; D

Firebase-Firestore不能同时加载2个文档的信息

早上好 所以,我可以从我的Firebase文档和集合中加载信息,在某种程度上… 当我的collections有1个文件,一切都顺利。 当它有一个以上的文件,那么,应用程序中断。 所以,我有这个: db.collection(“KitListCategorie”).get().addOnSuccessListener { snapshot -> for (document1 in snapshot.documents) { val data1 = document1.data val weights = data1[“categoryName”] as String val misc = data1[“categoryName”] as String categorySpinnerArray.add(weights) categorySpinnerArray.add(misc) } categorySpinnerArrayAdapter.notifyDataSetChanged() } 对于此Firestore设置: https : //imgur.com/a/pmBcE 然后我得到这个错误: kotlin.TypeCastException: null cannot be cast to non-null type kotlin.String 我究竟做错了什么? 谢谢

不能在Kotlinunit testing(ExecutionException,Aapt2Exception)

一个简单的测试… import org.junit.Test class KotlinUnitTest { @Test fun test() { assert(true) } } …结果如下… Information:Gradle: Executing tasks: [:app:assembleDebug, :app:assembleDebugUnitTest] Information:Kotlin: Kotlin JPS plugin is disabled Information:Module “app” was fully rebuilt due to project configuration/dependencies changes Information:06/12/2017 5:08 PM – Compilation completed with 3 errors and 0 warnings in 19s 962ms Error:Gradle: java.util.concurrent.ExecutionException: java.util.concurrent.ExecutionException: com.android.tools.aapt2.Aapt2Exception: AAPT2 […]

‘when’语句跳过Android的Kotlin条件

我一直在使用kotlin在android studio canary 5上开发应用程序。 我正在使用when语句来validationregistry单是否有效。 else if(registering) when { email.text == null -> email.error = “Enter Email!” !isValidEmail(email.text) -> email.error = “Invalid Email!” password.text == null -> password.error = “Enter Password!” password_conf.text == null -> password_conf.error = “Re-enter Password!” password_conf.text.toString() != password.text.toString() -> password_conf.error = “Re-enter Password!” password_conf.text.toString() != password.text.toString() -> password_conf.error = “Passwords Don’t […]

将Kotlin的KClass转换为Java中的常规类

我正在尝试从Kotlin调用一个常规的Java方法,如下所示: public T proxy(KClass kClass) { // unfortunately nothing like getJavaClass() exists return (T) proxy(kClass.getJavaClass()); } public T proxy(Class jClass) { return (T) context.getBean(jClass); } 在Kotlin中,您可以在每个KClass上调用.java 。 这不是这种情况,我无法从KClass中提取Java类对象。 有没有办法做到这一点?