Java Arrays

Arrays in Java are a fundamental data structure that allow you to store multiple values of the same type in a single variable. They provide a convenient way to manage and manipulate collections of data, whether you're dealing with numbers, strings, or objects. Arrays are indexed, meaning each element in the array can be accessed using its position, starting from zero. This makes it easy to iterate through elements using loops, perform bulk operations, and manage large datasets efficiently. Understanding arrays is crucial for mastering Java, as they form the basis for more complex data structures and algorithms. Whether you’re just starting or are a seasoned developer, mastering Arrays in Java will significantly enhance your coding toolkit. 

In this comprehensive blog, we'll explore the intricacies of Java Arrays. From understanding their structure to learning how to declare, initialise, and manipulate them, you'll gain a solid foundation in using this fundamental data structure. Let’s dive in!

Table of Contents

1)  Array in Java- an overview

2) Types of Array in Java

3) Advanced Array Concepts

4) Accessing and Modifying Array elements

5) Operations on Arrays

6) Looping Through Arrays

7) Java Array Members

8) Advantages and Disadvantages of Having Arrays in Java?

9) Conclusion

Array in Java- an overview  

In Java, an Array is a data structure that allows you to store multiple values of the same type in a single variable. It’s a collection of like-typed variables that are accessed by a common name. Arrays are objects in Java, so they come with an attribute called length that tells you how many elements the Array can hold. Here are some key points about Java Arrays:

a) Dynamic Allocation: Arrays in Java are dynamically allocated, meaning their size can be determined during runtime.

b) Contiguous Memory: The elements of an Array are stored in contiguous memory locations, which allows for fast access times.

c) Indexing: Each element in an Array is indexed, starting from 0. This index is used to access and modify the elements within the Array.

d) Fixed Size: Once an Array is created, its size is fixed and cannot be changed.

e) Type-specific: An Array can hold primitives (like int, char, etc.) or objects, but all elements must be of the same type.

Here’s a simple example of how to declare, instantiate, and access an Array in Java:

// Declare an array of integers

int[] myArray;

// Instantiate the array with a size of 10

myArray = new int[10];

// Access and assign a value to the first element

myArray[0] = 100;

// Access and print the first element

System.out.println(myArray[0]);

This code snippet demonstrates the declaration of an array, allocation of memory with the new keyword, and basic operations to set and retrieve values from the Array.

Java Courses

Types of Arrays in Java 

Now, let us learn about the types of Arrays in Java. 

One-dimensional Array 

A Single-dimensional Array in Java is a linear structure that stores a sequence of elements of the same data type. It’s akin to a list where each element is identified by an index, starting from 0. Here’s a breakdown of its characteristics:

a) Linear Storage: Elements are stored in a straight line, one after another.

b) Fixed Size: The number of elements it can hold is set when the Array is created and cannot be changed later.

c) Type Homogeneity: All elements in the Array must be of the same data type.

d) Index-based Access: Elements are accessed using their index, with the first element at index 0.

To declare a single-dimensional Array, you specify the data type followed by square brackets and the Array name. For example:

int[] array; // Declaration of an array of integers

Multi-dimensional Array 

A multi-dimensional Array in Java is essentially an “array of arrays,” where each element can itself be an Array. This allows for the creation of complex data structures like matrices or tables. Here’s what you need to know about multi-dimensional Arrays:

a) Structure: In a two-dimensional Array, which is the simplest form of a multi-dimensional array, the data is stored in rows and columns, creating a grid-like structure.

b) Declaration: You declare a multi-dimensional Array by adding more square brackets for each dimension. For example, int[][] for a 2D Array, int[][][] for a 3D Array, and so on.

c) Initialisation: You can initialise a multi-dimensional Array using nested curly braces for each dimension, or by using the new keyword specifying the size of each dimension.

d) Accessing Elements: To access an element, you specify indexes for each dimension, like Array [i][j] for a 2D Array, where i is the row index, and j is the column index.

