 
- Java.io - Home
- Java.io - BufferedInputStream
- Java.io - BufferedOutputStream
- Java.io - BufferedReader
- Java.io - BufferedWriter
- Java.io - ByteArrayInputStream
- Java.io - ByteArrayOutputStream
- Java.io - CharArrayReader
- Java.io - CharArrayWriter
- Java.io - Console
- Java.io - DataInputStream
- Java.io - DataOutputStream
- Java.io - File
- Java.io - FileDescriptor
- Java.io - FileInputStream
- Java.io - FileOutputStream
- Java.io - FilePermission
- Java.io - FileReader
- Java.io - FileWriter
- Java.io - FilterInputStream
- Java.io - FilterOutputStream
- Java.io - FilterReader
- Java.io - FilterWriter
- Java.io - InputStream
- Java.io - InputStreamReader
- Java.io - LineNumberInputStream
- Java.io - LineNumberReader
- Java.io - ObjectInputStream
- Java.io - ObjectInputStream.GetField
- Java.io - ObjectOutputStream
- io - ObjectOutputStream.PutField
- Java.io - ObjectStreamClass
- Java.io - ObjectStreamField
- Java.io - OutputStream
- Java.io - OutputStreamWriter
- Java.io - PipedInputStream
- Java.io - PipedOutputStream
- Java.io - PipedReader
- Java.io - PipedWriter
- Java.io - PrintStream
- Java.io - PrintWriter
- Java.io - PushbackInputStream
- Java.io - PushbackReader
- Java.io - RandomAccessFile
- Java.io - Reader
- Java.io - SequenceInputStream
- Java.io - SerializablePermission
- Java.io - StreamTokenizer
- Java.io - StringBufferInputStream
- Java.io - StringReader
- Java.io - StringWriter
- Java.io - Writer
- Java.io package Useful Resources
- Java.io - Discussion
Java - CharArrayReader ready() method
Description
The Java CharArrayReader ready() method checks whether the next read operation will not block. It returns true if the stream is ready to be read (i.e., there are still characters left to read), and false if the end of the stream is reached.
Declaration
Following is the declaration for java.io.CharArrayReader.ready() method −
public boolean ready()
Parameters
NA
Return Value
Returns true, if the next read is guaranteed not to block for input.
Exception
IOException − If any I/O error occurs.
Example - Using CharArrayReader ready() method
The following example shows the usage of Java CharArrayReader ready() method.
CharArrayReaderDemo.java
package com.tutorialspoint;
import java.io.CharArrayReader;
import java.io.IOException;
public class CharArrayReaderDemo {
   public static void main(String[] args) {      
      CharArrayReader car = null;
      char[] ch = {'A', 'B', 'C', 'D', 'E'};
      
      try {
         // create new character array reader
         car = new CharArrayReader(ch);
         
         // test whether the stream is ready to be read
         boolean isReady = car.ready();
         
         // print
         System.out.println("Ready ? "+isReady);
         
      } catch(IOException e) {
         // if I/O error occurs
         e.printStackTrace();
      } finally {
         // releases any system resources associated with the stream
         if(car!=null)
            car.close();
      }
   }
}
Output
Let us compile and run the above program, this will produce the following result −
Ready ? true
Example - Checking if Reader is Ready Before Reading
The following example shows the usage of Java CharArrayReader ready() method.
CharArrayReaderDemo.java
package com.tutorialspoint;
import java.io.CharArrayReader;
import java.io.IOException;
public class CharArrayReaderDemo {
   public static void main(String[] args) {
      char[] data = "Hello, World!".toCharArray();
      try (CharArrayReader reader = new CharArrayReader(data)) {
         System.out.println("Is the reader ready? " + reader.ready());
         while (reader.ready()) {  // Check if the reader is ready before reading
            System.out.print((char) reader.read());
         }
         System.out.println("\nIs the reader ready after reading? " + reader.ready());
      } catch (IOException e) {
         System.err.println("IOException occurred: " + e.getMessage());
      }
   }
}
Output
Let us compile and run the above program, this will produce the following result −
Is the reader ready? True Hello, World! Is the reader ready after reading? false
Explanation
- Initialize CharArrayReader− A CharArrayReader is created with "Hello, World!" converted to a character array. 
- Check Readiness− reader.ready() is called before reading, which returns true. 
- Reading While Ready− A while loop reads characters only if ready() returns true, ensuring smooth reading without blocking. 
- Check Readiness Again− After reading all characters, ready() returns false, indicating the end of the stream. 
Example - Checking Readiness After Skipping Characters
The following example shows the usage of Java CharArrayReader ready() method.
CharArrayReaderDemo.java
package com.tutorialspoint;
import java.io.CharArrayReader;
import java.io.IOException;
public class CharArrayReaderDemo {
   public static void main(String[] args) {
      char[] data = "Java Programming".toCharArray();
      try (CharArrayReader reader = new CharArrayReader(data)) {
         System.out.println("Is reader ready? " + reader.ready());
         // Skip first 5 characters ("Java ")
         reader.skip(5);
         System.out.println("Is reader ready after skipping? " + reader.ready());
         while (reader.ready()) {
            System.out.print((char) reader.read());
         }
      } catch (IOException e) {
         System.err.println("IOException occurred: " + e.getMessage());
      }
   }
}
Output
Let us compile and run the above program, this will produce the following result −
Is reader ready? true Is reader ready after skipping? true Programming
Explanation
- Initialize Reader− The string "Java Programming" is converted to a character array. 
- Check Readiness− Initially, reader.ready() returns true. 
- Skip Characters− reader.skip(5) skips the first five characters ("Java "). Readiness is checked again, and it remains true. 
- Read Remaining Characters− Characters are read one by one while ready() is true. 
Key Points abount ready()
- Non-Blocking Check− ready() returns true if characters can be read without blocking. Useful before reading large data to prevent unnecessary waiting. 
- Usage with read()− Works well in loops to ensure smooth reading. 
- Doesn't Consume Characters− Unlike read(), calling ready() does not move the read position. 
- Interaction with skip()− ready() remains true if there are characters left after skipping. 
These examples show how ready() helps in safe and efficient reading from CharArrayReader!