No.1
- 回答日時:
> InputStreamからreadでデータを読み込んでも、読み込んだデータはStream内に消えずに残っているため
普通はそんな現象は起きないので流れてきたデータを順番にreadするだけですが、どういうプログラムでそういうことが発生しているのか示すことはできますか?
なお、読み飛ばしたいバイト数が分かっているならばInputStream.skip()メソッドを使うこともできます。
この回答への補足
お返事ありがとうございます。
簡単にプログラムを書かせていただきますと、
--------Server--------
OutputStream outStream;
byte[] writeDataByte =new byte[6];//送るデータをbyteに変換した物
outStream.write(wirteDataByte);
outStream.write(wirteDataByte);
--------Server--------
--------Client--------
InputStream inStream;//markはsupportしていない
byte[] readByte = new byte[100];
System.out.println("available = " + inStream.available());//結果は12
inStream.read(readByte, 0, 100);
for(int i = 0;i < 100;i++)
{
System.out.println("readByte" + i + " = " + readByte[i]);
}
System.out.println("available = " + inStream.available());//結果は0
inStream.read(readByte, 0, 100);
for(int i = 0;i < 100;i++)
{
System.out.println("readByte" + i + " = " + readByte[i]);
}
--------Client--------
このようなソースを動かすと、一回目の出力と二回目の出力が同じ内容になります。また私もavailableでデータの長さを読み取り、skipで後ろから送ったデータの分だけをとろうともしたのですが、二回目のavailableでは長さが0になっているため、うまくいきません。
お手数をお掛け致しますが、お返事よろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
ANo.1の者です。
> inStream.read(readByte, 0, 100);
read()の返り値をチェックしていないのが気になります。
おそらくですが、2回目のread()では1バイトも読み込んでいないのでreadByte[]の内容が変わっていないのではないでしょうか。
↓このようにしたらどうなりますか?
n = inStream.read(readByte, 0, readByte.length);
System.out.println("n = " + n);
for(int i = 0;i < n;i++)
{
System.out.println("readByte" + i + " = " + readByte[i]);
}
なんどもお返事ありがとうございます。
言われたとおりにやってみると二回目はー1を吐いていました。
なので前のデータを表示させていただけだったんですか・・・。
初歩的なミスではずかしいです。しかしおかげさまで問題は解決できました。付き合っていただきありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- CAD・DTP JWW-CADでDXF変換後の線が連動して消える 2 2023/01/13 11:09
- その他(プログラミング・Web制作) pythonでクラスで複数のメソッドを利用する方法 2 2022/04/15 04:17
- USBメモリー・SDカード・フラッシュメモリー microSDカードに追記出来ない 9 2023/06/18 17:19
- ノートパソコン ノートパソコンのBD-Rドライブが使用できなくなってしまったらどうする 9 2022/12/05 09:14
- Android(アンドロイド) スマホデータについて 一時期心霊写真にはまってて保存してたんですが、色々あって気味が悪くなって消しま 2 2022/04/24 20:36
- その他(Microsoft Office) OneNote2016で過去のデータを読もうとすると「このページが開けませんでした」となってしまう。 2 2022/10/30 12:58
- ドライブ・ストレージ HDDをバックアップできる状態にしたい 4 2023/07/30 16:49
- ドライブ・ストレージ iPhoneのストレージのことなのですが、Safariの書類とデータが112.89GBになってます。 4 2023/03/21 13:02
- ビデオカメラ ビデオカメラを撮影しながらスマホに画面を映し出す方法はありますか? 2 2023/04/11 20:56
- PostgreSQL ポストグレにあるExcelファイルを開くには 1 2022/12/13 18:07
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
教えて下さい
-
VBA 空白セルを削除ではない方...
-
配列でデータが入っている要素...
-
多量のSUMIF式を軽くしたい
-
[VBA] CountIfに変数を使いたい
-
GridViewの行の一部を複数行にする
-
モジュラス103の算出方法について
-
バーコードリーダーの読込デー...
-
【VBA】データを入力後に,同一...
-
ブレーカー落ちで壊れたりしな...
-
【エクセル】測定時間がバラバ...
-
C言語について
-
VBA 判定文で理解できない結果...
-
独自データ属性に日本語は利用...
-
ActiveReportについて
-
ユーザーフォームのテキストボ...
-
なぜ通りがけをすると昇順に整...
-
この行は既に別のテーブルに属...
-
リングバッファって何ですか
-
MySQLから取ってきた配列のデー...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
教えて下さい
-
【エクセル】測定時間がバラバ...
-
配列でデータが入っている要素...
-
多量のSUMIF式を軽くしたい
-
エクセルで2つの時系列のデー...
-
Excelのマクロでワードのテキス...
-
メモ帳(テキストデータ)をExc...
-
VBA 空白セルを削除ではない方...
-
VBAを使ってOutlookメール本文...
-
Accessで該当データにフラグを...
-
合計3TBのデータのハッシュ値を...
-
シーケンサにパソコンからアク...
-
S9タイプからXタイプにデータ...
-
カンマからスラッシュに
-
VBAでシートからコンボボックス...
-
VBA 毎日取得するデータを順番...
-
ビットシフトについて
-
ユーザーフォームのテキストボ...
-
EXCELVBAでSQLserverからデータ...
-
特定のデータの抽出方法を教え...
おすすめ情報