ClassNotFoundException: could not find class "android.databinding.DataBinderMapper"

I am using android data binding library for views in library project

I added the following line to my gradle root file

classpath 'com.android.databinding:dataBinder:1.0-rc1'

and enable data binding, as described below in the gradle file module

apply plugin: 'com.android.databinding'
...
...
android {
....
  dataBinding {
      enabled = true
  }
}

I have included the multiDex project in my library as well as in the main application that uses this library but I get this stack trace error when starting library activity

java.lang.NoClassDefFoundError: Failed resolution of: Landroid/databinding/DataBinderMapper;
    at android.databinding.DataBindingUtil.<clinit>(DataBindingUtil.java:31)
    at sdk.ui.activities.MyActivity.onCreate(MyActivity.java:76)
    at android.app.Activity.performCreate(Activity.java:6280)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1116)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2534)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2647)
    at android.app.ActivityThread.-wrap11(ActivityThread.java)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1502)
    at android.os.Handler.dispatchMessage(Handler.java:111)
    at android.os.Looper.loop(Looper.java:207)
    at android.app.ActivityThread.main(ActivityThread.java:5763)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:888)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
Caused by: java.lang.ClassNotFoundException: Didn't find class "android.databinding.DataBinderMapper" on path: DexPathList[[zip file "/data/app/testApp.dev-1/base.apk"],nativeLibraryDirectories=[/data/app/testApp.dev-1/lib/arm64, /data/app/testApp.dev-1/base.apk!/lib/arm64-v8a, /vendor/lib64, /system/lib64]]
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
    at android.databinding.DataBindingUtil.<clinit>(DataBindingUtil.java:31) 
    at sdk.ui.activities.MyActivity.onCreate(MyActivity.java:76) 
    at android.app.Activity.performCreate(Activity.java:6280) 
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1116) 
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2534) 
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2647) 
    at android.app.ActivityThread.-wrap11(ActivityThread.java) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1502) 
    at android.os.Handler.dispatchMessage(Handler.java:111) 
    at android.os.Looper.loop(Looper.java:207) 
    at android.app.ActivityThread.main(ActivityThread.java:5763) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:888) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749) 
Suppressed: java.lang.ClassNotFoundException: android.databinding.DataBinderMapper
    at java.lang.Class.classForName(Native Method)
    at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
    at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
        ... 15 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available
+4
source share
6 answers

Finally, I was able to solve this problem. There seems to be a conflict between the apt version of the application modules and the library.

updated the apt version in the application to

classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
+3

, , DataBinding, . .

android {
    ....
    dataBinding {
        enabled = true
    }
}
+5

. android-apt

, apt

apt 'lt.mdm.sdd:myLib:1.5.1' annotationProcessor 'lt.mdm.sdd:myLib:1.5.1'.

, , , .

( , androidannotations.org apt).

, apply plugin: 'com.android.databinding'? .

+2

build.gradle:

android {
    dataBinding {
        enabled = true
    }
}

:

dependencies {
    kapt 'com.android.databinding:compiler:3.0.1'
}
+1

classpath 'com.android.databinding: dataBinder: 1.0-rc1'

: 'com.android.databinding'

lib. gradle.

0

,

classpath 'com.neenbedankt.gradle.plugins: android-apt: 1.8'

build.gradle

: 'android-apt'

build.gradle, .

It seems to have been a mixed issue with Butterknife. Pretty strange.

0
source

Source: https://habr.com/ru/post/1662371/


All Articles