Проблема запуска тяжелого приложения - PullRequest
0 голосов
/ 18 августа 2010

Я разработал «тяжелое» приложение (700 Мб!). С помощью приложения "apk installer" я могу установить его на SD-карту Nexus One (опция Froyo "installLocation"). Мое приложение тяжело из-за видео, которое оно содержит (находится в каталоге / raw). Проблема, с которой я столкнулся, заключается в том, что при запуске происходит сбой с этой ошибкой:

08-18 11:22:16.179: ERROR/AndroidRuntime(1250): FATAL
> > EXCEPTION: main 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):
> > java.lang.RuntimeException: Unable to
> > instantiate activity
> > ComponentInfo{com.test.media/com.test.media.Welcome}:
> > java.lang.ClassNotFoundException:
> > com.test.media.Welcome in loader
> > dalvik.system.PathClassLoader[/mnt/asec/com.test.media-1/pkg.apk]
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.app.ActivityThread.access$2300(ActivityThread.java:125)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.os.Handler.dispatchMessage(Handler.java:99)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.os.Looper.loop(Looper.java:123)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.app.ActivityThread.main(ActivityThread.java:4627)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > java.lang.reflect.Method.invokeNative(Native
> > Method) 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > java.lang.reflect.Method.invoke(Method.java:521)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > dalvik.system.NativeStart.main(Native
> > Method) 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250): Caused by:
> > java.lang.ClassNotFoundException:
> > com.test.media.Welcome in loader
> > dalvik.system.PathClassLoader[/mnt/asec/com.test.media-1/pkg.apk]
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > java.lang.ClassLoader.loadClass(ClassLoader.java:573)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > java.lang.ClassLoader.loadClass(ClassLoader.java:532)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.app.Instrumentation.newActivity(Instrumentation.java:1021)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     at
> > android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577)
> > 08-18 11:22:16.179:
> > ERROR/AndroidRuntime(1250):     ... 11
> > more

Я не понимаю причину этой ошибки, потому что, когда я пытаюсь сделать то же самое с более легким приложением (250 Мб), оно работает отлично. Кто-нибудь из вас когда-либо сталкивался с такой проблемой? Знаете ли вы, есть ли ограничение на размер приложений для работы?

Спасибо за вашу помощь!

Ответы [ 4 ]

0 голосов
/ 18 августа 2010

Почему бы не сохранить приложение легким и загружать видео после первого запуска приложения. Как и старый Doom для Android, когда Id его забрали.

0 голосов
/ 18 августа 2010

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

0 голосов
/ 18 августа 2010

Может быть, предел ... вы можете, например, транслировать видео в прямом эфире, используя лучший кодек, разрешение не такое высокое, как у телефона / планшета, где вы, например, Но на самом деле я ничего не читал об ограничении размера.

Так что в противном случае я читаю ClassNotFoundException. Что произойдет, если вы удалите все дальнейшие методы и вызовы основного метода onCreate () и просто дадите разобрать свой макет? Если это работает, ошибка где-то еще. Если он все еще что-то выбрасывает, постарайтесь уменьшить макет как можно меньше. И если это не сработает, тогда ... тогда есть предел, и вы его нашли;)

0 голосов
/ 18 августа 2010

Ошибка:

java.lang.ClassNotFoundException: com.test.media.Welcome

Если вы удалите несколько видео, это работает? Также с SD-карты?

Если вы хотите проверить, существует ли класс, вы можете распаковать apk и проверить, действительно ли файл находится там.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...