Поведение PeekMessageW задокументировано:
Во время этого вызова система доставляет ожидающие сообщения без очереди, то есть сообщения, отправленные в окна, принадлежащие вызывающему потоку, SendMessage , SendMessageCallback , SendMessageTimeout или SendNotifyMessage . Затем извлекается первое сообщение в очереди, соответствующее указанному фильтру.
blockquote>Сообщения и очереди сообщений объясняет терминологию, а также основные принципы.
Чтение из входного потока и запись в ByteArrayOutputStream, затем вызов его toByteArray()
для получения массива байтов.
Создайте ByteArrayInputStream вокруг массива байтов для чтения из него.
Вот быстрый тест:
import java.io.*;
public class Test {
public static void main(String[] arg) throws Throwable {
File f = new File(arg[0]);
InputStream in = new FileInputStream(f);
byte[] buff = new byte[8000];
int bytesRead = 0;
ByteArrayOutputStream bao = new ByteArrayOutputStream();
while((bytesRead = in.read(buff)) != -1) {
bao.write(buff, 0, bytesRead);
}
byte[] data = bao.toByteArray();
ByteArrayInputStream bin = new ByteArrayInputStream(data);
System.out.println(bin.available());
}
}
Можно использовать org.apache.commons.io. IOUtils#toByteArray (java.io. InputStream)
InputStream is = getMyInputStream();
ByteArrayInputStream bais = new ByteArrayInputStream(IOUtils.toByteArray(is));