In Java we can usually perform an assignment within the while
condition. However Kotlin complains about it. So the following code does not compile:
Here is the shortest solution powered by stdlib that also safely closes the reader:
reader.forEachLine {
println(it)
}
And here is a short Kotlin-style general solution by Roman Elizarov:
while (true) {
val line = reader.readLine() ?: break
println(line);
}
Here break
has Nothing type that also helps to promote type inference for the line
as non-nullable string.
In cases you just want to replace while ((x = y.someFunction()) != null)
you may use the following instead:
generateSequence { y.someFunction() }
.forEach { x -> /* what you did in your while */ }
generateSequence will extract you all the values one by one until the first null
is reached. You may replace the .forEach with a reduce or fold (or anything else that seems appropriate ;-)) if you want to keep the last value or sum up the values to something else.
For your specific use case however you may just use what JB Nizet in his answer has shown or use useLines:
reader.useLines {
it.forEach(::println)
}
.forEachLine is probably the next best short-hand solution to that specific readLine
-problem (already answered here) if you know you just want to read all lines and then stop.
(This Example for while loop ) Hope this example will help you..
Change from
while ((c = is
.read(buffer)) > 0) {
sb.append(String(buffer, 0, c, Charset.forName(UTF8)))
}
to
while ({c = is
.read(buffer);c}() > 0) {
sb.append(String(buffer, 0, c, Charset.forName(UTF8)))
}
No, the best way, IMO, would be
val reader = BufferedReader(reader)
reader.lineSequence().forEach {
println(it)
}
And if you want to make sure the reader is properly closed (as you would with a try-with-resources statement in Java), you can use
BufferedReader(reader).use { r ->
r.lineSequence().forEach {
println(it)
}
}