web-dev-qa-db-ja.com

致命的な信号6SIGABRTコード= -6

オーディオ信号を視覚化するためのAndroidプログラムを作成しています。主なアクティビティは次のとおりです。

package com.example.soundvisualizer;
import Android.os.Bundle;
import Android.app.Activity;
import Android.content.Context;
import Android.util.Log;
import Android.view.Display;
import Android.view.View;
import Android.view.View.OnClickListener;
import Android.widget.Button;
import Android.widget.Toast;

public class MainActivity extends Activity implements OnClickListener {
private CDrawer.CDrawThread mDrawThread;
private CDrawer mdrawer;
private Button btn;
private View.OnClickListener listener;
private Boolean m_bStart;
private Boolean recording;
private CSampler sampler;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    m_bStart = false;
    mdrawer = (CDrawer) findViewById(R.id.drawer);
    while (true){
        recording = false;
        run();    
        return; 
    }  
}

/**
 * Pause the visualizer when the app is paused
 */
@Override
protected void onPause(){
    System.out.println("onPause");
    sampler.SetRun(false);
    mDrawThread.setRun(false);
    sampler.SetSleeping(true);
    mDrawThread.SetSleeping(true);
    super.onPause();
}
/**
 * Resters the visualizer when the app restarts
 */
@Override
protected void onRestart(){
    m_bStart = true;
    System.out.println("onRestart");
    super.onRestart();
}
/**
 * Resume the visualizer when the app resumes
 */
@Override
protected void onResume(){
    System.out.println("onResume");
    int i = 0;
    while (true){
        if ((sampler.GetDead2()) && (mdrawer.GetDead2())){
            System.out.println(sampler.GetDead2() + ", " + mdrawer.GetDead2());
            sampler.Restart();
            if (!m_bStart.booleanValue())
                mdrawer.Restart(true);
            sampler.SetSleeping(false);
            mDrawThread.SetSleeping(false);
            m_bStart = false;
            super.onResume();
            return;
        }
        try{
            Thread.sleep(500L);
            System.out.println("Hang on..");
            i++;
            if (!sampler.GetDead2().booleanValue())
                System.out.println("sampler not DEAD!!!");
            if (!mdrawer.GetDead2().booleanValue()){
                System.out.println("mDrawer not DeAD!!");
                mdrawer.SetRun(false);
            }
            if (i <= 4)
                continue;
            mDrawThread.SetDead2(true);
        }
        catch (InterruptedException localInterruptedException){
            localInterruptedException.printStackTrace();
        }
    }   
}

@Override
protected void onStart(){
    System.out.println("onStart");
    super.onStart();
}

@Override
protected void onStop(){
    System.out.println("onStop");
    super.onStop();
}


/** 
 * Recives the buffert from the sampler
 * @param buffert
 */
public void setBuffer(short[] paramArrayOfShort){
    mDrawThread = mdrawer.getThread();
    mDrawThread.setBuffer(paramArrayOfShort);
}

/**
 * Called by OnCreate to get everything up and running
 */
public void run(){
    try {
        if (mDrawThread == null){
            mDrawThread = mdrawer.getThread();
        }
        if (sampler == null)
            sampler = new CSampler(this);
        Context localContext = getApplicationContext();
        Display localDisplay = getWindowManager().getDefaultDisplay();
        Toast localToast = Toast.makeText(localContext, "Please make some noise..", Toast.LENGTH_LONG);
        localToast.show();
        if (sampler != null){
            try {
                sampler.Init();
            } 
            catch (Exception e) {
                Toast.makeText(this,"Could not instance the sampler. Could not access the device audio-drivers", Toast.LENGTH_LONG).show();
            }
            btn = (Button) this.findViewById(R.id.button_stop);
            btn.setOnClickListener(this);
            sampler.StartRecording();
            sampler.StartSampling();
        }
      }
    catch (NullPointerException e) {
        Log.e("Main_Run", "NullPointer: " + e.getMessage());
    }
}

@Override
public void onClick(View v) {
    // TODO Auto-generated method stub
    if(btn.getText().equals("Start")){
        btn.setText("Stop");
        sampler.StartRecording();
        sampler.StartSampling();
    }
    else{
        btn.setText("Start");
        sampler.StopRecording();
    }
}

}

これで、アプリが起動し、正常に動作します。停止ボタンをクリックして大丈夫です。 [スタート]をもう一度クリックすると、再起動は正常に機能します。もう一度[停止]をクリックすると、アプリがクラッシュし、logcatにアプリを保護する次の行が表示されます。

