Which of the following stream operations is a terminal operation?

  • collect()
  • filter()
  • forEach()
  • mapToDouble()
In Java Streams API, a terminal operation is an operation that produces a result or a side-effect. The collect() method is a terminal operation that collects the elements of a stream into a new collection or performs some other final action. Options 1 to 3 are intermediate operations, which transform or filter the elements but do not terminate the stream.

When an array element, such as arr[2][3], is accessed, Java uses ________ to locate it in memory.

  • column-major order
  • linear search
  • random access
  • row-major order (or row-major indexing)
In Java, when you access an element in a two-dimensional array like arr[2][3], the system uses row-major order (or row-major indexing) to locate it in memory. This means it first traverses rows and then columns to find the desired element efficiently.

What is the worst-case time complexity of Linear Search?

  • O(1)
  • O(log n)
  • O(n)
  • O(n^2)
The worst-case time complexity of Linear Search is O(n), where 'n' is the number of elements in the data. In the worst scenario, the search may have to check every element in the list to find the target, making it a linear time algorithm.

Which exception might be thrown when opening a file for reading?

  • FileNotFoundException
  • FileOpenException
  • FileReadException
  • IOException
When opening a file for reading in Java, the FileNotFoundException might be thrown if the specified file does not exist or cannot be found. This exception is a subclass of IOException and is commonly used to handle file-related errors during file input operations. Other exceptions like FileReadException and FileOpenException are not standard Java exceptions.

In a scenario where you need to manage a large number of database connections, how would you optimize and manage database connectivity to ensure minimal resource usage and maximum performance?

  • Implementing a connection pool to reuse and manage database connections, thus reducing the overhead of opening and closing connections frequently.
  • Increasing the maximum number of concurrent connections allowed by the database server to accommodate high traffic.
  • Manually managing connections by creating a custom connection manager class to handle connection creation and release.
  • Opening a new database connection for each database operation to ensure fresh and up-to-date data access.
Managing database connections efficiently is crucial for resource usage and performance. Connection pooling is a widely-used technique where connections are reused, reducing the overhead of opening and closing connections repeatedly. Manually managing connections is error-prone and not recommended. Increasing the maximum connections may lead to resource exhaustion and reduced performance.

How does the use of synchronized methods or blocks affect the performance of a Java application and why?

  • It has no impact on performance.
  • It improves performance by speeding up method execution.
  • It may degrade performance due to thread contention.
  • It only affects memory management.
Synchronized methods or blocks can lead to performance degradation because they introduce thread contention. When multiple threads try to access synchronized code, they may block, waiting for access, which can lead to slowdowns. While synchronization is necessary for thread safety, it should be used judiciously, especially in high-throughput scenarios, to avoid excessive contention and performance issues.

Imagine a scenario where you need to send a text message over a network using Java. How would you utilize byte streams and character streams to ensure that the message is correctly received and encoded on the other side?

  • Use DataOutputStream to convert the text message to bytes and send it over the network, and DataInputStream to read and decode the message.
  • Use FileInputStream to send the message as bytes and FileReader to read and decode the message on the other side.
  • Use ObjectOutputStream to serialize the message and ObjectInputStream to deserialize it for network transmission.
  • Use PrintWriter to send the message as characters over the network, and Scanner to read and decode the message.
To send a text message over a network, you should use DataOutputStream to convert the message to bytes and DataInputStream to read and decode it. This ensures proper encoding and decoding of the message. PrintWriter and Scanner deal with characters, FileInputStream/FileReader with bytes, and ObjectOutputStream/ObjectInputStream with object serialization, which aren't ideal for text messages.

Can a constructor be private in Java?

  • No, constructors can only be package-private
  • No, constructors must always be public.
  • Yes, constructors can be private in Java.
  • Yes, constructors can only be protected.
Yes, constructors can be private in Java. A private constructor is often used in design patterns like Singleton to ensure that only one instance of a class can be created. It restricts external instantiation of the class.

What is the purpose of serialization in Java?

  • To convert objects into a byte stream
  • To create new objects
  • To perform mathematical calculations on objects
  • To sort objects
Serialization in Java is primarily used to convert objects into a byte stream so that they can be easily stored, transmitted over a network, or reconstructed at a later time. This is especially useful for saving object state, such as in file I/O or network communication.

Which of the following statements about the 'this' keyword is incorrect?

  • 'this' can be used to call other class constructors from within a constructor.
  • 'this' is used to reference the current instance of the class.
  • 'this' is used to create a new object of the class.
  • 'this' can be used to access instance variables and methods of the class.
The 'this' keyword in Java is primarily used to refer to the current instance of a class. It can be used to access instance variables and methods, and also to call other constructors of the same class. Option 3 is incorrect; 'this' does not create a new object but references the existing instance. Options 1, 2, and 4 are correct statements.