Skip to main content

Socket (TCP & UDP) communication in Java

Socket communication in Java enables communication between two endpoints over a network. There are two main types of sockets: TCP sockets and UDP sockets. Let's explain both types with examples: TCP Socket Communication: 1. **Server Side**:    - The server creates a `ServerSocket` object to listen for incoming connections on a specific port.    - When a client connects, the server accepts the connection and creates a `Socket` object to communicate with the client.    - The server reads from and writes to the socket's input and output streams to communicate with the client. import java.io.*; import java.net.*; public class TCPServer {     public static void main(String[] args) throws IOException {         ServerSocket serverSocket = new ServerSocket(12345);         System.out.println("Server started. Waiting for client...");         Socket clientSocket = serverSocket.accept();         System.out.println("Client connected.");         BufferedReader in = new Bu

Byte Streams

 Java Byte Streams

Byte streams in Java are used to handle input and output of raw binary data. They are suitable for handling low-level data such as images, audio, and binary files. Let's dive into an example to illustrate how byte streams work:

Example: Copying a File Using Byte Streams

In this example, we'll create a program that reads the contents of a source file and writes them into a destination file using byte streams.


import java.io.*;

public class ByteStreamExample {

    public static void main(String[] args) {

        String sourceFile = "source.txt";

        String destinationFile = "destination.txt";


        try (FileInputStream fis = new FileInputStream(sourceFile);

             FileOutputStream fos = new FileOutputStream(destinationFile)) {


            int byteRead;

            while ((byteRead = fis.read()) != -1) {

                fos.write(byteRead);

            }

            System.out.println("File copied successfully!");

        } catch (IOException e) {

            e.printStackTrace();

        }

    }

}



Explanation:

- We import the necessary classes from the `java.io` package for file input and output operations.

- Inside the `main` method, we specify the source and destination file names.

- We create a `FileInputStream` to read bytes from the source file and a `FileOutputStream` to write bytes to the destination file. We use try-with-resources to ensure proper resource management, which automatically closes the streams after use.

- We use a `while` loop to read bytes from the source file (`fis.read()`) and write them to the destination file (`fos.write()`). The loop continues until the `read` method returns `-1`, indicating the end of the file.

- If any `IOException` occurs during file operations, we catch and print the exception stack trace.


Execution:

1. Ensure that the source file (`source.txt`) exists and contains some text.

2. Run the `ByteStreamExample` class.

3. Check the destination file (`destination.txt`) to verify that the contents have been copied successfully.


This example demonstrates the basic usage of byte streams for file copying. Byte streams are efficient for handling binary data, but they are not suitable for processing text-based data where character encoding matters. For text-based operations, character streams should be used instead.

Comments

Popular posts from this blog

Method Overloading in Java

Method Overloading in Java Method Overloading  is a feature in Java that allows a class to have multiple methods with the same name but different parameter lists. The methods can have a different number or types of parameters. The decision on which method to invoke is made by the compiler based on the arguments provided during the method call.  Example: public class Calculator {     // Method to add two integers     public int add(int a, int b) {         return a + b;     }     // Method to add three integers     public int add(int a, int b, int c) {         return a + b + c;     }     // Method to add two doubles     public double add(double a, double b) {         return a + b;     }     // Method to concatenate two strings     public String concatenate(String str1, String str2) {         return str1 + str2;     } } Method Overloading in Action: public class Main {     public static void main(String[] args) {         Calculator calculator = new Calculator();         // Overloaded meth

Java Runtime Environment (JRE)

Definition : Java Runtime Environment (JRE) is a set of software tools and libraries that enables the execution of Java applications. It provides the necessary runtime support for Java programs to run on various devices and platforms. Components of Java Runtime Environment (JRE): Java Virtual Machine (JVM): Definition: The JVM is a crucial component of the JRE responsible for executing Java bytecode. Functionality: It interprets Java bytecode or, in some cases, uses Just-In-Time (JIT) compilation to translate bytecode into native machine code for improved performance. Importance: JVM abstracts the underlying hardware, allowing Java programs to be platform-independent. Class Libraries: Definition: JRE includes a set of precompiled classes and methods that Java applications can utilize. Functionality: These classes cover a wide range of functionalities, from basic data structures to networking. Importance: Class libraries provide a foundation for developers, offering reusable code