I/ActivityManager(  755): START u0 {act=Android.intent.action.MAIN cat=[Android.intent.category.LAUNCHER] flg=0x10200000 cmp=com.example.soundvisualizer/.MainActivity} from pid 1054
I/ActivityManager(  755): Start proc com.example.soundvisualizer for activity com.example.soundvisualizer/.MainActivity: pid=6959 uid=10126 gids={50126}
I/ActivityManager(  755): Displayed com.example.soundvisualizer/.MainActivity: +710ms
W/ActivityManager(  755):   Force finishing activity com.example.soundvisualizer/.MainActivity
W/ActivityManager(  755): Exception thrown during pause
W/ActivityManager(  755): Android.os.DeadObjectException
W/ActivityManager(  755):   at Android.os.BinderProxy.transact(Native Method)
W/ActivityManager(  755):   at Android.app.ApplicationThreadProxy.schedulePauseActivity(ApplicationThreadNative.Java:660)
W/ActivityManager(  755):   at com.Android.server.am.ActivityStack.startPausingLocked(ActivityStack.Java:761)
W/ActivityManager(  755):   at com.Android.server.am.ActivityStack.finishActivityLocked(ActivityStack.Java:2455)
W/ActivityManager(  755):   at com.Android.server.am.ActivityStack.finishTopRunningActivityLocked(ActivityStack.Java:2329)
W/ActivityManager(  755):   at com.Android.server.am.ActivityStackSupervisor.finishTopRunningActivityLocked(ActivityStackSupervisor.Java:2035)
W/ActivityManager(  755):   at com.Android.server.am.ActivityManagerService.handleAppCrashLocked(ActivityManagerService.Java:9543)
W/ActivityManager(  755):   at com.Android.server.am.ActivityManagerService.makeAppCrashingLocked(ActivityManagerService.Java:9436)
W/ActivityManager(  755):   at com.Android.server.am.ActivityManagerService.crashApplication(ActivityManagerService.Java:10081)
W/ActivityManager(  755):   at com.Android.server.am.ActivityManagerService.handleApplicationCrashInner(ActivityManagerService.Java:9632)
W/ActivityManager(  755):   at com.Android.server.am.NativeCrashListener$NativeCrashReporter.run(NativeCrashListener.Java:86)
I/ActivityManager(  755): Config changes=480 {1.0 222mcc10mnc it_IT ldltr sw360dp w360dp h567dp 480dpi nrml port finger -keyb/v/h -nav/h s.583}
I/ActivityManager(  755): Process com.example.soundvisualizer (pid 6959) has died.
W/ActivityManager(  755): No content provider found for permission revoke: file:///data/local/tmp/SoundVisualizer.apk
W/ActivityManager(  755): No content provider found for permission revoke: file:///data/local/tmp/SoundVisualizer.apk
I/ActivityManager(  755): Force stopping com.example.soundvisualizer appid=10126 user=-1: uninstall pkg
I/ActivityManager(  755): Force stopping com.example.soundvisualizer appid=10126 user=-1: update pkg
I/ActivityManager(  755): Force stopping com.example.soundvisualizer appid=10126 user=0: pkg removed

エラーの原因とその修正方法がわかりません。誰か助けてもらえますか?前もって感謝します。

編集私が見つけた このリンク ここでは、エラーsigabrtのタイプが説明されています。この表は、-Xrsを使用してsigabrtを無効にできることを示しています。 Eclipse IDEで-Xrsを使用するにはどうすればよいですか?

11
bece

この場合、それは私に起こります:

  • ビューをonCreateでロードし、関数が非常に高速に呼び出された後、そのビューにアクセスします。

ビューはいつかnullになる可能性があります!!!

あなたの場合、そのビューにアクセスするたびにこれを入れてください:

if(mdrawer!=null){
   //DO Whatever
}else{
   Log.e(TAG,"Android BUG");
}

編集:関数が非常に高速に呼び出されたためではないことに気付きました。リスナーがあり、OnDestroy()のときに登録を解除しなかったためです。そして、OnCreateの場合、リスナーが2つありました。 NULLの結果ともう1つはOKです。

@Override
public void onDestroy() {                       
    super.onDestroy();
    if (mSensorManager!=null){mSensorManager.unregisterListener(listener);}
}
3
toni