15CS45 OOC Solutions - Dec 2017 - Jan 2018-1 PDF
15CS45 OOC Solutions - Dec 2017 - Jan 2018-1 PDF
15CS45 OOC Solutions - Dec 2017 - Jan 2018-1 PDF
Solution:
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
The compiler decides which function is to be called based upon the number, type, and
sequence of parameters that are passed to the function call.
1c. What is a constructor? List the different type of constructors and explain default 06
constructor with an example. Marks
Solution:
• The constructor gets called automatically for each object that has just got created.
• It appears as member function of each class, whether it is defined or not.
• It has the same name as that of the class.
• It may or may not take parameters.
• It does not return anything (not even void).
• The prototype of a constructor is
<Class name> (<parameter list>);
• The compiler embeds a call to the constructor for each object when it is created.
• The different types of constructors are:
o Zero-argument/ default constructor
o Parameterized constructor
o Explicit constructor
o Copy constructor
Default Constructor
• The constructor does not take any arguments and is called the default constructor.
• The constructor provided by default by the compiler also does not take any
arguments.
• Therefore, the terms ‘zero-argument constructor’ and ‘default constructor’ are
used interchangeably.
Example program
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
2a. Explain the concept of object-oriented programming 08
I) Encapsulation Marks
II) Polymorphism
III) Inheritance
IV) Data initialization
Solution:
Encapsulation - Encapsulation is the mechanism that binds together code and the data it
manipulates and keeps both safe from outside interference and misuse. One way to think
about encapsulation is as a protective wrapper that prevents the code and data from being
arbitrarily accessed by other code defined outside the wrapper. Access to the code and data
inside the wrapper is tightly controlled through a well-defined interface.
Inheritance - Inheritance is the process by which one object acquires the properties of
another object. This is important because it supports the concept of hierarchical
classification.
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
Data Initialization - Initialization of a variable provides its initial value at the time of
construction. The initial value may be provided in the initializer section of a declarator or a
new expression. It also takes place during function calls: function parameters and the
function return values are also initialized.
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
class A
{
};
/*End of A1.h*/
/*Beginning of A2.h*/
class A //a class with an existing name
{
};
/*End of A2.h*/
Now, let us include both these header files in a program and see what happens if we
declare an object of the class
#include “A1.h”
#include “A2.h”
void main()
{
A obj; // Ambiguity error due to multiple definitions of A
}
Enclosing the two definitions of the class in separate namespaces overcomes this problem.
/*Beginning of A1.h*/
namespace A1 //beginning of a namespace A1
{
class A
{
};
} //end of a namespace A1
/*End of A1.h*/
/*Beginning of A2.h*/
namespace A2 //beginning of a namespace A2
{
class A
{
};
} //end of a namespace A2
#include “A1.h”
#include “A2.h”
void main()
{
using namespace A1;
A obj1; // using object from namespace A1 from header file A1.h
using namespace A1;
A obj2; // using object from namespace A2 from header file A2.h
// or can be used as
A2::A a2obj2; // creates object of namespace A2 from A2.h
}
MODULE – II
3a. Explain how java is robust and interactive 05
Marks
Solution:
Robust: Java frees you from having to worry about many of the most common causes of
programming errors. Because Java is a strictly typed language, it checks your code at
compile time. However, it also checks your code at run time.
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
To better understand how Java is robust, consider two of the main reasons for program
failure:
1. memory management mistakes
2. Mishandled exceptional conditions (that is, run-time errors).
Memory management mistakes
Memory management can be a difficult, tedious task in traditional programming
environments. For example, in C/C++, the programmer must manually allocate and free all
dynamic memory. This sometimes leads to problems, because programmers will either
forget to free memory that has been previously allocated or, worse, try to free some memory
that another part of their code is still using. Java virtually eliminates these problems by
managing memory allocation and deallocation for you. (In fact, deallocation is completely
automatic, because Java provides garbage collection for unused objects.)
Interactive: Java programs carry with them substantial amounts of run-time type
information that is used to verify and resolve accesses to objects at run time. This makes it
possible to dynamically link code in a safe and expedient manner. This is crucial to the
robustness of the Java environment, in which small fragments of byte code may be
dynamically updated on a running system.
3b. Write a Java program to sum only first 5 elements of the array using for each loop. 05
Solution: Marks
import java.lang.*
class SumFirstFive
{
public static void main( String args[])
{
int arr[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int counter = 1, sum = 0;
for(int i : arr)
{
sum += i;
counter++;
if( counter == 5)
break;
}
System.out.println(“Sum of first 5 numbers is “ + sum);
}
}
Solution:
i) Modulus Operator - %
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
The modulus operator, %, returns the remainder of a division operation. It can be
applied to floating-point types as well as integer types. The following example
program demonstrates the %:
// Demonstrate the % operator.
class Modulus {
public static void main(String args[]) {
int x = 42;
double y = 42.25;
System.out.println("x mod 10 = " + x % 10);
System.out.println("y mod 10 = " + y % 10);
}
}
When you run this program, you will get the following output:
x mod 10 = 2
y mod 10 = 2.25
4a. Write a java program to initialize and display different types of integers and floating 06
point variables. Marks
Solution:
class IntegersAndFloating{
public static void main(String args[]){
byte b =10;
short s = 300;
int i = 20000;
long l = 3426987;
float f = 1.3456;
double d = 3.145674;
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
System.out.println(“Byte data = “ + b);
System.out.println(“short data = “ + s);
System.out.println(“int data = “ + i);
System.out.println(“long data = “ + l);
System.out.println(“float data = “ + f);
System.out.println(“double data = “ + d);
}
}
4b. What is type casting? Illustrate with an example. What is meant by automatic type 06
promotion? Marks
Solution:
The process of converting one data type to another data type is known as type conversion.
If the two types are compatible, then Java will perform the conversion automatically. For
example, it is always possible to assign an int value to a long variable.
A cast is simply an explicit type conversion.
It has this general form:
(target-type) value
The following program demonstrates some type conversions that require casts:
// Demonstrate casts.
class Conversion
{
public static void main(String args[])
{
int i;
double d = 323.142;
System.out.println("Conversion of double to int.");
i= (int) d;
System.out.println("integer is " + i);
}
}
This program generates the following output:
Conversion of double to int
integer is 323
4c. How to declare two dimensional arrays in Java? Explain with simple example. 04
Marks
Solution:
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
int twoD[][] = new int[4][5];
This allocates a 4 by 5 array and assigns it to twoD. Internally this matrix is implemented
as an array of arrays of int.
The following program numbers each element in the array from left to right, top to
bottom, and then displays these values:
Solution:
Access modifiers define the scope of the class and its members (data and methods). For
example, private members are accessible within the same class members (methods). Java
provides many levels of security that provides the visibility of members (variables and
methods) within the classes, subclasses, and packages.
Packages are meant for encapsulating, it works as containers for classes and other
subpackages. Class acts as containers for data and methods. There are four categories,
provided by Java regarding the visibility of the class members between classes and
packages:
• Subclasses in the same package
• Non-subclasses in the same package
• Subclasses in different packages
• Classes that are neither in the same package nor subclasses
The three main access modifiers private, public and protected provides a range of ways to
access required by these categories.
ACCESS PROTECTION IN PACKAGES
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
Simply remember, private cannot be seen outside of its class, public can be access from
anywhere, and protected can be accessible in subclass only in the hierarchy.
A class can have only two access modifier, one is default and another is public. If the class
has default access then it can only be accessed within the same package by any other code.
But if the class has public access then it can be access from any where by any other code.
try {
// block of code to monitor for errors
}
catch (ExceptionType1 exOb) {
// exception handler for ExceptionType1
}
catch (ExceptionType2 exOb) {
// exception handler for ExceptionType2
}
// ...
finally {
// block of code to be executed after try block ends
}
finally creates a block of code that will be executed after a try/catch block has completed
and before the code following the try/catch block. The finally block will execute whether
or not an exception is thrown.
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
6b. Illustrate with example a super class variable can reference a subclass object. 06
Marks
Solution:
A reference variable of a superclass can be assigned a reference to any subclass derived
from that superclass. For example, consider the following:
class RefDemo {
public static void main(String args[]) {
BoxWeight weightbox = new BoxWeight(3, 5, 7, 8.37);
Box plainbox = new Box();
double vol;
vol = weightbox.volume();
System.out.println("Volume of weightbox is " + vol);
System.out.println("Weight of weightbox is " + weightbox.weight);
System.out.println();
// assign BoxWeight reference to Box reference
plainbox = weightbox;
vol = plainbox.volume(); // OK, volume() defined in Box
System.out.println("Volume of plainbox is " + vol);
/* The following statement is invalid because plainbox
does not define a weight member. */
// System.out.println("Weight of plainbox is " + plainbox.weight);
}
}
MODULE – IV
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
7a. What is Thread? Explain two ways of creation of thread. 05
Marks
Solution:
A thread is a lightweight sub-process, the smallest unit of processing.
a) The easiest way to create a thread is to create a class that implements the Runnable interface. Runnable
abstracts a unit of executable code. You can construct a thread on any object that implements Runnable.
Output:
thread is running...
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
7b. What is synchronization? When do we use it? 05
Marks
Solution:
Synchronization in java is the capability to control the access of multiple threads to any
shared resource. Java Synchronization is better option where we want to allow only one
thread to access the shared resource.
keyEvents
This low-level event is generated by a component object (such as a text field) when a key
is pressed, released, or typed. The event is passed to every KeyListener or KeyAdapter
object which registered to receive such events using the component's addKeyListener
method. (KeyAdapter objects implement the KeyListener interface.) Each such listener
object gets this KeyEvent when the event occurs.
For key pressed and key released events, the getKeyCode method returns the event's
keyCode. For key typed events, the getKeyCode method always returns
VK_UNDEFINED. The getExtendedKeyCode method may also be used with many
international keyboard layouts.
"Key pressed" and "key released" events are lower-level and depend on the platform and
keyboard layout. They are generated whenever a key is pressed or released, and are the only
way to find out about keys that don't generate character input (e.g., action keys, modifier
keys, etc.). The key being pressed or released is indicated by the getKeyCode and
getExtendedKeyCode methods, which return a virtual key code.
Pressing and releasing a key on the keyboard results in the generating the following key
events (in order):
KEY_PRESSED
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
KEY_TYPED (is only generated if a valid Unicode character could be generated.)
KEY_RELEASED
MouseEvents
The MouseEvents class extends Applet and implements both the MouseListener and
MouseMotionListener interfaces. These two interfaces contain methods that receive and
process the various types of mouse events. Notice that the applet is both the source and the
listener for these events. This works because Component, which supplies the
addMouseListener( ) and addMouseMotionListener( ) methods, is a superclass of Applet.
Being both the source and the listener for events is a common situation for applets.
Inside init( ), the applet registers itself as a listener for mouse events. This is done by using
addMouseListener( ) and addMouseMotionListener( ), which, as mentioned, are members
of Component. They are shown here:
Here, ml is a reference to the object receiving mouse events, and mml is a reference to the
object receiving mouse motion events.
Events: The event object defines the change in state in the event source class. For example,
interacting with the graphical interfaces, such as clicking a button or entering text via
keyboard in a text box, item selection in a list, all represent some sort of change in the state.
The event object is used to carry the required information about the state change. However,
all events are not cause by user interaction. There are events such as timer event,
hardware/software events, and so forth, that do not depend upon user interaction. They
occur automatically. We can define the procedure to handle them once they occur.
Event sources: Event sources are objects that cause the events to occur due to some change
in the property of the component. Because there can be various types a component can
trigger, each must be registered to a listener to provide a suitable response.
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
Event listeners: Event listeners are objects that are notified as soon as a specific event
occurs. Event listeners must define the methods to process the notification they are
interested to receive.
8b. Explain the role of synchronization with producer and consumer problem. 08
Marks
Solution:
Java includes an elegant interprocess communication mechanism via
the wait( ), notify( ), and notifyAll( ) methods. These methods are implemented as final
methods in Object, so all classes have them. All three methods can be called only from
within a synchronized context. The rules for using these methods are actually quite simple:
• wait( ) tells the calling thread to give up the monitor and go to sleep until some
other thread enters the same monitor and calls notify( ).
• notify( ) wakes up a thread that called wait( ) on the same object.
• notifyAll( ) wakes up all the threads that called wait( ) on the same object. One of the
threads will be granted access.
These methods are declared within Object, as shown here:
final void wait( ) throws InterruptedException
final void notify( )
final void notifyAll( )
Consider the following sample program that implements a simple form of the producer/
consumer problem. It consists of four classes: Q, the queue that you’re trying to
synchronize; Producer, the threaded object that is producing queue entries; Consumer, the
threaded object that is consuming queue entries; and PC, the tiny class that creates the single
Q, Producer, and Consumer. The methods wait( ) and notify( ) to signal in both directions.
Inside get( ), wait( ) is called. This causes its execution to suspend until the Producer notifies
you that some data is ready. When this happens, execution inside get( ) resumes. After the
data has been obtained, get( ) calls notify( ). This tells Producer that it is okay to put more
data in the queue. Inside put( ), wait( ) suspends execution until the Consumer has removed
the item from the queue. When execution resumes, the next item of data is put in the queue,
and notify( ) is called. This tells the Consumer that it should now remove it. Implementation
of a producer and consumer program in Java is given below:
class Q {
int n;
boolean valueSet = false;
synchronized int get() {
while(!valueSet)
try {
wait();
} catch(InterruptedException e) {
System.out.println("InterruptedException caught");
}
System.out.println("Got: " + n);
valueSet = false;
notify();
return n;
}
synchronized void put(int n) {
while(valueSet)
try {
wait();
} catch(InterruptedException e) {
System.out.println("InterruptedException caught");
}
this.n = n;
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
valueSet = true;
System.out.println("Put: " + n);
notify();
}
}
class Producer implements Runnable {
Q q;
Producer(Q q) {
this.q = q;
new Thread(this, "Producer").start();
}
public void run() {
int i = 0;
while(true) {
q.put(i++);
}
}
}
class Consumer implements Runnable {
Q q;
Consumer(Q q) {
this.q = q;
new Thread(this, "Consumer").start();
}
public void run() {
while(true) {
q.get();
}
}
}
class PCFixed {
public static void main(String args[]) {
Q q = new Q();
new Producer(q);
new Consumer(q);
System.out.println("Press Control-C to stop.");
}
}
MODULE – V
9a. What is an applet? Explain five main methods of applet. 08
Marks
Solution:
Applet is a special type of program that is embedded in the webpage to generate the
dynamic content. It runs inside the browser and works at client side.
// An Applet skeleton.
import java.awt.*;
import java.applet.*;
/*
<applet code="AppletSkel" width=300 height=100>
</applet>
*/
public class AppletSkel extends Applet {
// Called first.
public void init() {
// initialization
}
/* Called second, after init(). Also called whenever
the applet is restarted. */
public void start() {
// start or resume execution
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
}
// Called when the applet is stopped.
public void stop() {
// suspends execution
}
/* Called when applet is terminated. This is the last
method executed. */
public void destroy() {
// perform shutdown activities
}
// Called when an applet's window must be restored.
public void paint(Graphics g) {
// redisplay contents of window
}
}
Applet Initialization and Termination
It is important to understand the order in which the various methods shown in the skeleton
are called. When an applet begins, the following methods are called, in this sequence:
1. init( )
2. start( )
3. paint( )
When an applet is terminated, the following sequence of method calls takes place:
1. stop( )
2. destroy( )
init( )
The init( ) method is the first method to be called. This is where you should initialize
variables. This method is called only once during the run time of your applet.
start( )
The start( ) method is called after init( ). It is also called to restart an applet after it has
been
stopped. Whereas init( ) is called once—the first time an applet is loaded—start( ) is called
each time an applet’s HTML document is displayed onscreen. So, if a user leaves a web
page and comes back, the applet resumes execution at start( ).
paint( )
The paint( ) method is called each time your applet’s output must be redrawn. This situation
can occur for several reasons. For example, the window in which the applet is running may
be overwritten by another window and then uncovered. Or the applet window may be
minimized and then restored. paint( ) is also called when the applet begins execution.
Whatever the cause, whenever the applet must redraw its output, paint( ) is called. The
paint( ) method has one parameter of type Graphics. This parameter will contain the
graphics context, which describes the graphics environment in which the applet is running.
This context is used whenever output to the applet is required.
stop( )
The stop( ) method is called when a web browser leaves the HTML document containing
the applet—when it goes to another page, for example. When stop( ) is called, the applet is
probably running. You should use stop( ) to suspend threads that don’t need to run when
the applet is not visible. You can restart them when start( ) is called if the user returns to
the page.
destroy( )
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
The destroy( ) method is called when the environment determines that your applet needs to
be removed completely from memory. At this point, you should free up any resources the
applet may be using. The stop( ) method is always called before destroy( ).
Solution:
(i) JLabel: JLabel is the simplest and easiest-to-use component because it does not accept
user input. It simply displays information, which can consist of text, an icon, or a
combination of the two. The label created by the program contains only text, which is
passed to its constructor. The next line of code creates a Swing JLabel component:
(ii) JTextfield: JTextField is the simplest Swing text component. It is also probably its most
widely used text component. JTextField allows you to edit one line of text. It is derived
from JTextComponent, which provides the basic functionality common to Swing text
components. JTextField uses the Document interface for its model.
Here, str is the string to be initially presented, and cols is the number of columns in the text
field. If no string is specified, the text field is initially empty. If the number of columns is
not specified, the text field is sized to fit the specified string.
(iii) JButton: The JButton class provides the functionality of a push button. JButton allows
an icon, a string, or both to be associated with the push button. Three of its constructors are
shown here:
JButton(Icon icon)
JButton(String str)
JButton(String str, Icon icon)
Here, str and icon are the string and icon used for the button.
(iv) JCheckBox: The JCheckBox class provides the functionality of a check box. Its
immediate superclass is JToggleButton, which provides support for two-state buttons.
JCheckBox defines several constructors. The one used here is JCheckBox(String str). It
creates a check box that has the text specified by str as a label. Other constructors let you
specify the initial selection state of the button and specify an icon.
When the user selects or deselects a check box, an ItemEvent is generated. You can obtain
a reference to the JCheckBox that generated the event by calling getItem( ) on the ItemEvent
passed to the itemStateChanged( ) method defined by ItemListener. The easiest way to
determine the selected state of a check box is to call isSelected( ) on the JCheckBox
instance.
10a. Create swing applet that has two buttons named beta and gamma. When either of the 08
buttons pressed, it should display “beta was pressed” and “gamma was pressed” Marks
respectively.
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
Solution:
import java.awt.event.*;
import javax.swing.*;
public class Beta_Gamma{
Beta_Gamma(){
JFrame f=new JFrame("Beta_Gamma Button Example");
final JTextField tf=new JTextField();
tf.setBounds(50,50, 150,20);
JButton b1=new JButton("Beta");
b1.setBounds(50,100,95,30);
b1.addActionListener(new ActionListener(){
public void actionPerformed(ActionEvent e){
tf.setText("Beta was pressed"); } });
JButton b2=new JButton("Gamma");
b2.setBounds(50,150,95,30);
b2.addActionListener(new ActionListener(){
public void actionPerformed(ActionEvent e){
tf.setText("Gamma was pressed");} });
f.add(tf);
f.add(b1);
f.add(b2);
f.setSize(400,400);
f.setLayout(null);
f.setVisible(true);
f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
public static void main(String[] args) {
new Beta_Gamma();
}
}
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98
The following applet illustrates these methods:
// Display code and document bases.
import java.awt.*;
import java.applet.*;
import java.net.*;
/*
<applet code="Bases" width=300 height=50>
</applet>
*/
public class Bases extends Applet{
// Display code and document bases.
public void paint(Graphics g) {
String msg;
URL url = getCodeBase(); // get code base
msg = "Code base: " + url.toString();
g.drawString(msg, 10, 20);
url = getDocumentBase(); // get document base
msg = "Document base: " + url.toString();
g.drawString(msg, 10, 40);
}
}
Sample output from this program is shown here:
Prepared by: Mr. R Rajkumar – Assistant Professor, Dept. of ISE, RNSIT, Bengaluru – 98