2013-05-18 2 views
20

Я потратил часы, пытаясь получить библиотеку для работы с моим проектом в Android Studio, и я просто не могу понять это.NoClassDefFoundError с библиотеками в Android Studio

Вот что мои зависимости выглядеть для моего модуля enter image description here

И мои библиотеки: http://i.imgur.com/t8E3sB8.png

Я даже добавил

compile files('libs/signpost-commonshttp4-1.2.1.2.jar') 
compile files('libs/signpost-core-1.2.1.2.jar') 

моему build.gradle , Без этого приложение даже не будет компилироваться.

На этом этапе, когда я пытаюсь ссылаться на одну из библиотек в коде, приложение выходит из строя с исключением NoClassDefFoundError.

Что-то подсказывает мне, что этого не должно быть так сложно - чего я не замечаю?

LogCat:

05-17 21:51:15.676: I/ActivityManager(714): START u0 {flg=0x10104000 cmp=com.crazydog.splitwiser/.InitialSplash bnds=[328,402][656,692]} from pid 1513 
05-17 21:51:15.896: I/ActivityManager(714): Start proc com.crazydog.splitwiser for activity com.crazydog.splitwiser/.InitialSplash: pid=18174 uid=10288 gids={50288, 3003, 1028} 
05-17 21:51:16.326: I/ActivityManager(714): Displayed com.crazydog.splitwiser/.InitialSplash: +437ms (total +1m9s209ms) 
05-17 21:51:17.017: I/ActivityManager(714): START u0 {cmp=com.crazydog.splitwiser/.LogIn} from pid 18174 
05-17 21:51:17.097: E/dalvikvm(18174): Could not find class 'oauth.signpost.commonshttp.CommonsHttpOAuthConsumer', referenced from method com.crazydog.splitwiser.Toolkit.oAuthTransaction 
05-17 21:51:17.097: W/dalvikvm(18174): VFY: unable to resolve new-instance 662 (Loauth/signpost/commonshttp/CommonsHttpOAuthConsumer;) in Lcom/crazydog/splitwiser/Toolkit; 
05-17 21:51:17.097: D/dalvikvm(18174): DexOpt: unable to opt direct call 0x112f at 0x08 in Lcom/crazydog/splitwiser/Toolkit;.oAuthTransaction 
05-17 21:51:17.107: E/AndroidRuntime(18174): at com.crazydog.splitwiser.Toolkit.oAuthTransaction(Toolkit.java:65) 
05-17 21:51:17.107: E/AndroidRuntime(18174): at com.crazydog.splitwiser.LogIn.onResume(LogIn.java:116) 
05-17 21:51:17.117: W/ActivityManager(714): Force finishing activity com.crazydog.splitwiser/.LogIn 
05-17 21:51:17.117: W/ActivityManager(714): Force finishing activity com.crazydog.splitwiser/.InitialSplash 
05-17 21:51:17.618: W/ActivityManager(714): Activity pause timeout for ActivityRecord{40d040d0 u0 com.crazydog.splitwiser/.LogIn} 
+0

Опубликовать свой логарифм – moDev

+0

Я добавил его к сообщению. – jhirsch

+0

действительно ли я полагаюсь на http? – Blundell

ответ

29

У меня была точно такая же проблема, А как ты я думал, что это достаточно, чтобы добавить

compile files('libs/signpost-commonshttp4-1.2.1.2.jar') 
compile files('libs/signpost-core-1.2.1.2.jar') 

Все работало после того, как я сделал ./gradlew clean (я на маке, так что в вашем случае эквивалент.) Вы должны сделать эту команду из командной строки Terminal/Command, когда вы находитесь в корне вашего проекта.

+1

Очень полезно, спасибо! Работает над окнами 8, называющими «gradle clean» в proj директоре. –

+0

Ох, спасибо, очень много ... это заняло у меня 4 часа! <3 <3 - (в качестве пользователя Mac вы можете установить град, используя «гравюру установки», - если у вас нет варить GET IT! –

+3

Очень странно, что gradlew clean работает в то время как Build -> Project clean не работает ... –

Смежные вопросы