Here’s an example of declaring, instantiating, and initialising a two-dimensional Array in Java:

// Declare and instantiate a 2D array with 3 rows and 4 columns

int[][] twoDArray = new int[3][4];

// Initialize the first row

twoDArray[0][0] = 1;

twoDArray[0][1] = 2;

twoDArray[0][2] = 3;

twoDArray[0][3] = 4;

// Access the element in the first row and third column

int element = twoDArray[0][2]; // This would be 3


3) Advanced Array Concepts 

Let's examine a couple of techniques and strategies for working with arrays that go beyond the basics. These concepts include anonymous array and jagged array

Anonymous Array in Java 

 Java supports the feature of an anonymous array, ensuring there's no need to declare the array while passing an array to the method.
 

//Java Program to demonstrate the way of passing an anonymous array  

//to method.  

public class TestAnonymousArray{  

//creating a method which receives an array as a parameter  

static void printArray(int arr[]){  

for(int i=0;i

System.out.println(arr[i]);  

}

public static void main(String args[]){  

printArray(new int[]{10,22,44,66});//passing anonymous array to method  

}}  

 

Output: 
 

1 2 3

2 4 5

4 4 5

 

Jagged Array in Java

A jagged array creates an odd number of columns in a 2D array. In other words, it is an array of arrays with different numbers of columns.
 

//Java Program to illustrate the jagged array  

class TestJaggedArray{  

    public static void main(String[] args){  

        //declaring a 2D array with odd columns  

        int arr[][] = new int[3][];  

        arr[0] = new int[3];  

        arr[1] = new int[4];  

        arr[2] = new int[2];  

        //initializing a jagged array  

        int count = 0;  

        for (int i=0; i

            for(int j=0; j

                arr[i][j] = count++;  

        //printing the data of a jagged array   

        for (int i=0; i

            for (int j=0; j

                System.out.print(arr[i][j]+" ");  

            }  

            System.out.println();//new line  

        }  

    }  

}  

 

Output: 

0 1 2 

3 4 5 6 

7 8

 

Accessing and Modifying Array elements  

Accessing and modifying Array elements are fundamental operations in programming. Here’s a brief explanation:

Accessing Array Elements: Arrays are collections of items that can be accessed using an index. In most Programming Languages, Array indexing starts at 0. So, to access the first element, you use index 0 for the second element, index 1, and so on. For example:

const array = ['apple', 'banana', 'cherry'];

console.log(array[0]); // Outputs: apple

Index-based Access: This refers to using the index to access an element directly. The time complexity for index-based access is constant, denoted as O(1), meaning it takes the same amount of time to access an element regardless of the Array’s size.

Updating Elements: To update an element, you assign a new value to the Array at a specific index. For example:

array[1] = 'blueberry';

console.log(array); // Outputs: ['apple', 'blueberry', 'cherry']

Join the Java Programming Course today! To fully understand the programming and get the most out of it.    

Operations on Arrays  

Operations on Arrays are fundamental in computer programming, providing a means to manipulate collections of elements efficiently. Arrays are data structures consisting of a collection of elements, each identified by at least one array index or key. Various operations can be performed on Arrays, including addition and multiplication of elements, copying, merging, splitting, searching, and cloning.

Each of these operations plays a vital role in data manipulation and algorithm implementation. Let's delve into each operation in detail: 

1) Addition Using Java Arrays 

Adding Array elements involves iterating through each element of the Array and summing them up. This operation is useful for accumulating values stored in an Array.

int sum = 0;

for(int i = 0; i < array.length; i++) {

    sum += array[i];

}

Output: The output is the sum of all elements in the Array.

2) Multiplication using Java Arrays

Similar to addition, this operation multiplies all elements within an Array. It's commonly used in mathematical problems where the product of a series of numbers is required.

int product = 1;

for(int i = 0; i < array.length; i++) {

    product *= array[i];

}

Output: The output is the product of all elements in the Array.

Gain deeper insight into the world of Java with our Java Engineer Training – Sign up now! 

3) Copying Using Java Arrays

