Программа не блокирует, просто очень, очень медленная и неэффективная. Он использует 100% CPU. Проблема в if (mTail.available() >= mByteSlave.length)
- в большинстве случаев это возвращает false, и вы получаете занятый цикл в этом потоке Если вы можете избавиться от этого, сделайте это. Тогда эта проблема решена. Если вы не можете, это становится сложнее ...
Есть еще одна проблема: PipedInputStream.read
возвращает int. Вам необходимо использовать:
int len = mTail.read(mByteSlave, 0, mByteSlave.length);
mAudioTrack.write(mByteSlave, 0, len);
Кроме этого, я не смог найти ничего плохого в этом коде. Мой полный тестовый пример выглядит так:
import java.io.*;
public class Test2 {
PipedOutputStream mHead;
PipedInputStream mTail;
byte[] mByteSlave = new byte[1024];
boolean mStop;
public static void main(String... ar) throws Exception {
new Test2().run();
}
void run() throws Exception {
mTail = new PipedInputStream();
mHead = new PipedOutputStream(mTail);
Thread mT1 = new Thread(new DecoderTask(), "Reader");
Thread mT2 = new Thread(new WriteTask(), "Writer");
mT1.start();
mT2.start();
}
class DecoderTask implements Runnable {
public void run() {
while (!mStop) {
try {
mHead.write(new byte[3000]);
mHead.flush();
System.out.println("decoded 3000");
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
class WriteTask implements Runnable {
public void run() {
while (!mStop) {
try {
int len = mTail.read(mByteSlave, 0, mByteSlave.length);
if (len < 0) break; // EOF
// mAudioTrack.write(mByteSlave, 0, len);
// mAudioTrack.flush();
System.out.println("written " + len);
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}