I am doing code for calculating bpm for media files. my requirement is i have to play song only for 5 seconds not more than 5 seconds. so i use Thread.sleep(5000) and i call handler message. it throws java.long.stackoverflowexception.
my code:
currentThread.start();
....
public void run() {
try {
Log.e("bpm", "in run method");
BPM2SampleProcessor processor = new BPM2SampleProcessor();
processor.setSampleSize(1024);
EnergyOutputAudioDevice output = new EnergyOutputAudioDevice(processor);
output.setAverageLength(1024);
try {
player = new Player(new FileInputStream("/sdcard/taxi.mp3"), output); // line no 40
currentThread.run(); // line no 41
player.play();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (JavaLayerException e) {
e.printStackTrace();
}
text.setText("bpm is "+processor.getBPM());
Log.e("bpm"," bpm is "+processor.getBPM());
Thread.sleep(5000);
threadHandler.sendEmptyMessage(0);
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
private Handler threadHandler = new Handler()
{
public void handleMessage(android.os.Message msg)
{
Log.e("calledThread","5seconds");
player.close();
}
};
log cat:
05-20 18:05:01.761: ERROR/AndroidRuntime(2777): Uncaught handler: thread Thread-8 exiting due to uncaught exception
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): java.lang.StackOverflowError
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.nio.HeapByteBuffer.<init>(HeapByteBuffer.java:49)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.nio.HeapByteBuffer.<init>(HeapByteBuffer.java:45)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.nio.ReadWriteHeapByteBuffer.<init>(ReadWriteHeapByteBuffer.java:49)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.nio.BufferFactory.newByteBuffer(BufferFactory.java:51)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.nio.ByteBuffer.allocate(ByteBuffer.java:54)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.nio.charset.CharsetEncoder.encode(CharsetEncoder.java:351)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.nio.charset.Charset.encode(Charset.java:711)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.lang.String.getBytes(String.java:1022)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at org.apache.harmony.luni.util.Util.getBytes(Util.java:61)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.io.File.properPath(File.java:1362)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.io.FileInputStream.<init>(FileInputStream.java:77)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.io.FileInputStream.<init>(FileInputStream.java:130)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at beatit.beatit.main2.run(main2.java:40)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.lang.Thread.run(Thread.java:1096)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at beatit.beatit.main2.run(main2.java:41)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.lang.Thread.run(Thread.java:1096)
05-20 18:05:02.237: ERROR/AndroidRuntime(2777): at java.la
05-20 18:05:05.573: ERROR/Java开发者_Python百科Binder(1276): !!! FAILED BINDER TRANSACTION !!!
Your thread calling the run method over and over again, causing a stackoverflow:
currentThread.run();
There is no condition to stop that. (Just to make it clear, currentThread.start()
calls the run method in some stage)
You almost answered yourself:
currentThread.run(); // line no 41
Below I wrote example how to deal with your problem:
AsyncTask<Void, Void, Void> task = new AsyncTask<Void, Void, Void>() {
@Override
protected Void doInBackground(Void... params) {
//put your code here
}
};
try {
task.execute((Void)null).get(5, TimeUnit.SECONDS);
} catch(Exception e) {
e.printStackTrace();
}
精彩评论