Copying Arrays involves creating a new Array and then copying the contents of the original Array into it. This can be done element by element or by using utility methods like System.arraycopy() or Arrays.copyOf().

Syntax using System.arraycopy(): 

int[] original = {1, 2, 3};

int[] copy = new int[original.length];

System.arraycopy(original, 0, copy, 0, original.length);

Syntax using Arrays.copyOf():

int[] copy = Arrays.copyOf(original, original.length);

Output: Both methods produce a new array (copy) that contains the same elements as the original Array.

4) Merging Using Java Arrays 

Merging Arrays involves combining the elements of two Arrays into a single Array. The elements of the second Array follow those of the first Array in the merged Array.

int[] array1 = {1, 2, 3};

int[] array2 = {4, 5, 6};

int[] mergedArray = new int[array1.length + array2.length];

System.arraycopy(array1, 0, mergedArray, 0, array1.length);

System.arraycopy(array2, 0, mergedArray, array1.length, array2.length);

5) Splitting Using Java Arrays 

Splitting an Array involves dividing it into two or more smaller Arrays. This could be based on a specific condition or at a specified index.

Syntax: There is no direct method to split Arrays in Java, but one can achieve this by using System.arraycopy() or manual iteration.

int[] original = {1, 2, 3, 4, 5};

int[] firstPart = new int[2];

int[] secondPart = new int[original.length - firstPart.length]

System.arraycopy(original, 0, firstPart, 0, firstPart.length);

System.arraycopy(original, firstPart.length, secondPart, 0, secondPart.length);

Output: firstPart and secondPart are two Arrays containing the split elements of the original Array.

6) Binary Search Using Java Arrays

Binary search is a technique for finding a particular element in a sorted Array by repeatedly dividing the search interval in half. If the search value is less than the item in the middle of the interval, narrow the interval to the lower half. Otherwise, narrow it to the upper half.

Syntax using Arrays.binarySearch():

int[] arr = {2, 4, 6, 8, 10};

int key = 6;

int result = Arrays.binarySearch(arr, key);

Output: Result is the index of key in the Array arr. If key is not found, the method returns a negative value.

7) Cloning Using Java Arrays 

Cloning an Array in Java creates a new Array that is a shallow copy of the original Array. The clone has the same size, element type, and values as the original. 

Syntax:

int[] original = {1, 2, 3};

int[] clone = original.clone();

Output: The clone is a new Array that is identical to original but resides at a different memory location.

Want to develop your knowledge on Java EE APIs, then signup for our Introduction To Java EE Training now!    

Looping Through Arrays  

Looping through Arrays is a fundamental concept in Java, allowing you to access and manipulate each element of an Array. Here’s a detailed explanation of both traditional for loop and enhanced for-each loop:

1) For Loop

The traditional For Loop is used to iterate over an Array by index. It’s useful when you need to keep track of the index position or modify the Array.

Syntax:

for (int i = 0; i < array.length; i++) {

    // Access array elements as array[i]

}

2) For-each Loop 

The enhanced for-each loop, introduced in Java 5, is a simplified syntax for iterating over Arrays and collections. It eliminates the need for a counter variable and is less prone to errors.

Syntax:

for (type variable : array) {

    // Access each array element as 'variable'

}

3) While Loop 

The While Loop in Java is a control flow statement that allows code to be executed repeatedly based on a given Boolean condition. It’s a fundamental tool for performing repetitive tasks until a certain condition is met.

Syntax:

while (condition) {

    // Statements to execute

}

4) Do-while Loop 

A Do-while Loop executes a block of statements repeatedly until a specified condition evaluates to false. The main feature that distinguishes it from a regular While Loop is that the condition is evaluated after the execution of the loop’s body, guaranteeing that the loop’s body will be executed at least once.

Syntax: 

