Я написал эту программу, но она никогда не достигает line b
, Я уверен, что цикл завершается. Кто-нибудь знает, что не так? : D спасибо
while((x = inr.read(chars, 0, chars.length)) != -1){
result += String.valueOf(chars[0]);
Log.d("@@@", "a " + result); // line a
};
Log.d("@@@", "a " + result); // line b
Выход
05-31 10:18:20.249: D/@@@(676): Starting iMNSConnection...
05-31 10:18:20.249: D/@@@(676): Is trying to connect to server...
05-31 10:18:20.289: D/@@@(676): a W
05-31 10:18:20.289: D/@@@(676): a We
05-31 10:18:20.289: D/@@@(676): a Wel
05-31 10:18:20.289: D/@@@(676): a Welc
05-31 10:18:20.289: D/@@@(676): a Welco
05-31 10:18:20.294: D/@@@(676): a Welcom
05-31 10:18:20.294: D/@@@(676): a Welcome
05-31 10:18:20.294: D/@@@(676): a Welcome
05-31 10:18:20.294: D/@@@(676): a Welcome !
05-31 10:18:20.294: D/@@@(676): a Welcome !!
05-31 10:18:20.294: D/@@@(676): a Welcome !!!
05-31 10:18:20.299: D/dalvikvm(676): GC_CONCURRENT freed 1196K, 36% free 16727K/25991K, paused 1ms+2ms, total 15ms
05-31 10:18:20.299: D/dalvikvm(676): WAIT_FOR_CONCURRENT_GC blocked 13ms
отредактированный
На самом деле я использую сервер C ++ с клиентом Java
Сторона C ++
char* classroomList = "{........}";
send(ConnectedSocket, classroomList, strlen(classrooomList), 0);
Затем клиент Silde (Java)
Если я использую BufferedReader и ничего не распечатывать.
Так что я использую это,
InputStreamReader inr = new InputStreamReader(ins);
char[] chars = new char[1024];
while((x = inr.read(chars, 0, chars.length - 1)) != -1){
result += String.valueOf(chars);
}
Вывод как это:
05-31 10:47:32.464: D/@@@(14850): Is trying to connect to server...
05-31 10:47:32.494: D/@@@(14850): 11a Welcome !!!������...(and 2028 same characters)
Поэтому я пытаюсь добавить это
while((x = inr.read(chars, 0, chars.length - 1)) != -1){
chars[x] = '\0';
result += String.valueOf(chars);
Log.d("@@@", x + "a " + result);
}
Это работает, когда Java заканчивает данные на сервер C ++. Я делаю это на C ++, но не работаю на Java
Наконец я попробую это,
while((x = inr.read(chars, 0, chars.length - 1)) != -1){
chars[x] = '\0';
result += String.valueOf(chars);
Log.d("@@@", x + "a " + result);
}
Или использование StringBuilder тоже не работает.
После следить за работой СМ,
Log.d("@@@", "Waiting for server reply...");
InputStream in = socket.getInputStream();
InputStreamReader inr = new InputStreamReader(in);
BufferedReader br = new BufferedReader(inr);
StringBuilder sb = new StringBuilder();
String line;
while ((line = br.readLine()) != null) {
Log.d("@@@", ": " + line);
sb.append(line);
}
br.close();
Log.d("@@@", ": " + sb.toString());
Выходные данные не проходят через цикл while
05-31 11:04:37.734: D/dalvikvm(22624): GC_FOR_ALLOC freed 1621K, 39% free 15950K/25991K, paused 18ms, total 18ms
05-31 11:04:37.749: D/@@@(22624): Starting iMNSConnection...
05-31 11:04:37.749: D/@@@(22624): Is trying to connect to server...
05-31 11:04:37.759: D/@@@(22624): Waiting for server reply...
05-31 11:04:37.789: D/dalvikvm(22624): GC_CONCURRENT freed 1194K, 36% free 16744K/25991K, paused 1ms+1ms, total 13ms
05-31 11:04:37.789: D/dalvikvm(22624): WAIT_FOR_CONCURRENT_GC blocked 12ms
05-31 11:04:37.809: D/AbsListView(22624): Get MotionRecognitionManager
05-31 11:04:37.819: D/SensorManager(22624): unregisterListener:: Listener= android.view.OrientationEventListener$SensorEventListenerImpl@41d85420
05-31 11:04:37.819: D/Sensors(22624): Remain listener = Sending .. normal delay 200ms
05-31 11:04:37.819: I/Sensors(22624): sendDelay --- 200000000
05-31 11:04:37.819: D/SensorManager(22624): JNI - sendDelay
05-31 11:04:37.819: I/SensorManager(22624): Set normal delay = true
05-31 11:05:41.944: D/dalvikvm(22624): GC_CONCURRENT freed 1078K, 33% free 17590K/25991K, paused 21ms+20ms, total 82ms
Кто производит текст Welcome !!!
? Может быть, другая сторона не закрывает поток.
В любом случае ваш код очень неэффективен. Вы создаете много объектов String, по одному на каждый прочитанный символ. Если вы читаете текст из потока, вам лучше использовать что-то вроде:
BufferedReader br = new BufferedReader(new InputStreamReader(inputStream));
StringBuilder sb = new StringBuilder();
String line;
while ((line = br.readLine()) != null) {
sb.append(line);
}
br.close(); // and catch exception
Строки Java не заканчиваются нулем. Если вы получаете x
байтов в byte[]
буфер buffer
, правильный способ построить строку из него new String(buffer, 0, x)
,