
- 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.PutField put(String name, boolean val) method
Description
The Java ObjectOutputStream.PutField put(String name, boolean val) method puts the value of the named boolean field into the persistent field.
It's used inside a class's private void writeObject(ObjectOutputStream oos) method.
You use oos.putFields() to get a PutField object.
Then, you use put(name, value) to assign values to specific fields.
Finally, you call oos.writeFields() to write them to the stream.
Declaration
Following is the declaration for java.io.ObjectOutputStream.PutField.put(String name, boolean val) method.
public abstract void put(String name, boolean val)
Parameters
name − The name of the serializable field.
val − The value to assign to the field.
Return Value
This method does not return a value.
Exception
IllegalArgumentException − If name does not match the name of a serializable field for the class whose fields are being written, or if the type of the named field is not boolean.
Example - Usage of ObjectOutputStream.PutField put(String name, boolean val) method
The following example shows the usage of ObjectOutputStream.PutField put(String name, boolean val) method.
ObjectOutputStreamDemo.java
package com.tutorialspoint; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.ObjectStreamField; import java.io.Serializable; public class ObjectOutputStreamDemo implements Serializable { public static void main(String[] args) { 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.writeObject(new Example()); oout.flush(); oout.close(); // create an ObjectInputStream for the file we created before ObjectInputStream ois = new ObjectInputStream(new FileInputStream("test.txt")); // read an object from the stream and cast it to Example Example a = (Example) ois.readObject(); // print var of a System.out.println("" + a.var); } catch (Exception ex) { ex.printStackTrace(); } } static public class Example implements Serializable { static boolean var = false; // assign a new serialPersistentFields private static final ObjectStreamField[] serialPersistentFields = { new ObjectStreamField("var", Boolean.TYPE) }; private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException { // get the field and assign it at var ObjectInputStream.GetField fields = in.readFields(); // get var var = fields.get("var", true); } private void writeObject(ObjectOutputStream out) throws IOException { // write into the ObjectStreamField array the variable var ObjectOutputStream.PutField fields = out.putFields(); fields.put("var", var); out.writeFields(); } } }
Output
Let us compile and run the above program, this will produce the following result −
false
Example - Serialize a User object with a custom boolean field
The following example shows the usage of ObjectOutputStream.PutField put(String name, boolean val) method. We're serializing only the isActive field explicitly, along with the name.
ObjectOutputStreamDemo.java
package com.tutorialspoint; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; public class ObjectOutputStreamDemo { public static void main(String[] args) throws IOException, ClassNotFoundException { try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("user_bool1.ser"))) { User user = new User("Alice", true); oos.writeObject(user); ObjectInputStream ois = new ObjectInputStream(new FileInputStream("user_bool1.ser")); User u = (User)ois.readObject(); System.out.println(" User:: name= " + u.name + " isActive= " + u.isActive); } } static class User implements Serializable { private static final long serialVersionUID = 1L; String name; boolean isActive; public User(String name, boolean isActive) { this.name = name; this.isActive = isActive; } private void writeObject(ObjectOutputStream oos) throws IOException { ObjectOutputStream.PutField fields = oos.putFields(); fields.put("name", name); fields.put("isActive", isActive); // write boolean field manually oos.writeFields(); } private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { ObjectInputStream.GetField fields = ois.readFields(); name = (String) fields.get("name", "Unknown"); isActive = fields.get("isActive", false); } } }
Output
Let us compile and run the above program, this will produce the following result−
User:: name= Alice isActive= true
Explanation
The put() call explicitly writes the isActive boolean field.
On deserialization, the value is restored properly.
Example - Conditionally exclude a boolean value from serialization
The following example shows the usage of ObjectOutputStream.PutField put(String name, boolean val) method. We only serialize isAdmin = true; skip it if false.
ObjectOutputStreamDemo.java
package com.tutorialspoint; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; public class ObjectOutputStreamDemo { public static void main(String[] args) throws IOException, ClassNotFoundException { try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("user_bool2.ser"))) { Admin admin = new Admin("Bob", false); // This will skip 'isAdmin' oos.writeObject(admin); ObjectInputStream ois = new ObjectInputStream(new FileInputStream("user_bool2.ser")); Admin ad = (Admin)ois.readObject(); System.out.println(" Admin:: username= " + ad.username + " isAdmin= " + ad.isAdmin); } } static class Admin implements Serializable { private static final long serialVersionUID = 1L; String username; boolean isAdmin; public Admin(String username, boolean isAdmin) { this.username = username; this.isAdmin = isAdmin; } private void writeObject(ObjectOutputStream oos) throws IOException { ObjectOutputStream.PutField fields = oos.putFields(); fields.put("username", username); if (isAdmin) { fields.put("isAdmin", true); // Only write if true } oos.writeFields(); } private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { ObjectInputStream.GetField fields = ois.readFields(); username = (String) fields.get("username", "guest"); isAdmin = fields.get("isAdmin", false); // will default to false if not present } } }
Output
Let us compile and run the above program, this will produce the following result−
Admin:: username= Bob isAdmin= false
Explanation
The boolean isAdmin is only written if true.
If the field is missing during deserialization, it defaults to false via fields.get("isAdmin", false).