Home >Backend Development >C#.Net Tutorial >BinaryWriter in C#
In C#, BinaryWriter is a class used to write primitive types as binary data in a particular encoding stream. It is present under System.IO namespace.
Following are some important points regarding BinaryWriter:
The constructor to create an object of BinaryWriter is available in four overloaded forms. The syntax to create a BinaryWriter object using all its overloaded constructors are as follows:
Syntax #1
protected BinaryWriter();
It is used to initialize an instance of the BinaryWriter class.
Syntax #2
BinaryWriter binaryWriter = new BinaryWriter(outputStream) ;
The above statement initializes a new instance of BinaryWriter class on the basis of the specified stream (outputStream) and using UTF-8 character encoding.
Syntax #3
BinaryWriter binaryWriter = new BinaryWriter(outputStream, encoding);
The above statement initializes a new instance of BinaryWriter based on the specified stream (outputStream) and character encoding (encoding).
Syntax #4
BinaryWriter binaryWriter = new BinaryWriter(outputStream, encoding, true);
Code:
using (BinaryWriter binaryWriter = new BinaryWriter(File.Open(fileName, FileMode.Create )) ) { //user code }
Here, File.Open() method returns FileStream object which helps to create an instance of BinaryWriter.
Following table shows details of some Write() methods of BinaryWriter for different data types:
Method | Description |
Write(Boolean) | This method is used to write the one-byte Boolean value to the present stream; 0 represents false while 1 represents true. |
Write(Byte) | This method is used to write an unsigned byte to the present stream and then it advances the position of the stream by one byte. |
Write(Char) | This method is used to write Unicode character to present stream and also it advances the present stream position according to the character encoding used and according to the characters being written to the present stream. |
Write(Decimal) | This method is used to write a decimal value to the present stream and also it advances the position of the current stream by sixteen bytes. |
Write(Double) | This method is used to write an eight-byte floating-point value to the present stream and then it also advances the position of the current stream by eight bytes. |
Write(Int32) | This method is used to write a four-byte signed integer to the present stream and then it advances the position of current stream by four bytes. |
Write(String) | This method is used to write length prefixed string to present stream in the present encoding of BinaryWriter and also it advances the current stream position according to the encoding used and according to the characters being written to the present stream. |
Example showing the creation of file:
Code:
using System; using System.IO; namespace ConsoleApp4 { public class Demo { string fileLocation = "E:\\Content\\newBinaryFile.dat"; public void WritingFile() { try { //checking if file exists if (File.Exists(fileLocation)) { File.Delete(fileLocation); } FileStream fileStream = new FileStream(fileLocation, FileMode.Create, FileAccess.Write, FileShare.ReadWrite); //creating binary file using BinaryWriter using (BinaryWriter binaryWriter = new BinaryWriter(fileStream)) { //writing data using different Write() methods //of BinaryWriter binaryWriter.Write(5253); binaryWriter.Write("This is a string value."); binaryWriter.Write('A'); } } catch (Exception exception) { Console.WriteLine(exception.Message); } } public void ReadingFile() { try { FileStream fileStream = new FileStream(fileLocation, FileMode.Open, FileAccess.Read, FileShare.ReadWrite); using (BinaryReader binaryReader = new BinaryReader(fileStream)) { Console.WriteLine("IntegerValue = " + binaryReader.ReadInt32()); Console.WriteLine("StringValue = " + binaryReader.ReadString()); Console.WriteLine("CharValue = " + binaryReader.ReadChar()); } } catch (Exception exception) { Console.WriteLine(exception.Message); } } } public class BinaryWriterDemo { static void Main(string[] args) { Demo demoObj = new Demo(); demoObj.WritingFile(); demoObj.ReadingFile(); Console.ReadLine(); } } }
Output:
In C#, the BinaryWriter class is used to write primitive types as binary information to the stream. If the encoding is not defined, then the BinaryWriter class uses the default UTF-8 character encoding to write data to a binary file. An object of BinaryWriter can be created using the Stream object.
The above is the detailed content of BinaryWriter in C#. For more information, please follow other related articles on the PHP Chinese website!