do {

    // Statements to execute

} while (condition);

Java Array Members

Now that you know arrays are objects of a class, with the class Object being their direct superclass, consider the following members of an array type:

1) The public final field length contains the number of components in the array, which may be zero or positive.

2) All members are inherited from the class Object, except for the clone method.

3) The public method clone() overrides the clone method in the class Object and does not throw checked exceptions.

Advantages and Disadvantages of Having Arrays in Java? 

Here is a list of a few advantages and disadvantages of having Arrays in Java mentioned below. 
 

 Advantages 

 Disadvantages 

User-friendly: Arrays are simple to use and declare in Java.  

Effective Use of Memory: Arrays are efficient in terms of memory usage because they allocate memory in contiguous blocks.  

Quick Access: Arrays can provide quick access to elements. 

Strongly Typed: Arrays are strongly typed, meaning they can only hold elements of the same type to prevent errors. 

Fixed-size: Once an Array is created in Java, its size cannot be changed. 

Wastage of Memory: Arrays can be a waste of memory if they are declared but not fully utilised. 

Linear Search: Finding an element in an Array can be slow if the Array is large and unsorted. 

No Dynamic Resizing: Arrays do not have a built-in mechanism for dynamic resizing.  


Overall, Arrays are a useful data structure in Java that provides fast and efficient access to elements. However, their fixed size and the other discussed cons can be a disadvantage in some situations. 

Conclusion 

By reading this blog, you will better understand Java Arrays and be able to use them effectively in your Java Programming. Furthermore, this blog on Java Arrays will give you an overall perspective of what you will and should learn to become an excellent Java Developer. 

Are you interested in learning web development using Java? Then, this Web Development Using Java Training is for you. Register Now! 

Frequently Asked Questions

What are the Three Types of Java? faq-arrow

The three types of Java are Java Standard Edition (Java SE), Java Enterprise Edition (Java EE), and Java Micro Edition (Java ME). Each type has its API, JVM, and different application and device features.

Which Interfaces are Implemented by Arrays in Java? faq-arrow

Arrays in Java implement functional interfaces, nested interfaces, marker interfaces and comparator interfaces.

What is the Knowledge Pass, and how does it work? faq-arrow

The Knowledge Academy’s Knowledge Pass, a prepaid voucher, adds another layer of flexibility, allowing course bookings over a 12-month period. Join us on a journey where education knows no bounds. 

What are Related Courses and Blogs Provided by The Knowledge Academy? faq-arrow

The Knowledge Academy offers various Java Courses, including Java Programming, JavaScript for Beginners and Java Swing Development Training. These courses cater to different skill levels, providing comprehensive insights into How to Become a Java Developer.  

Our Programming and DevOps Blogs cover a range of topics related to Java, offering valuable resources, best practices, and industry insights. Whether you are a beginner or looking to advance your Java Programming skills, The Knowledge Academy's diverse courses and informative blogs have you covered. 
 

What are the other resources provided by The Knowledge Academy? faq-arrow

The Knowledge Academy takes global learning to new heights, offering over 30,000 online courses across 490+ locations in 220 countries. This expansive reach ensures accessibility and convenience for learners worldwide. 

Alongside our diverse Online Course Catalogue, encompassing 17 major categories, we go the extra mile by providing a plethora of free educational Online Resources like News updates, Blogs, videos, webinars, and interview questions. Tailoring learning experiences further, professionals can maximise value with customisable Course Bundles of TKA.
 

Upcoming Programming & DevOps Resources Batches & Dates

Date

building Java Programming

Get A Quote

WHO WILL BE FUNDING THE COURSE?

close

close

Thank you for your enquiry!

One of our training experts will be in touch shortly to go over your training requirements.

close

close

Press esc to close

close close

Back to course information

Thank you for your enquiry!

One of our training experts will be in touch shortly to go overy your training requirements.

close close

Thank you for your enquiry!

One of our training experts will be in touch shortly to go over your training requirements.