OutputStreamWriter is a class in java.io class that is useful for the conversion of character stream into a byte stream. This conversion of characters into bytes is done using charset encoding that has been specified. It contains a write () method that calls the encoding converter to convert a character into a stream of bytes from where the resultant bytes are sent into the buffer where it is accumulated and sent to the outputstream. The characters are passed to the write () method without being buffered, thus leading to frequent converter invocation, thus being used with BufferedWriter.
Start Your Free Software Development Course
Web development, programming languages, Software testing & others
Syntax:
public class OutputStreamWriter extends Writer
This syntax depicts that this is a public class that means it can be instantiated from anywhere in the project. This class is a direct subclass of an abstract class- Writer class that deals with writing to the character streams.
To create an instance of OutputStreamWriter class, we have the following 4 types of constructors:
This constructor returns an instance of OutputStreamWriter with default character encoding. This is the simplest way to create an instance.
Example:
FileOutputStream fileObj = new FileOutputStream (String path); //
This is an instance of OutputStream.
OutputStreamWriter output = new OutputStreamWriter (fileObj);//
The above instance is passed as an argument to specify the file where the output needs to be written.
This constructor returns an instance of OutputStreamWriter that uses the Charset specified. Here charset specified can be like Charset.forName ( “UTF8”), creating an instance of charset as an argument to the method.
Example:
OutputStreamWriter output = new OutputStreamWriter (fileObj,Charset.forName ( "UTF8"));
This constructor returns an instance of OutputStreamWriter that uses the specified Charset encoder.
Example:
CharsetEncoderencoder = B2CConverter.UTF_8.newEncoder () OutputStreamWriter output = new OutputStreamWriter (fileObj, encoder);
This constructor returns an instance of OutputStreamWriter that uses the specified Charset name.
Example:
OutputStreamWriter output = new OutputStreamWriter (fileObj,"UTF-8");
Here, the charset Name used for converting a character stream to the byte stream is “UTF-8”.
1. close ():- This method helps to close the stream after flushing it. No Parameter is required, and nothing is returned from this method.
Syntax
public void close ()
2. flush ():- This method helps to flush the stream.No Parameter is required, and nothing is returned from this method.
Syntax
public void flush ()
3. getEncoding ():- This method helps to retrieve the name of charset encoding being used by the given instance of OutputStreamWriter. No parameter needs to be passed while calling the method.
Syntax
public String getEncoding ()
The string representation of the name of the Encoding being used by the instance is returned.
4. write (char[] charbuf, int off, int len):- This method helps to write a particular portion of an array of characters that starts from the offset position and whose length is ‘len’.This method throwsIOException in case any input is given is incorrect or null.
Syntax
public void write (char[] charbuf, int off, int len)
This method just writes the converted byte stream to the output file. It does not return anything.
5. write (int ch):- This method is used to write a single character to the stream specifying its ASCII character. This method throwsIOException in case any input is given is incorrect or null.
Syntax
public void write (int ch)
This method just writes the converted byte stream to the output file. It does not return anything.
6. write(String str, int off, int len):- This method is used to write a portion of a string starting with the given offset and given length to the stream.
Syntax
public void write (String strObj, int offset, int lgth)
This method just writes the converted byte stream to the output file. It does not return anything.
Below the examples of Java OutputStreamWriter:
import java.io.*; public class StreamDemo { public static void main (String[] args) { String data = "LetsLearnOuptputStreamClass"; try { OutputStream file = new FileOutputStream ("abc.txt"); OutputStreamWriter outObj = new OutputStreamWriter (file); FileInputStream inFileObj = new FileInputStream ("abc.txt"); outObj.write (data, 5, 6); outObj.flush (); System.out.println ( "Name of Encoding used here is : " + outObj.getEncoding ()); for (int i = 0; i<6; i++) { System.out.println ( "Character written is : " + (char) inFileObj.read()); } outObj.close (); } catch (Exception ex) { System.out.println ( "Error Occurred"); ex.printStackTrace (); } } }
Output:
import java.io.*; public class StreamDemo { public static void main (String[] args) { try { OutputStream g = new FileOutputStream ( "C:/Users/savij/Desktop/abc.txt"); OutputStreamWriter outObj = new OutputStreamWriter (g); FileInputStream in = new FileInputStream ( "C:/Users/savij/Desktop/abc.txt"); outObj.write (69); outObj.write (68); outObj.write (85); outObj.write (67); outObj.write (66); outObj.write (65); outObj.flush (); for (int i = 0; i< 6; i++) { System.out.println ( "The char being written: " + (char) in.read()); } outObj.close (); } catch (Exception ex) { System.out.println ( "Error"); ex.printStackTrace (); } } }
Output:
//package Proc; import java.io.*; public class StreamDemo { public static void main (String[] args) { char[] data = {'E','D','U','C','B','A'}; try { OutputStream file = new FileOutputStream ( "abc.txt"); OutputStreamWriter outObj = new OutputStreamWriter (file); FileInputStream inFileObj = new FileInputStream ( "abc.txt"); outObj.write (data,2, 4); outObj.flush (); for (int i = 0; i<4; i++) { System.out.println ( "Character written is : " + (char) inFileObj.read()); } outObj.close (); } catch (Exception ex) { System.out.println ( "Error Occurred"); ex.printStackTrace (); } } }
Output:
OutputStreamWriter is a utility that acts as a bridge from the character stream to a byte stream. It contains a write method that takes input in the form of characters and converts them into bytes using the specified charset or charset encoder for e.g., UTF-8. This class’s efficiency and performance can be enhanced if BufferredWriter is being used instead of Writer to write the resultant byte stream to the output streams.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!