
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を吐いていました。
なので前のデータを表示させていただけだったんですか・・・。
初歩的なミスではずかしいです。しかしおかげさまで問題は解決できました。付き合っていただきありがとうございます。
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になっているため、うまくいきません。
お手数をお掛け致しますが、お返事よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
教えて下さい
-
二分探索の平均探索回数
-
【エクセル】測定時間がバラバ...
-
配列でデータが入っている要素...
-
アクセス2000で画像データ...
-
多量のSUMIF式を軽くしたい
-
Android携帯をUSBメモリ代わりに
-
ACCESSからEXCELに出力する際、...
-
マクロを使って「円」を消すのは
-
メモ帳(テキストデータ)をExc...
-
Accessで該当データにフラグを...
-
特定のデータの抽出方法を教え...
-
ブレーカー落ちで壊れたりしな...
-
カンマからスラッシュに
-
なぜ通りがけをすると昇順に整...
-
delphi でグラフ表示
-
AIの簡単な仕組みについて
-
ページ数を求めたい
-
C言語の度数分布の問題
-
ユーザーフォームのテキストボ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
教えて下さい
-
【エクセル】測定時間がバラバ...
-
配列でデータが入っている要素...
-
VBA 空白セルを削除ではない方...
-
メモ帳(テキストデータ)をExc...
-
EXCELVBAでSQLserverからデータ...
-
多量のSUMIF式を軽くしたい
-
この行は既に別のテーブルに属...
-
CString型の文字列連結について
-
ACCESSからEXCELに出力する際、...
-
ユーザーフォームのテキストボ...
-
エクセルで2つの時系列のデー...
-
C# でDataTableの更新を高速化...
-
特定のデータの抽出方法を教え...
-
C# ソケット通信でデータ受信時...
-
二分探索の平均探索回数
-
Excel VBAでのオートフィルター...
-
ブレーカー落ちで壊れたりしな...
-
Accessで該当データにフラグを...
-
VBAを使ってOutlookメール本文...
おすすめ情報