Я получаю сообщение об ошибке Couldn't load memtrack module (No such file or directory) failed to load memtrack module: -2
во время выполнения.
Ошибка StackTrace:
E/SoundPool(1280) : error loading /system/media/audio/ui/Effect_Tick.ogg
E/SoundPool(1280) : error loading /system/media/audio/ui/KeypressStandard.ogg
E/SurfaceFlinger(931) : glCheckFramebufferStatusOES error 733995180
E/memtrack(1873) : Couldn't load memtrack module (No such file or directory)
E/android.os.Debug(1873): failed to load memtrack module: -2
E/libEGL(931) : called unimplemented OpenGL ES API
E/libEGL(931) : called unimplemented OpenGL ES API
E/libEGL(931) : called unimplemented OpenGL ES API
E/libEGL(931) : called unimplemented OpenGL ES API
E/SurfaceFlinger(931) : glCheckFramebufferStatusOES error 733995180
E/SurfaceFlinger(931) : got GL_FRAMEBUFFER_COMPLETE_OES error while taking screenshot
E/libEGL(931) : called unimplemented OpenGL ES API
E/libEGL(931) : called unimplemented OpenGL ES API
Манифест:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.hive"
android:versionCode="1"
android:versionName="1.0">
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="19" />
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" android:name="com.sit.gems.app.GemsApplication"
android:theme="@style/AppTheme" >
<activity
android:name="com.sit.gems.activity.SplashActivity"
android:label="@string/app_name" android:screenOrientation="portrait">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name="com.sit.gems.activity.HomeActivity" android:screenOrientation="portrait"></activity>
</application>
</manifest>
SplashActivity.java:
package com.sit.gems.activity;
import com.example.hive.R;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
public class SplashActivity extends FragmentActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.layout_home);
startActivity(new Intent(SplashActivity.this,HomeActivity.class));
SplashActivity.this.finish();
}
}
layout_home.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TabHost
android:id="@android:id/tabhost"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_above="@android:id/tabs" >
<FrameLayout
android:id="@+id/tab_home"
android:layout_width="fill_parent"
android:layout_height="fill_parent" />
<FrameLayout
android:id="@+id/tab_video"
android:layout_width="fill_parent"
android:layout_height="fill_parent" />
<FrameLayout
android:id="@+id/tab_audio"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
</FrameLayout>
<FrameLayout
android:id="@+id/tab_blog"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
</FrameLayout>
<FrameLayout
android:id="@+id/tab_gal"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
</FrameLayout>
<FrameLayout
android:id="@+id/tab_more"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
</FrameLayout>
</FrameLayout>
<TabWidget
android:id="@android:id/tabs"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:background="@drawable/bottom_bar"
android:divider="@null" />
<!-- android:background="#d8e49c" -->
</RelativeLayout>
</TabHost>
</LinearLayout>
Вывод:
Наконец, отображается пустой экран.
Кто-нибудь знает, как решить эти ошибки?
android
logcat
stack-trace
Стив
источник
источник
Ответы:
Эта ошибка, как вы можете прочитать по вопросу, указанному в комментариях выше , приводит к следующему:
Шаг 1 ниже должен решить эту проблему. Кроме того, как я вижу, в вашем манифесте есть несколько странных имен пакетов:
<manifest>
теге,<application>
<activity>
Как вы знаете, эти вещи не мешают отображению вашего приложения. Но я думаю:
Для лучшего использования и с некоторыми вещами эту проблему можно решить, следуя этим советам:
1. Попробуйте другой эмулятор ...
И даже настоящий прибор!
memtrack module
Ошибка , кажется , связана с эмулятором. Так что измените его наRun configuration
, не забудьте также изменитьAPI
.2. Журналы ошибок OpenGL
Для
OpenGl
ошибок, какcalled unimplemented OpenGL ES API
, это не ошибка, а утверждение! Вы должны включить его в своем манифесте (вы можете прочитать этот ответ, если используете GLSurfaceView внутриHomeActivity.java
, это может вам помочь):<uses-feature android:glEsVersion="0x00020000"></uses-feature> // or <uses-feature android:glEsVersion="0x00010001" android:required="true" />
3. Используйте тот же пакет
Не объявляйте разные имена пакетов для всех тегов в
Manifest
. Вы должны иметь то же самое дляManifest
,Activities
и т.д. Что - то вроде этого выглядит правильно:<!-- set the general package --> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.sit.gems.activity" android:versionCode="1" android:versionName="1.0" > <!-- don't set a package name in <application> --> <application ... > <!-- then, declare the activities --> <activity android:name="com.sit.gems.activity.SplashActivity" ... > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <!-- same package here --> <activity android:name="com.sit.gems.activity.HomeActivity" ... > </activity> </application> </manifest>
4. Не заблудитесь с макетами:
Вам следует установить другой макет,
SplashScreenActivity.java
потому что вы не используете егоTabHost
для экрана-заставки, и это небезопасный ресурсный способ. Объявите конкретный макет с чем-то другим, например, с названием приложения и логотипом:// inside SplashScreen class setContentView(R.layout.splash_screen); // layout splash_screen.xml <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center" android:text="@string/appname" />
Избегайте использования макета в действиях, в которых он не используется.
5. Заставка?
Наконец, я не совсем понимаю цель вашего
SplashScreenActivity
. Он устанавливает вид содержимого и сразу завершает. Это бесполезно.Поскольку он называется Splash Screen , я предполагаю, что вы хотите отобразить экран перед запуском вашего
HomeActivity
. Следовательно, вы должны сделать это и не использоватьTabHost
макет;) :// FragmentActivity is also useless here! You don't use a Fragment into it, so, use traditional Activity public class SplashActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // set your splash_screen layout setContentView(R.layout.splash_screen); // create a new Thread new Thread(new Runnable() { public void run() { try { // sleep during 800ms Thread.sleep(800); } catch (InterruptedException e) { e.printStackTrace(); } // start HomeActivity startActivity(new Intent(SplashActivity.this, HomeActivity.class)); SplashActivity.this.finish(); } }).start(); } }
Я надеюсь, что такие советы помогут вам достичь желаемого.
Если это не так, дайте мне знать, чем я могу вам помочь.
источник
TabHost in layout_home.xml
У меня была такая же ошибка. Создание нового AVD с соответствующим уровнем API решило мою проблему.
источник
Я столкнулся с той же проблемой, но когда я изменил скин устройства AVD на HVGA, он работал.
источник
вы вызвали ViewTreeObserver и не удалили его.
mEtEnterlive.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() { // do nothing here can cause such problem });
источник
У меня тоже была эта проблема, тоже работающая на эмуляторе. Такое же сообщение отображалось в Logcat, но это не влияло на функциональность приложения. Но это раздражало, и мне не нравится видеть в журнале ошибки, которые я не понимаю.
Все равно избавился от сообщения, увеличив ОЗУ на эмуляторе.
источник