
- 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 - ObjectOutputStream writeBytes(String str) method
Description
The Java ObjectOutputStream writeBytes(String str) method writes strings of bytes.
Writes the low-order byte of each character in the string to the stream (i.e., discards high-order byte).
Inherited from DataOutput, which ObjectOutputStream implements.
Each character is treated as a single byte, so it's not Unicode-safe - suitable for ASCII only.
This is not object serialization − it's raw byte writing.
Declaration
Following is the declaration for java.io.ObjectOutputStream.writeBytes(String str) method.
public void writeBytes(String str)
Parameters
val − The string of bytes to be written.
Return Value
This method does not return a value.
Exception
IOException − If I/O errors occur while writing to the underlying stream.
Example - Usage of ObjectOutputStream writeBytes(String str) method
The following example shows the usage of ObjectOutputStream writeBytes(String str) method.
ObjectOutputStreamDemo.java
package com.tutorialspoint; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; public class ObjectOutputStreamDemo { public static void main(String[] args) { String s = "Hello"; try { // create a new file with an ObjectOutputStream FileOutputStream out = new FileOutputStream("test.txt"); ObjectOutputStream oout = new ObjectOutputStream(out); // write something in the file oout.writeBytes(s); oout.writeBytes("World"); // close the stream oout.close(); // create an ObjectInputStream for the file we created before ObjectInputStream ois = new ObjectInputStream(new FileInputStream("test.txt")); // read and print what we wrote before for (int i = 0; i < 10; i++) { System.out.print("" + (char) ois.readByte()); } } catch (Exception ex) { ex.printStackTrace(); } } }
Output
Let us compile and run the above program, this will produce the following result −
HelloWorld
Example - Write a basic ASCII string to a file and read it back
The following example shows the usage of ObjectOutputStream writeBytes(String str) method. We're writing "Hello" using writeBytes() and print the result.
ObjectOutputStreamDemo.java
package com.tutorialspoint; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectOutputStream; public class ObjectOutputStreamDemo { public static void main(String[] args) { String filename = "ascii_output.txt"; // Write the string as raw bytes try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(filename))) { oos.writeBytes("Hello"); System.out.println("String written using writeBytes(): Hello"); } catch (IOException e) { e.printStackTrace(); } // Read and print the file try (FileInputStream fis = new FileInputStream(filename)) { byte[] data = fis.readAllBytes(); String result = new String(data); // assumes default charset System.out.println("Read from file: " + result); } catch (IOException e) { e.printStackTrace(); } } }
Output
Let us compile and run the above program, this will produce the following result−
String written using writeBytes(): Hello Read from file: Hello
Example - Write a formatted ASCII message using writeBytes()
The following example shows the usage of ObjectOutputStream writeBytes(String str) method. We're writing a simple ASCII log entry using writeBytes().
ObjectOutputStreamDemo.java
package com.tutorialspoint; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectOutputStream; public class ObjectOutputStreamDemo { public static void main(String[] args) { String filename = "log_output.txt"; // Simulate a log entry String timestamp = "2024-03-25"; String level = "INFO"; String message = "Application started successfully"; String logEntry = "[" + timestamp + "] [" + level + "] " + message + "\n"; try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(filename))) { oos.writeBytes(logEntry); System.out.println("Log entry written using writeBytes():"); System.out.println(logEntry); } catch (IOException e) { e.printStackTrace(); } // Read and print the file content try (FileInputStream fis = new FileInputStream(filename)) { fis.skip(6); byte[] data = fis.readAllBytes(); String result = new String(data); System.out.println("Read from file:"); System.out.println(result); } catch (IOException e) { e.printStackTrace(); } } }
Output
Let us compile and run the above program, this will produce the following result−
Log entry written using writeBytes(): [2024-03-25] [INFO] Application started successfully Read from file: [2024-03-25] [INFO] Application started successfully
Explanation
skip(6) is used because ObjectOutputStream adds some headers before the actual content. The first 6 bytes are headers, in our case.
We write a plain ASCII log line using writeBytes().
Because it's ASCII-only, there's no data loss.
This shows writeBytes() is totally fine for writing logs, IDs, and simple messages - as long as they don't include accented or non-Latin characters.