0

我正在创建一个应用程序来识别声波文件,为此我发现“Musicg”库就是为此目的。所以我只是在我的项目中编写了一个简单的代码来查看声音是否相似,但是当我运行项目时它崩溃了,然后我发现当程序来到指纹Similarity = wave.getFingerprintSimilarity(wave1); 然后它崩溃了,所以谁能告诉我我在哪里做错了什么?

这是我的简单代码

FingerprintSimilarity fingerprintSimilarity;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        Wave wave = new Wave("sampledata/cock_a_1.wav");
        Wave wave1 = new Wave("sampledata/cock_a_1.wav");

        fingerprintSimilarity = wave.getFingerprintSimilarity(wave1);


       float score = fingerprintSimilarity.getScore();
       float similarity = fingerprintSimilarity.getSimilarity();
       Log.d("hi","score :" +score+ "\n Similarity :" + similarity);


    }

它给了我这些错误:

03-24 23:42:41.984 2817-2817/com.example.fingerprint E/AndroidRuntime:致命异常:主进程:com.example.fingerprint,PID:2817 java.lang.RuntimeException:无法启动活动 ComponentInfo{com. example.fingerprint/com.example.fingerprint.MainActivity}:java.lang.NullPointerException:尝试在 android.app.ActivityThread 的空对象引用上调用虚拟方法“int com.musicg.wave.WaveHeader.getSampleRate()”。 performLaunchActivity(ActivityThread.java:2416) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 在 android.app.ActivityThread.-wrap11(ActivityThread.java) 在 android.app.ActivityThread$H.handleMessage(ActivityThread. java:1344) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:148) 在 android.app.ActivityThread.main(ActivityThread.java:5417) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java: 726)在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 引起:java.lang.NullPointerException:尝试调用虚拟方法'int com.musicg.wave.WaveHeader.getSampleRate()'在 com.musicg.wave.Wave.getFingerprint(Wave.java:329) 在 com.musicg.wave.Wave.getFingerprintSimilarity(Wave) 的 com.musicg.fingerprint.FingerprintManager.extractFingerprint(FingerprintManager.java:69) 的空对象引用.java:335) 在 com.example.fingerprint.MainActivity.onCreate(MainActivity.java:31) 在 android.app.Activity.performCreate(Activity.java:6237) 在 android。app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 在 android.app.ActivityThread.- wrap11(ActivityThread.java) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java :148) 在 android.app.ActivityThread.main(ActivityThread.java:5417) 在 java.lang.reflect.Method.invoke(Native Method) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java :726) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)1107) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 在 android.app.ActivityThread.-wrap11(ActivityThread.java) 在 android.app .ActivityThread$H.handleMessage(ActivityThread.java:1344) 在 android.app.ActivityThread 的 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:148)。 main(ActivityThread.java:5417) 在 java.lang.reflect.Method.invoke(Native Method) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal。 os.ZygoteInit.main(ZygoteInit.java:616)1107) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 在 android.app.ActivityThread.-wrap11(ActivityThread.java) 在 android.app .ActivityThread$H.handleMessage(ActivityThread.java:1344) 在 android.app.ActivityThread 的 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:148)。 main(ActivityThread.java:5417) 在 java.lang.reflect.Method.invoke(Native Method) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal。 os.ZygoteInit.main(ZygoteInit.java:616)ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 在 android.app.ActivityThread.-wrap11(ActivityThread.java) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 在 android.os.Handler.dispatchMessage( Handler.java:102) 在 android.os.Looper.loop(Looper.java:148) 在 android.app.ActivityThread.main(ActivityThread.java:5417) 在 java.lang.reflect.Method.invoke(Native Method)在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 在 android.app.ActivityThread.-wrap11(ActivityThread.java) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 在 android.os.Handler.dispatchMessage( Handler.java:102) 在 android.os.Looper.loop(Looper.java:148) 在 android.app.ActivityThread.main(ActivityThread.java:5417) 在 java.lang.reflect.Method.invoke(Native Method)在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:148) at android.app.ActivityThread.main(ActivityThread.java:5417) at java.lang.reflect.Method.invoke(Native方法)在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:148) at android.app.ActivityThread.main(ActivityThread.java:5417) at java.lang.reflect.Method.invoke(Native方法)在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 

4

0 回答 0