Automation Testing Interview Question - V1 - 0 - 1
Automation Testing Interview Question - V1 - 0 - 1
Automation testing is the process of testing a software or application using an automation testing
tool to find the defects. In this process, executing the test scripts and generating the results are
performed automatically by automation tools. It is required when we have huge amount of
regression test cases.Some most popular tools to do automation testing are HP QTP/UFT,
Selenium WebDriver etc.,
This is one of the common interview questions in any Automation testing job.
As we all know Selenium WebDriver is a tool which automates the browser to mimic real user
actions on the web. Selenium is a free open source testing tool. Some of the challenges with
selenium webdriver are as follows
It depends on Test case scenario complexity and length. I did automate 5-15 test scenarios per
day when the complexity is limited. Sometimes just 1 or fewer test scenarios in a day when the
complexity is high.
6. What is a Framework?
A framework defines a set of rules or best practices which we can follow in a systematic way to
achieve the desired results. There are different types of automation frameworks and the most
common ones are:
If you are a beginner: You can say “No, I didn’t get a chance to create framework from the
scratch. I have used the framework which is already available. My contribution is mostly in
creating test cases by using the existing framework.”
If you are a beginner but have good knowledge on creating framework: You can say “Yes, I
have involved in developing framework along with other automation tester in my company.”
If you are an experienced tester: You can say “I have contributed in developing framework.” or
You can say “Yes, I have created framework from the scratch. I designed the framework from
the scratch.”
8. Can you explain the Framework which you have used in your Selenium Project?
Explain about folder structure, test data implementation, Reporting, Configurable options for
environment, partial or full test suite execution.
Selenium is an open source (free) automated testing suite to test web applications. It supports
different platforms and browsers. It has gained a lot of popularity in terms of web-based
automated testing and giving a great competition to the famous commercial tool HP QTP (Quick
Test Professional) AKA HP UFT (Unified Functional Testing).
Selenium is a set of different software tools. Each tool has a different approach in supporting
web based automation testing.
Selenese is the language which is used to write test scripts in Selenium IDE.
13. Which is the only browser that supports Selenium IDE to be used?
Firefox
Selenium RC AKA Selenium Remote control / Selenium 1. Selenium Remote Control was the
main Selenium project for a long time before the WebDriver merge brought up Selenium 2.
Selenium 1 is still actively supported (in maintenance mode). It relies on JavaScript for
automation. It supports Java, Javascript, Ruby, PHP, Python, Perl and C#. It supports almost
every browser out there.
Selenium Grid is a tool used to run tests on different machines against different browsers in
parallel. That is, running multiple tests at the same time against different machines running
different browsers and operating systems.
In simple words, it is used to distribute your test execution on multiple platforms and
environments concurrently.
Selenium Grid can be used to execute same or different test scripts on multiple platforms and
browsers concurrently so as to achieve distributed test execution
It allows running test cases in parallel thereby saving test execution time.
It allows multi-browser testing
It allows us to execute test cases on multi-platform
A hub is a server or a central point that controls the test executions on different machines.
Node is the machine which is attached to the hub. There can be multiple nodes in Selenium Grid.
Firefox Driver
Gecko Driver
InternetExplorer Driver
Chrome Driver
HTMLUnit Driver
Opera Driver
Safari Driver
Android Driver
iPhone Driver
EventFiringWebDriver
22. Which WebDriver implementation claims to be the fastest?
Headless browser testing using Selenium WebDriver is done to test the application without any
visual interruption.
1. HTMLUnitDriver
2. PhantomJSDriver
1. It’s faster. The performance is better compared to browser automation. Automated testing
is to automate a browser to ensure that the application is running as expected. Running
regression scripts take lots of time. With headless browsers, we could save time.
2. It enables you to run the scripts on a system which doesn’t have a browser.
3. Imagine you have a situation to run some tests on a version of google chrome and there is
no such version of google chrome on your local system. In this case, you could use the
headless browser, most of the headless browsers support browser versions.
1. Debugging is a bit difficult using headless browsers. Here browser is not visible, the only
way is to capture a screenshot.
C#
Java
Python
Ruby
Perl
PHP
Windows
Linux
Apple
1. ID
2. ClassName
3. Name
4. TagName
5. LinkText
6. PartialLinkText
7. XPath
8. CSS Selector
XPath is used to locate the elements. Using XPath, we could navigate through elements and
attributes in an XML document to locate web elements such as textbox, button, checkbox, Image
etc., in a web page.
Single Slash “/” – Single slash is used to create XPath with absolute path i.e. the XPath would
be created to start selection from the document node/start node.
Double Slash “//” – Double slash is used to create XPath with relative path i.e. the XPath would
be created to start selection from anywhere within the document.
29. What is the difference between Absolute Path and Relative Path?
Absolute XPath starts from the root node and ends with desired descendant element’s node. It
starts with top HTML node and ends with input node. It starts with a single forward slash(/) as
shown below.
/html/body/div[3]/div[1]/form/tabl
1 /html/body/div[3]/div[1]/form/table/tbody/tr[1]/td/input
Relative XPath starts from any node in between the HTML page to the current element’s
node(last node of the element). It starts with a double forward slash(//) as shown below.
//input[@id='email']
1 //input[@id='email']
Assert: In simple words, if the assert condition is true then the program control will execute the
next test step but if the condition is false, the execution will stop and further test step will not be
executed.
Verify: In simple words, there won’t be any halt in the test execution even though the verify
condition is true or false.
Soft Assert: Soft Assert collects errors during @Test Soft Assert does not throw an exception
when an assert fails and would continue with the next step after the assert statement.
Hard Assert: Hard Assert throws an AssertException immediately when an assert statement
fails and test suite continues with next @Test
In Selenium IDE, we use Selenese Verify and Assert Commands as Verification points
In Selenium WebDriver, there is no built-in features for verification points. It totally depends on
our coding style. some of the Verification points are
Note: If you use geckodriver with Selenium, you must upgrade to Selenium 3.3. Here we have to
set the property as follows
System.setProperty("w ebdriver
SearchContext.
instead of creating
If we create a reference variable driver of type WebDriver then we could use the same driver
variable to work with any browser of our choice such as IEDriver, SafariDriver etc.,
38. What are the different exceptions you have faced in Selenium WebDriver?
1. ElementNotVisibleException
2. StaleElementReferenceException
This exception will be thrown when you are trying to locate a particular element on webpage that
is not currently visible eventhough it is present in the DOM. Also sometimes, if you are trying to
locate an element with the xpath which associates with two or more element.
A Stale Element Reference Exception is thrown in one of two cases, the first being more
common than the second.
We face this stale element reference exception when the element we are interacting is destroyed
and then recreated again. When this happens the reference of the element in the DOM becomes
stale. Hence we are not able to get the reference to the element.
WebDriverException
IllegalStateException
TimeoutException
NoAlertPresentException
NoSuchWindowException
NoSuchElementException etc
39. How to Login into any site if it is showing an Authentication Pop-Up for Username and
Password?
http://username:passw ord@url
e.g. http://myUserName:myPass
1 http://username:password@url
2 e.g. http://myUserName:[email protected]
In Selenium we could see three types of waits such as Implicit Waits, Explicit Waits and Fluent
Waits.
Implicit Waits
Explicit Waits
Fluent Waits
Implicit waits tell to the WebDriver to wait for a certain amount of time before it throws an
exception. Once we set the time, WebDriver will wait for the element based on the time we set
before it throws an exception. The default setting is 0 (zero). We need to set some wait time to
make WebDriver to wait for the required time.
WebDriverWait is applied on a certain element with defined expected condition and time. This
wait is only applied to the specified element. This wait can also throw an exception when an
element is not found.
FluentWait can define the maximum amount of time to wait for a specific condition and
frequency with which to check the condition before throwing an “ElementNotVisibleException”
exception.
44. How to input text in the text box using Selenium WebDriver?
45. How to input text in the text box without calling the sendKeys()?
// To initialize js object
JavascriptExecutor JS = (Javas
// To enter username
JS.executeScript("document.ge
1 // To initialize js object
2 JavascriptExecutor JS = (JavascriptExecutor)webdriver;
3 // To enter username
4 JS.executeScript("document.getElementById('User').value='SoftwareTestingMaterial.com'");
5 // To enter password
6 JS.executeScript("document.getElementById('Pass').value='tester'");
46. How to clear the text in the text box using Selenium WebDriver?
@Test
public void testmethod(){
System.setProperty("webdriver.chrome.driver", "D:\\Selenium Environment\\Drivers\\
chromedriver.exe");
WebDriver driver = new ChromeDriver();
driver.get("https://www.google.com");
String availableText = driver.findElement(By.xpath("//*[@id='gbw']/div/div/div[1]/div[1]/
a")).getText();
System.out.println("Text Available is :"+availableText);
}
}
By using getAttribute(value);
HTML:
<input name="nameSelenium" va
Selenium Code:
driver.findElement(By.linkText(“S
driver.findElement(By.id("form_1
1 driver.findElement(By.id("form_1")).submit();
Alternatively, you can use click method on the element which does form submission
To press ENTER key using Selenium WebDriver, We need to use Selenium Enum Keys with its
constant ENTER.
driver.findElement(By.xpath("xp
1 driver.findElement(By.xpath("xpath")).sendKeys(Keys.ENTER);
Thread.sleep(5000)
1 Thread.sleep(5000)
53. Is Selenium Server needed to run Selenium WebDriver Scripts?
When we are distributing our Selenium WebDriver scripts to execute using Selenium Grid, we
need to use Selenium Server.
driver.get("https://w w w .softw a
1 driver.get("https://www.softwaretestingmaterial.com");
55. What is the alternative to driver.get() method to open an URL using Selenium
WebDriver?
driver.get(): To open an URL and it will wait till the whole page gets loaded
driver.navigate.to(): To navigate to an URL and It will not wait till the whole page gets loaded
We use Navigate interface to do navigate back and forth in a browser. It has methods to move
back, forward as well as to refresh a page.
driver.navigate().forward(); – to navigate to the next web page with reference to the browser’s
history
driver.navigate().back(); – takes back to the previous webpage with reference to the browser’s
history
driver.navigate().refresh(); – to refresh the current web page thereby reloading all the web
elements
driver.navigate().to(“url”); – to launch a new web browser window and navigate to the
specified URL
driver.getCurrentUrl();
1 driver.getCurrentUrl();
To maximize browser window in selenium we use maximize() method. This method maximizes
the current window if it is not already maximized
1 driver.manage().window().maximize();
driver.manage().deleteAllCookie
1 driver.manage().deleteAllCookies();
62. What are the ways to refresh a browser using Selenium WebDriver?
Purpose of these two methods (driver.close and driver.quit) is almost same. Both allow us to
close a browser but still, there is a difference.
findElement() returns a single WebElement (found first) based on the locator passed as
parameter. Whereas findElements() returns a list of WebElements, all satisfying the
locator value passed.
Syntax of findElement()-
WebElement textbox = driver.findElement(By.id(“textBoxLocator”));
Syntax of findElements()-
List <WebElement> elements = element.findElements(By.id(“value”));
Another difference between the two is- if no element is found then findElement() throws
NoSuchElementException whereas findElements() returns a list of 0 elements.
WebDriver facilitates the user with the following methods to check the visibility of the web
elements. These web elements can be buttons, drop boxes, checkboxes, radio buttons, labels etc.
1. isDisplayed()
2. isSelected()
boolean eleSelected= driver.find
3. isEnabled()
WebElement mySelectElement =
Select dropdow n = new Select(
dropdow n.selectByVisibleText(
dropdow n.selectByIndex(Index
Test cases may fail while executing the test scripts. While we are executing the test cases
manually we just take a screenshot and place in a result repository. The same can be done by
using Selenium WebDriver.
Some of the scenarios we may need to capture a screenshot using Selenium WebDriver are
i. Application issues
ii. Assertion Failure
iii. Difficulty to find Webelements on the web page
iv. Timeout to find Webelements on the web page
Selenium provides an interface called TakesScreenshot which has a method getScreenShotAs
which can be used to take a screenshot of the application under test.
In Selenium 3, to handle issues while capturing Screenshots. we use aShot utility (additional jar
file) .
@Test
public static void captureScreenMethod() throws Exception{
System.setProperty("webdriver.gecko.driver","D://Selenium
Environment//Drivers//geckodriver.exe");
WebDriver driver = new FirefoxDriver();
driver.manage().window().maximize();
driver.get("http://www.girmiti.com");
File screenshotFile = ((TakesScreenshot)driver).getScreenshotAs(OutputType.FILE);
FileUtils.copyFile(screenshotFile, new File("D:\\SoftwareTesting.png"));
driver.close();
driver.quit();
}
To handle alerts popups we need to do switch to the alert window and call Selenium WebDriver
Alert API methods.
Selenium doesn’t support windows based applications. It is an automation testing tool which
supports only web application testing. We could handle windows based popups in
Selenium using some third party tools such as AutoIT, Sikuli, Robot class etc.
(JavascriptExecutor(driver)).ex
(JavascriptExecutor(driver)).executeScript("document.getElementsByClassName(ElementLoca
1
tor).click();");
73. How can you find Broken Links in a page using Selenium WebDriver?
@Test
System.setProperty("webdriver.chrome.driver", "C:\\resources\\chromedriver.exe");
driver.get("https://www.google.com/");
for(int i=0;i<allLinks.size();i++) {
httpcon.setConnectTimeout(2000);
httpcon.connect();
System.out.println(httpcon.getResponseCode());
74. How to find more than one web element in the list?
// To store the list
List <WebElement> eleList = driv
// To fetch the size of the list
int listSize = eleList.size();
By using JavascriptExecutor
For example:
driver.findElement(By.id("Id Valu
1 driver.findElement(By.id("Id Value")).click();
Sometimes web controls don’t react well against selenium commands and we may face issues
with the above statement (click()). To overcome such kind of situation, we
use JavaScriptExecutor interface.
There is no need to write a separate script to execute JavaScript within the browser
using Selenium WebDriver script. Just we use predefined interface named ‘Java Script
Executor’. We need to import the JavascriptExecutor package in the script.
Package:
import org.openqa.selenium.Jav
1 import org.openqa.selenium.JavascriptExecutor;
Syntax:
JavascriptExecutor js = (Javasc
js.executeScript(Script,Argume
Test data can efficiently be read from excel using JXL or POI API. POI API has many
advantages than JXL.
No, It’s not possible to automate captcha and bar code reader.
Handling AJAX calls is one of the common issues when using Selenium WebDriver. We
wouldn’t know when the AJAX call would get completed and the page has been updated. In this
post, we see how to handle AJAX calls using Selenium.
AJAX stands for Asynchronous JavaScript and XML. AJAX allows the web page to retrieve
small amounts of data from the server without reloading the entire page. AJAX sends HTTP
requests from the client to server and then process the server’s response without reloading the
entire page. To handle AJAX controls, wait commands may not work. It’s just because the actual
page is not going to refresh.
When you click on a submit button, the required information may appear on the web page
without refreshing the browser. Sometimes it may load in a second and sometimes it may take
longer. We have no control over loading time. The best approach to handle this kind of situations
in selenium is to use dynamic waits (i.e. WebDriverWait in combination with
ExpectedCondition)
1. titleIs() – The expected condition waits for a page with a specific title.
w ait.until(ExpectedConditions.tit
1 wait.until(ExpectedConditions.elementToBeClickable(By.xpath("xpath")));
w ait.until(ExpectedConditions.a
1 wait.until(ExpectedConditions.alertIsPresent()) !=null);
w ait.until(ExpectedConditions.te
80. List some scenarios which we cannot automate using Selenium WebDriver?
Object Repository is used to store element locator values in a centralized location instead of hard
coding them within the scripts. We do create a property file (.properties) to store all the element
locators and these property files act as an object repository in Selenium WebDriver.
In Selenium, we call objects as locators (such as ID, Name, Class Name, Tag Name, Link Text,
Partial Link Text, XPath, and CSS). Object repository is a collection of objects. One of the ways
to create Object Repository is to place all the locators in a separate file (i.e., properties file). But
the best way is to use Page Object Model. In the Page Object Model Design Pattern, each web
page is represented as a class. All the objects related to a particular page of a web application are
stored in a class.
83. What is Page Object Model in Selenium?
Page Object Model (POM) is a Design Pattern which has become popular in Selenium Test
Automation. It is widely used design pattern in Selenium for enhancing test maintenance and
reducing code duplication. Page object model (POM) can be used in any kind of framework such
as modular, data-driven,keyword driven, hybrid framework etc. A page object is an object-
oriented class that serves as an interface to a page of your Application Under Test(AUT). The
tests then use the methods of this page object class whenever they need to interact with the User
Interface (UI) of that page. The benefit is that if the UI changes for the page, the tests themselves
don’t need to change, only the code within the page object needs to change. Subsequently, all
changes to support that new UI is located in one place.
We have seen that ‘Page Object Model’ is a way of representing an application in a test
framework. For every ‘page’ in the application, we create a Page Object to reference the ‘page’
whereas a ‘Page Factory’ is one way of implementing the ‘Page Object Model’.
85. What is the difference between Page Object Model (POM) and Page Factory?
Page Object is a class that represents a web page and hold the functionality and members.
Page Factory is a way to initialize the web elements you want to interact with within the page
object when you create an instance of it.
Code reusability – We could achieve code reusability by writing the code once and use it in
different tests.
Code maintainability – There is a clean separation between test code and page specific code
such as locators and layout which becomes very easy to maintain code. Code changes only on
Page Object Classes when a UI change occurs. It enhances test maintenance and reduces code
duplication.
Object Repository – Each page will be defined as a java class. All the fields in the page will be
defined in an interface as members. The class will then implement the interface.
Readability – Improves readability due to clean separation between test code and page specific
code
87. How can you use the Recovery Scenario in Selenium WebDriver?
1 try {
2 driver.get("www.SoftwareTestingMaterial.com");
3 }catch(Exception e){
4 System.out.println(e.getMessage());
5}
There are two cases which are majorly used to upload a file in Selenium WebDriver such
as using SendKeys Method and using AutoIT Script.
90. How to run Selenium WebDriver Test from the command line?
1. Run testng.xml file from command line with the following commands
set projectLocation=C:\Users\Admin\Desktop\STMSeleniumTutorial\workspace\
SoftwareTestingMaterial
cd %projectLocation%
set classpath=%projectLocation%\bin;%projectLocation%\lib\*
Run testng.xml
2. Run testng.xml from pom.xml using failsafe or surefire plugin, if it is maven project
By using the following code, we could switch between frames using frame id or frame name
driver.sw itchTo().frame();
As we all know Selenium WebDriver is a tool to automate User Interface. We could only interact
with Browser using Selenium WebDriver.
We use JDBC Driver to connect the Database in Selenium (While using Java Programming
Language).
To resize the browser window to particular dimensions, we use ‘Dimension’ class to resize the
browser window.
driver.manage().window().setSize(d);
JavaScript scrollBy() method scrolls the document by the specified number of pixels.
js.executeScript("window.scrollBy(0,250)", "");
95. How To Perform Right Click Action (Context Click) In Selenium WebDriver?
action.contextClick(WebElement).build().perform();
action.doubleClick(webelement).build().perform();
97. How To Perform Drag And Drop Action in Selenium WebDriver?
action.dragAndDrop(sourceLocator, targetLocator).build().perform();
99. Have you used any crossbrowsertesting tool to run selenium scripts on cloud?
DesiredCapabilities desiredCapa
As we all know Selenium WebDriver is a tool to automate User Interface. We could only interact
with Browser using Selenium WebDriver.
Sometimes, we may face a situation to get the data from the Database or to modify
(update/delete) the data from the Database. If we plan to automate anything outside the vicinity
of a browser, then we need to use other tools to achieve our task. To achieve the Database
connection and work on it, we need to use JDBC API Driver.
The Java Database Connectivity (JDBC) API provides universal data access from the Java
programming language. Using the JDBC API, you can access virtually any data source, from
relational databases to spreadsheets and flat files. It lets the user connect and interact with the
Database and fetch the data based on the queries we use in the automation script. JDBC is a SQL
level API that allows us to execute SQL statements. It creates a connectivity between Java
Programming Language and the database.
driver.Manage().Cookies.Delete
1 driver.Manage().Cookies.DeleteAllCookies();
TestNG is a testing framework designed to simplify a broad range of testing needs, from unit
testing to integration testing. TestNG will give flexibility to the user to develop and execute
automated tests.
106. What is TestNG Assert and list out some common Assertions supported by TestNG?
TestNG Asserts help us to verify the condition of the test in the middle of the test run. Based on
the TestNG Assertions, we will consider a successful test only if it is completed the test run
without throwing any exception.
In TestNG framework, we need to create TestNG XML file to create and handle multiple test
classes. We do configure our test run, set test dependency, include or exclude any test, method,
class or package and set priority etc in the XML file.
We use priority attribute to the @Test annotations. In case priority is not set then the test scripts
execute in alphabetical order.
package TestNG;
import org.testng.annotations.*;
public class PriorityTestCase{
@Test(priority=0)
1 package TestNG;
2 import org.testng.annotations.*;
3 public class PriorityTestCase{
4 @Test(priority=0)
5 public void testCase1() {
6 system.out.println("Test Case 1");
7 }
8 @Test(priority=1)
9 public void testCase2() {
10 system.out.println("Test Case 2");
11 }
12 }
Output:
Test Case 1
Test Case 2
1 Test Case 1
2 Test Case 2
Parameterized tests allow developers to run the same test over and over again using different
values.
with testng.xml
@Test
@Parameters("browser")
public void parameterizedTest(String browser){
if(browser.equals("firefox")){
System.out.println("Open Firefox Driver");
}else if(browser.equals("chrome")){
System.out.println("Open Chrome Driver");
}
}
@Test (dataProvider="getData")
//If the name is not supplied, the data provider’s name automatically defaults to the method’s
name.
@DataProvider(name="getData")
data[1][0] = "SecondUid";
data[1][1] = "SecondPWD";
return data;
Groups are specified in your testng.xml file and can be found either under the <test> or <suite>
tag. Groups specified in the <suite> tag apply to all the <test> tags underneath.
Ans. TestNG listeners are used to configure reports and logging. One of the most widely used
listeners in TestNG is ITestListener interface. It has methods like onTestStart, onTestSuccess,
onTestFailure, onTestSkipped etc. We should implement this interface creating a listener class of
our own. Next, we should add the listeners annotation (@Listeners) in the Class which was
created.
@DataProvider(name="getData"
public Object[][] getDa
//Object [][]
Object [][] d
@DataProvider(name="getData")
public Object[][] getData(){
//Object [][] data = new Object [rowCount][colCount];
Object [][] data = new Object [2][2];
data [0][0] = "FirstUid";
data [0][1] = "FirstPWD";
data[1][0] = "SecondUid";
data[1][1] = "SecondPWD";
return data;
}
1) What is Java?
Java is the high-level, object-oriented, robust, secure programming language, platform-
independent, high performance, Multithreaded, and portable programming language. It was
developed by James Gosling in June 1991. It can also be known as the platform as it provides its
own JRE and API.
The differences between C++ and Java are given in the following table.
Comparison
C++ Java
Index
Platform-
C++ is platform-dependent. Java is platform-independent.
independent
Java is mainly used for application
C++ is mainly used for system programming. It is widely used in window,
Mainly used for
programming. web-based, enterprise and mobile
applications.
Java was designed and created as an
C++ was designed for systems interpreter for printing systems but later
Design Goal and applications programming. extended as a support network computing. It
It was an extension of C was designed with a goal of being easy to
use and accessible to a broader audience.
C++ supports the goto
Goto Java doesn't support the goto statement.
statement.
Java doesn't support multiple inheritance
Multiple C++ supports multiple
through class. It can be achieved by
inheritance inheritance.
interfaces.
Operator C++ supports operator
Java doesn't support operator overloading.
Overloading overloading
Java supports pointer internally. However,
C++ supports pointers. You can you can't write the pointer program in java.
Pointers
write pointer program in C++. It means java has restricted pointer support
in java.
Compiler and C++ uses compiler only. C++ is Java uses compiler and interpreter both.
Interpreter compiled and run using the Java source code is converted into bytecode
compiler which converts source at compilation time. The interpreter executes
code into machine code so, C+ this bytecode at runtime and produces
+ is platform dependent. output. Java is interpreted that is why it is
platform independent.
Call by Value and C++ supports both call by value Java supports call by value only. There is no
Call by reference and call by reference. call by reference in java.
Structure and C++ supports structures and
Java doesn't support structures and unions.
Union unions.
C++ doesn't have built-in
support for threads. It relies on
Thread Support Java has built-in thread support.
third-party libraries for thread
support.
Java supports documentation comment
Documentation C++ doesn't support
(/** ... */) to create documentation for java
comment documentation comment.
source code.
Java has no virtual keyword. We can
C++ supports virtual keyword
override all non-static methods by default.
Virtual Keyword so that we can decide whether
In other words, non-static methods are
or not override a function.
virtual by default.
Java supports unsigned right shift >>>
unsigned right C++ doesn't support >>> operator that fills zero at the top for the
shift >>> operator. negative numbers. For positive numbers, it
works same like >> operator.
Java uses a single inheritance tree always
C++ creates a new inheritance because all classes are the child of Object
Inheritance Tree
tree always. class in java. The object class is the root of
the inheritance tree in java.
Hardware C++ is nearer to hardware. Java is not so interactive with hardware.
Java is also an object-oriented language.
C++ is an object-oriented
However, everything (except fundamental
language. However, in C
Object-oriented types) is an object in Java. It is a single root
language, single root hierarchy
hierarchy as everything gets derived from
is not possible.
java.lang.Object.
Simple: Java is easy to learn. The syntax of Java is based on C++ which makes easier to
write the program in it.
Object-Oriented: Java follows the object-oriented paradigm which allows us to maintain
our code as the combination of different type of objects that incorporates both data and
behavior.
Portable: Java supports read-once-write-anywhere approach. We can execute the Java
program on every machine. Java program (.java) is converted to bytecode (.class) which
can be easily run on every machine.
Platform Independent: Java is a platform independent programming language. It is
different from other programming languages like C and C++ which needs a platform to be
executed. Java comes with its platform on which its code is executed. Java doesn't depend
upon the operating system to be executed.
Secured: Java is secured because it doesn't use explicit pointers. Java also provides the
concept of ByteCode and Exception handling which makes it more secured.
Robust: Java is a strong programming language as it uses strong memory management.
The concepts like Automatic garbage collection, Exception handling, etc. make it more
robust.
Architecture Neutral: Java is architectural neutral as it is not dependent on the
architecture. In C, the size of data types may vary according to the architecture (32 bit or
64 bit) which doesn't exist in Java.
Interpreted: Java uses the Just-in-time (JIT) interpreter along with the compiler for the
program execution.
High Performance: Java is faster than other traditional interpreted programming
languages because Java bytecode is "close" to native code. It is still a little bit slower than
a compiled language (e.g., C++).
Multithreaded: We can write Java programs that deal with many tasks at once by
defining multiple threads. The main advantage of multi-threading is that it doesn't occupy
memory for each thread. It shares a common memory area. Threads are important for
multi-media, Web applications, etc.
Distributed: Java is distributed because it facilitates users to create distributed
applications in Java. RMI and EJB are used for creating distributed applications. This
feature of Java makes us able to access files by calling the methods from any machine on
the internet.
Dynamic: Java is a dynamic language. It supports dynamic loading of classes. It means
classes are loaded on demand. It also supports functions from its native languages, i.e., C
and C++.
Java Virtual Machine is a virtual machine that enables the computer to run the Java program.
JVM acts like a run-time engine which calls the main method present in the Java code. JVM is
the specification which must be implemented in the computer system. The Java code is compiled
by JVM to be a Bytecode which is machine independent and close to the native code.
5) What is the difference between JDK, JRE, and JVM?
JVM
JVM is an acronym for Java Virtual Machine; it is an abstract machine which provides the
runtime environment in which Java bytecode can be executed. It is a specification which specifies
the working of Java Virtual Machine. Its implementation has been provided by Oracle and other
companies. Its implementation is known as JRE.
JVMs are available for many hardware and software platforms (so JVM is platform dependent). It
is a runtime instance which is created when we run the Java class. There are three notions of the
JVM: specification, implementation, and instance.
JRE
JRE stands for Java Runtime Environment. It is the implementation of JVM. The Java Runtime
Environment is a set of software tools which are used for developing Java applications. It is used
to provide the runtime environment. It is the implementation of JVM. It physically exists. It
contains a set of libraries + other files that JVM uses at runtime.
JDK
JDK is an acronym for Java Development Kit. It is a software development environment which is
used to develop Java applications and applets. It physically exists. It contains JRE + development
tools. JDK is an implementation of any one of the below given Java Platforms released by Oracle
Corporation:
Many types:
1. Class(Method) Area: Class Area stores per-class structures such as the runtime constant
pool, field, method data, and the code for methods.
2. Heap: It is the runtime data area in which the memory is allocated to the objects
3. Stack: Java Stack stores frames. It holds local variables and partial results, and plays a
part in method invocation and return. Each thread has a private JVM stack, created at the
same time as the thread. A new frame is created each time a method is invoked. A frame
is destroyed when its method invocation completes.
4. Program Counter Register: PC (program counter) register contains the address of the
Java virtual machine instruction currently being executed.
5. Native Method Stack: It contains all the native methods used in the application.
Just-In-Time(JIT) compiler: It is used to improve the performance. JIT compiles parts of the
bytecode that have similar functionality at the same time, and hence reduces the amount of time
needed for compilation. Here the term “compiler” refers to a translator from the instruction set of
a Java virtual machine (JVM) to the instruction set of a specific CPU.
9) What are the main differences between the Java platform and other platforms?
There are the following differences between the Java platform and other platforms.
Java is the software-based platform whereas other platforms may be the hardware
platforms or software-based platforms.
Java is executed on the top of other hardware platforms whereas other platforms can only
have the hardware components.
10) What gives Java its 'write once and run anywhere' nature?
The bytecode. Java compiler converts the Java programs into the class file (Byte Code) which is
the intermediate language between source code and machine code. This bytecode is not platform
specific and can be executed on any computer.
Classloader is a subsystem of JVM which is used to load class files. Whenever we run the java
program, it is loaded first by the classloader. There are three built-in classloaders in Java.
1. Bootstrap ClassLoader: This is the first classloader which is the superclass of Extension
classloader. It loads the rt.jar file which contains all class files of Java Standard Edition
like java.lang package classes, java.net package classes, java.util package classes, java.io
package classes, java.sql package classes, etc.
2. Extension ClassLoader: This is the child classloader of Bootstrap and parent classloader
of System classloader. It loads the jar files located inside $JAVA_HOME/jre/lib/ext
directory.
3. System/Application ClassLoader: This is the child classloader of Extension classloader.
It loads the class files from the classpath. By default, the classpath is set to the current
directory. You can change the classpath using "-cp" or "-classpath" switch. It is also
known as Application classloader.
Yes, Java allows to save our java file by .java only, we need to compile it by javac .java and run
by java classname Let's take a simple example:
run it by java A
No.
14) If I don't provide any arguments on the command line, then what will the value stored
in the String array passed into the main() method, empty or NULL?
The program compiles and runs correctly because the order of specifiers doesn't matter in Java.
The local variables are not initialized to any default value, neither primitives nor object
references.
In Java, access specifiers are the keywords which are used to define the access scope of the
method, class, or a variable. In Java, there are four access specifiers given below.
Public The classes, methods, or variables which are defined as public, can be accessed by
any class or method.
Protected Protected can be accessed by the class of the same package, or by the sub-class
of this class, or within the same class.
Default Default are accessible within the package only. By default, all the classes,
methods, and variables are of default scope.
Private The private class, methods, or variables defined as private can be accessed within
the class only.
The methods or variables defined as static are shared among all the objects of the class. The static
is the part of the class and not of the object. The static variables are stored in the class area, and
we do not need to create the object to access such variables. Therefore, static is used in the case,
where we need to define variables or methods which are common to all the objects of the class.
For example, In the class simulating the collection of the students in a college, the name of the
college is the common attribute to all the students. Therefore, the college name will be defined as
static.
1. class Test
2. {
3. public static void main (String args[])
4. {
5. System.out.println(10 + 20 + "Javatpoint");
6. System.out.println("Javatpoint" + 10 + 20);
7. }
8. }
30Javatpoint
Javatpoint1020
Explanation
In the first case, 10 and 20 are treated as numbers and added to be 30. Now, their sum 30 is
treated as the string and concatenated with the string Javatpoint. Therefore, the output will be
30Javatpoint.
In the second case, the string Javatpoint is concatenated with 10 to be the string Javatpoint10
which will then be concatenated with 20 to be Javatpoint1020.
1. class Test
2. {
3. public static void main (String args[])
4. {
5. System.out.println(10 * 20 + "Javatpoint");
6. System.out.println("Javatpoint" + 10 * 20);
7. }
8. }
200Javatpoint
Javatpoint200
Explanation
In the first case, The numbers 10 and 20 will be multiplied first and then the result 200 is treated
as the string and concatenated with the string Javatpoint to produce the output 200Javatpoint.
In the second case, The numbers 10 and 20 will be multiplied first to be 200 because the
precedence of the multiplication is higher than addition. The result 200 will be treated as the
string and concatenated with the string Javatpointto produce the output as Javatpoint200.
1. class Test
2. {
3. public static void main (String args[])
4. {
5. for(int i=0; 0; i++)
6. {
7. System.out.println("Hello Javatpoint");
8. }
9. }
10. }
The above code will give the compile-time error because the for loop demands a boolean value in
the second part and we are providing an integer value, i.e., 0.
It is a programming paradigm based on objects having data and methods defined in the class to
which it belongs. Object-oriented paradigm aims to incorporate the advantages of modularity and
reusability. Objects are the instances of classes which interacts with one another to design
applications and programs. There are the following features of the object-oriented paradigm.
The Object is the real-time entity having some state and behavior. In Java, Object is an instance
of the class having the instance variables as the state of the object and the methods as the
behavior of the object. The object of a class can be created by using the new keyword.
25) What is the difference between an object-oriented programming language and object-
based programming language?
There are the following basic differences between the object-oriented language and object-based
language.
Object-oriented languages follow all the concepts of OOPs whereas, the object-based
language doesn't follow all the concepts of OOPs like inheritance and polymorphism.
Object-oriented languages do not have the inbuilt objects whereas Object-based languages
have the inbuilt objects, for example, JavaScript has window object.
Examples of object-oriented programming are Java, C#, Smalltalk, etc. whereas the
examples of object-based languages are JavaScript, VBScript, etc.
26) What will be the initial value of an object reference which is defined as an instance
variable?
The constructor can be defined as the special type of method that is used to initialize the state of
an object. It is invoked when the class is instantiated, and the memory is allocated for the object.
Every time, an object is created using the new keyword, the default constructor of the class is
called. The name of the constructor must be similar to the class name. The constructor must not
have an explicit return type.
Based on the parameters passed in the constructors, there are two types of constructors in Java.
Default Constructor: default constructor is the one which does not accept any value. The
default constructor is mainly used to initialize the instance variable with the default
values. It can also be used for performing some useful task on object creation. A default
constructor is invoked implicitly by the compiler if there is no constructor defined in the
class.
Parameterized Constructor: The parameterized constructor is the one which can
initialize the instance variables with the given values. In other words, we can say that the
constructors which can accept the arguments are called parameterized constructors.
The purpose of the default constructor is to assign the default value to the objects. The java
compiler creates a default constructor implicitly if there is no constructor in the class.
1. class Student3{
2. int id;
3. String name;
4.
5. void display(){System.out.println(id+" "+name);}
6.
7. public static void main(String args[]){
8. Student3 s1=new Student3();
9. Student3 s2=new Student3();
10. s1.display();
11. s2.display();
12. }
13. }
Output:
0 null
0 null
Explanation: In the above class, you are not creating any constructor, so compiler provides you a
default constructor. Here 0 and null values are provided by default constructor.
Ans: yes, The constructor implicitly returns the current instance of the class (You can't use an
explicit return type with the constructor).
Yes, the constructors can be overloaded by changing the number of arguments accepted by the
constructor or by changing the data type of the parameters. Consider the following example.
1. class Test
2. {
3. int i;
4. public Test(int k)
5. {
6. i=k;
7. }
8. public Test(int k, int m)
9. {
10. System.out.println("Hi I am assigning the value max(k, m) to i");
11. if(k>m)
12. {
13. i=k;
14. }
15. else
16. {
17. i=m;
18. }
19. }
20. }
21. public class Main
22. {
23. public static void main (String args[])
24. {
25. Test test1 = new Test(10);
26. Test test2 = new Test(12, 15);
27. System.out.println(test1.i);
28. System.out.println(test2.i);
29. }
30. }
31.
In the above program, The constructor Test is overloaded with another constructor. In the first
call to the constructor, The constructor with one argument is called, and i will be initialized with
the value 10. However, In the second call to the constructor, The constructor with the 2
arguments is called, and i will be initialized with the value 15.
There is no copy constructor in java. However, we can copy the values from one object to another
like copy constructor in C++.
There are many ways to copy the values of one object into another in java. They are:
By constructor
By assigning the values of one object into another
By clone() method of Object class
In this example, we are going to copy the values of one object into another using java constructor.
Output:
111 Karan
111 Karan
35) What are the differences between the constructors and methods?
There are many differences between constructors and methods. They are given below.
a = 10 b = 15
Here, the data type of the variables a and b, i.e., byte gets promoted to int, and the first
parameterized constructor with the two integer parameters is called.
1. class Test
2. {
3. int i;
4. }
5. public class Main
6. {
7. public static void main (String args[])
8. {
9. Test test = new Test();
10. System.out.println(test.i);
11. }
12. }
The output of the program is 0 because the variable i is initialized to 0 internally. As we know
that a default constructor is invoked implicitly if there is no constructor in the class, the variable i
is initialized to 0 since there is no constructor in the class.
1. class Test
2. {
3. int test_a, test_b;
4. Test(int a, int b)
5. {
6. test_a = a;
7. test_b = b;
8. }
9. public static void main (String args[])
10. {
11. Test test = new Test();
12. System.out.println(test.test_a+" "+test.test_b);
13. }
14. }
There is a compiler error in the program because there is a call to the default constructor in the
main method which is not present in the class. However, there is only one parameterized
constructor in the class Test. Therefore, no default constructor is invoked by the constructor
implicitly.
The static variable is used to refer to the common property of all objects (that is not unique for
each object), e.g., The company name of employees, college name of students, etc. Static variable
gets memory only once in the class area at the time of class loading. Using a static variable makes
your program more memory efficient (it saves memory). Static variable belongs to the class
rather than the object.
More Details.
41) What are the restrictions that are applied to the Java static methods?
Two main restrictions are applied to the static methods.
The static method can not use non-static data member or call the non-static method
directly.
this and super cannot be used in static context as they are non-static.
Because the object is not required to call the static method. If we make the main method non-
static, JVM will have to create its object first and then call main() method which will lead to the
extra memory allocation.
Static block is used to initialize the static data member. It is executed before the main method, at
the time of classloading.
1. class A2{
2. static{System.out.println("static block is invoked");}
3. public static void main(String args[]){
4. System.out.println("Hello main");
5. }
6. }
Ans) Yes, one of the ways to execute the program without the main method is using static block.
46) What if the static modifier is removed from the signature of the main method?
Program compiles. However, at runtime, It throws an error "NoSuchMethodError."
47) What is the difference between static (class) method and instance method?
As we know that the static context (method, block, or variable) belongs to the class, not the
object. Since Constructors are invoked only when the object is created, there is no sense to make
the constructors static. However, if you try to do so, the compiler will show the compiler error.
In Java, if we make the abstract methods static, It will become the part of the class, and we can
directly call it which is unnecessary. Calling an undefined method is completely useless therefore
it is not allowed.
50) Can we declare the static variables and methods in an abstract class?
Yes, we can declare static variables and methods in an abstract method. As we know that there is
no requirement to make the object to access the static context, therefore, we can access the static
context declared inside the abstract class by using the name of the abstract class. Consider the
following example.
1. abstract class Test
2. {
3. static int i = 102;
4. static void TestMethod()
5. {
6. System.out.println("hi !! I am good !!");
7. }
8. }
9. public class TestClass extends Test
10. {
11. public static void main (String args[])
12. {
13. Test.TestMethod();
14. System.out.println("i = "+Test.i);
15. }
16. }
Output
hi !! I am good !!
i = 102
The this keyword is a reference variable that refers to the current object. There are the various
uses of this keyword in Java. It can be used to refer to current class properties such as instance
methods, variable, constructors, etc. It can also be passed as an argument into the methods or
constructors. It can also be returned from the method as the current class instance.
52) What are the main uses of this keyword?
No, this cannot be assigned to any value because it always points to the current class object and
this is the final reference in Java. However, if we try to do so, the compiler error will be shown.
Consider the following example.
Output
Yes, It is possible to use this keyword to refer static members because this is just a reference
variable which refers to the current class object. However, as we know that, it is unnecessary to
access static variables through objects, therefore, it is not the best practice to use this to refer
static members. Consider the following example.
Output
10
Constructor chaining enables us to call one constructor from another constructor of the class with
respect to the current class object. We can use this keyword to perform constructor chaining
within the same class. Consider the following example which illustrates how can we use this
keyword to achieve constructor chaining.
Output
56) What are the advantages of passing this into a method instead of the current class object
itself?
As we know, that this refers to the current class object, therefore, it must be similar to the current
class object. However, there can be two main advantages of passing this into a method instead of
the current class object.
this is a final variable. Therefore, this cannot be assigned to any new value whereas the
current class object might not be final and can be changed.
this can be used in the synchronized block.
Inheritance is a mechanism by which one object acquires all the properties and behavior of
another object of another class. It is used for Code Reusability and Method Overriding. The idea
behind inheritance in Java is that you can create new classes that are built upon existing classes.
When you inherit from an existing class, you can reuse methods and fields of the parent class.
Moreover, you can add new methods and fields in your current class also. Inheritance represents
the IS-A relationship which is also known as a parent-child relationship.
Single-level inheritance
Multi-level inheritance
Multiple Inheritance
Hierarchical Inheritance
Hybrid Inheritance
Multiple inheritance is not supported in Java through class.
There are various advantages of using inheritance in Java that is given below.
Inheritance provides code reusability. The derived class does not need to redefine the
method of base class unless it needs to provide the specific implementation of the method.
Runtime polymorphism cannot be achieved without using inheritance.
We can simulate the inheritance of classes with the real-time objects which makes OOPs
more realistic.
Inheritance provides data hiding. The base class can hide some data from the derived class
by making it private.
Method overriding cannot be achieved without inheritance. By method overriding, we can
give a specific implementation of some basic method contained by the base class.
To reduce the complexity and simplify the language, multiple inheritance is not supported in java.
Consider a scenario where A, B, and C are three classes. The C class inherits A and B classes. If
A and B classes have the same method and you call it from child class object, there will be
ambiguity to call the method of A or B class.
Since the compile-time errors are better than runtime errors, Java renders compile-time error if
you inherit 2 classes. So whether you have the same method or different, there will be a compile
time error.
1. class A{
2. void msg(){System.out.println("Hello");}
3. }
4. class B{
5. void msg(){System.out.println("Welcome");}
6. }
7. class C extends A,B{//suppose if it were
8.
9. Public Static void main(String args[]){
10. C obj=new C();
11. obj.msg();//Now which msg() method would be invoked?
12. }
13. }
Aggregation can be defined as the relationship between two classes where the aggregate class
contains a reference to the class it owns. Aggregation is best described as a has-a relationship.
For example, The aggregate class Employee having various fields such as age, name, and salary
also contains an object of Address class having various fields such as Address-Line 1, City, State,
and pin-code. In other words, we can say that Employee (class) has an object of Address class.
Consider the following example.
Address.java
Employee.java
Output
111 varun
gzb UP india
112 arun
gno UP india
Holding the reference of a class within some other class is known as composition. When an
object contains the other object, if the contained object cannot exist without the existence of
container object, then it is called composition. In other words, we can say that composition is the
particular case of aggregation which represents a stronger relationship between two objects.
Example: A class contains students. A student cannot exist without a class. There exists
composition between class and students.
Aggregation represents the weak relationship whereas composition represents the strong
relationship. For example, the bike has an indicator (aggregation), but the bike has an engine
(composition).
The pointer is a variable that refers to the memory address. They are not used in Java because
they are unsafe(unsecured) and complex to understand.
The super keyword in Java is a reference variable that is used to refer to the immediate parent
class object. Whenever you create the instance of the subclass, an instance of the parent class is
created implicitly which is referred by super reference variable. The super() is called in the class
constructor implicitly by the compiler if there is no super or this.
1. class Animal{
2. Animal(){System.out.println("animal is created");}
3. }
4. class Dog extends Animal{
5. Dog(){
6. System.out.println("dog is created");
7. }
8. }
9. class TestSuper4{
10. public static void main(String args[]){
11. Dog d=new Dog();
12. }
13. }
Output:
animal is created
dog is created
66) How can constructor chaining be done by using the super keyword?
1. class Person
2. {
3. String name,address;
4. int age;
5. public Person(int age, String name, String address)
6. {
7. this.age = age;
8. this.name = name;
9. this.address = address;
10. }
11. }
12. class Employee extends Person
13. {
14. float salary;
15. public Employee(int age, String name, String address, float salary)
16. {
17. super(age,name,address);
18. this.salary = salary;
19. }
20. }
21. public class Test
22. {
23. public static void main (String args[])
24. {
25. Employee e = new Employee(22, "Mukesh", "Delhi", 90000);
26. System.out.println("Name: "+e.name+" Salary: "+e.salary+" Age: "+e.age+" Address
: "+e.address);
27. }
28. }
Output
super can be used to refer to the immediate parent class instance variable.
super can be used to invoke the immediate parent class method.
super() can be used to invoke immediate parent class constructor.
68) What are the differences between this and super keyword?
There are the following differences between this and super keyword.
The super keyword always points to the parent class contexts whereas this keyword
always points to the current class context.
The super keyword is primarily used for initializing the base class variables within the
derived class constructor whereas this keyword primarily used to differentiate between
local and instance variables when passed in the class constructor.
The super and this must be the first statement inside constructor otherwise the compiler
will throw an error.
69) What is the output of the following Java program?
1. class Person
2. {
3. public Person()
4. {
5. System.out.println("Person class constructor called");
6. }
7. }
8. public class Employee extends Person
9. {
10. public Employee()
11. {
12. System.out.println("Employee class constructor called");
13. }
14. public static void main (String args[])
15. {
16. Employee e = new Employee();
17. }
18. }
Output
Explanation
The super() is implicitly invoked by the compiler if no super() or this() is included explicitly
within the derived class constructor. Therefore, in this case, The Person class constructor is called
first and then the Employee class constructor is called.
No, because this() and super() must be the first statement in the class constructor.
Example:
Output:
The object cloning is used to create the exact copy of an object. The clone() method of the Object
class is used to clone an object. The java.lang.Cloneable interface must be implemented by the
class whose object clone we want to create. If we don't implement Cloneable interface, clone()
method generates CloneNotSupportedException.
Method overloading is the polymorphism technique which allows us to create multiple methods
with the same name but different signature. We can achieve method overloading in two ways.
Method overloading increases the readability of the program. Method overloading is performed to
figure out the program quickly.
73) Why is method overloading not possible by changing the return type in java?
In Java, method overloading is not possible by changing the return type of the program due to
avoid the ambiguity.
1. class Adder{
2. static int add(int a,int b){return a+b;}
3. static double add(int a,int b){return a+b;}
4. }
5. class TestOverloading3{
6. public static void main(String[] args){
7. System.out.println(Adder.add(11,11));//ambiguity
8. }}
Output:
Compile Time Error: method add(int, int) is already defined in class Adder
No, We cannot overload the methods by just applying the static keyword to them(number of
parameters and types are the same). Consider the following example.
Output
By Type promotion is method overloading, we mean that one data type can be promoted to
another implicitly if no exact matching is found.
As displayed in the above diagram, the byte can be promoted to short, int, long, float or double.
The short datatype can be promoted to int, long, float or double. The char datatype can be
promoted to int, long, float or double and so on. Consider the following example.
1. class OverloadingCalculation1{
2. void sum(int a,long b){System.out.println(a+b);}
3. void sum(int a,int b,int c){System.out.println(a+b+c);}
4.
5. public static void main(String args[]){
6. OverloadingCalculation1 obj=new OverloadingCalculation1();
7. obj.sum(20,20);//now second int literal will be promoted to long
8. obj.sum(20,20,20);
9. }
10. }
Output
40
60
1. class OverloadingCalculation3{
2. void sum(int a,long b){System.out.println("a method invoked");}
3. void sum(long a,int b){System.out.println("b method invoked");}
4.
5. public static void main(String args[]){
6. OverloadingCalculation3 obj=new OverloadingCalculation3();
7. obj.sum(20,20);//now ambiguity
8. }
9. }
Output
Explanation
There are two methods defined with the same name, i.e., sum. The first method accepts the
integer and long type whereas the second method accepts long and the integer type. The
parameter passed that are a = 20, b = 20. We can not tell that which method will be called as there
is no clear differentiation mentioned between integer literal and long literal. This is the case of
ambiguity. Therefore, the compiler will throw an error.
If a subclass provides a specific implementation of a method that is already provided by its parent
class, it is known as Method Overriding. It is used for runtime polymorphism and to implement
the interface methods.
The method must have the same name as in the parent class.
The method must have the same signature as in the parent class.
Two classes must have an IS-A relationship between them.
No, you can't override the static method because they are the part of the class, not the object.
It is because the static method is the part of the class, and it is bound with class whereas instance
method is bound with the object, and static gets memory in class area, and instance gets memory
in a heap.
Yes.
No, we cannot override the private methods because the scope of private methods is limited to the
class and we cannot access them outside of the class.
84) Can we change the scope of the overridden method in the subclass?
Yes, we can change the scope of the overridden method in the subclass. However, we must notice
that we cannot decrease the accessibility of the method. The following point must be taken care
of while changing the accessibility of the method.
85) Can we modify the throws clause of the superclass method while overriding it in the
subclass?
Yes, we can modify the throws clause of the superclass method while overriding it in the
subclass. However, there are some rules which are to be followed while overriding in case of
exception handling.
If the superclass method does not declare an exception, subclass overridden method
cannot declare the checked exception, but it can declare the unchecked exception.
If the superclass method declares an exception, subclass overridden method can declare
same, subclass exception or no exception but cannot declare parent exception.
1. class Base
2. {
3. void method(int a)
4. {
5. System.out.println("Base class method called with integer a = "+a);
6. }
7.
8. void method(double d)
9. {
10. System.out.println("Base class method called with double d ="+d);
11. }
12. }
13.
14. class Derived extends Base
15. {
16. @Override
17. void method(double d)
18. {
19. System.out.println("Derived class method called with double d ="+d);
20. }
21. }
22.
23. public class Main
24. {
25. public static void main(String[] args)
26. {
27. new Derived().method(10);
28. }
29. }
Output
Explanation
The method() is overloaded in class Base whereas it is derived in class Derived with the double
type as the parameter. In the method call, the integer is passed.
Now, since java5, it is possible to override any method by changing the return type if the return
type of the subclass overriding method is subclass type. It is known as covariant return type. The
covariant return type specifies that the return type may vary in the same direction as the subclass.
1. class A{
2. A get(){return this;}
3. }
4.
5. class B1 extends A{
6. B1 get(){return this;}
7. void message(){System.out.println("welcome to covariant return type");}
8.
9. public static void main(String args[]){
10. new B1().get().message();
11. }
12. }
1. class Base
2. {
3. public void baseMethod()
4. {
5. System.out.println("BaseMethod called ...");
6. }
7. }
8. class Derived extends Base
9. {
10. public void baseMethod()
11. {
12. System.out.println("Derived method called ...");
13. }
14. }
15. public class Test
16. {
17. public static void main (String args[])
18. {
19. Base b = new Derived();
20. b.baseMethod();
21. }
22. }
Output
Explanation
The method of Base class, i.e., baseMethod() is overridden in Derived class. In Test class, the
reference variable b (of type Base class) refers to the instance of the Derived class. Here, Runtime
polymorphism is achieved between class Base and Derived. At compile time, the presence of
method baseMethod checked in Base class, If it presence then the program compiled otherwise
the compiler error will be shown. In this case, baseMethod is present in Base class; therefore, it is
compiled successfully. However, at runtime, It checks whether the baseMethod has been
overridden by Derived class, if so then the Derived class method is called otherwise Base class
method is called. In this case, the Derived class overrides the baseMethod; therefore, the Derived
class method is called.
In Java, the final variable is used to restrict the user from updating it. If we initialize the final
variable, we can't change its value. In other words, we can say that the final variable once
assigned to a value, can never be changed after that. The final variable which is not assigned to
any value can only be assigned through the class constructor.
1. class Bike9{
2. final int speedlimit=90;//final variable
3. void run(){
4. speedlimit=400;
5. }
6. public static void main(String args[]){
7. Bike9 obj=new Bike9();
8. obj.run();
9. }
10. }//end of class
1. class Bike{
2. final void run(){System.out.println("running");}
3. }
4.
5. class Honda extends Bike{
6. void run(){System.out.println("running safely with 100kmph");}
7.
8. public static void main(String args[]){
9. Honda honda= new Honda();
10. honda.run();
11. }
12. }
If we make any class final, we can't inherit it into any of the subclasses.
A final variable, not initialized at the time of declaration, is known as the final blank variable. We
can't initialize the final blank variable directly. Instead, we have to initialize it by using the class
constructor. It is useful in the case when the user has some data which must not be changed by
others, for example, PAN Number. Consider the following example:
1. class Student{
2. int id;
3. String name;
4. final String PAN_CARD_NUMBER;
5. ...
6. }
Yes, if it is not static, we can initialize it in the constructor. If it is static blank final variable, it
can be initialized only in the static block.
Yes, We can declare the main method as public static final void main(String[] args){}.
1. class Main {
2. public static void main(String args[]){
3. final int i;
4. i = 20;
5. System.out.println(i);
6. }
7. }
Output
20
Explanation
Since i is the blank final variable. It can be initialized only once. We have initialized it to 20.
Therefore, 20 will be printed.
97) What is the output of the following Java program?
1. class Base
2. {
3. protected final void getInfo()
4. {
5. System.out.println("method of Base class");
6. }
7. }
8.
9. public class Derived extends Base
10. {
11. protected final void getInfo()
12. {
13. System.out.println("method of Derived class");
14. }
15. public static void main(String[] args)
16. {
17. Base obj = new Base();
18. obj.getInfo();
19. }
20. }
Output
Explanation
The getDetails() method is final; therefore it can not be overridden in the subclass.
The constructor can never be declared as final because it is never inherited. Constructors are not
ordinary methods; therefore, there is no sense to declare constructors as final. However, if you try
to do so, The compiler will throw an error.
99) Can we declare an interface as final?
No, we cannot declare an interface as final because the interface must be implemented by some
class to provide its definition. Therefore, there is no sense to make an interface final. However, if
you try to do so, the compiler will show an error.
100) What is the difference between the final method and abstract method?
The main difference between the final method and abstract method is that the abstract method
cannot be final as we need to override them in the subclass to give its definition.
There are the following differences between compile-time polymorphism and runtime
polymorphism.
1. class Bike{
2. void run(){System.out.println("running");}
3. }
4. class Splendor extends Bike{
5. void run(){System.out.println("running safely with 60km");}
6. public static void main(String args[]){
7. Bike b = new Splendor();//upcasting
8. b.run();
9. }
10. }
Output:
In this process, an overridden method is called through the reference variable of a superclass.
The determination of the method to be called is based on the object being referred to by the
reference variable.
No, because method overriding is used to achieve runtime polymorphism and data members
cannot be overridden. We can override the member functions but not the data members.
Consider the example given below.
1. class Bike{
2. int speedlimit=90;
3. }
4. class Honda3 extends Bike{
5. int speedlimit=150;
6. public static void main(String args[]){
7. Bike obj=new Honda3();
8. System.out.println(obj.speedlimit);//90
9. }
Output:
90
104) What is the difference between static binding and dynamic binding?
In case of the static binding, the type of the object is determined at compile-time whereas, in
the dynamic binding, the type of the object is determined at runtime.
Static Binding
1. class Dog{
2. private void eat(){System.out.println("dog is eating...");}
3.
4. public static void main(String args[]){
5. Dog d1=new Dog();
6. d1.eat();
7. }
8. }
Dynamic Binding
1. class Animal{
2. void eat(){System.out.println("animal is eating...");}
3. }
4.
5. class Dog extends Animal{
6. void eat(){System.out.println("dog is eating...");}
7.
8. public static void main(String args[]){
9. Animal a=new Dog();
10. a.eat();
11. }
12. }
1. class BaseTest
2. {
3. void print()
4. {
5. System.out.println("BaseTest:print() called");
6. }
7. }
8. public class Test extends BaseTest
9. {
10. void print()
11. {
12. System.out.println("Test:print() called");
13. }
14. public static void main (String args[])
15. {
16. BaseTest b = new Test();
17. b.print();
18. }
19. }
Output
Test:print() called
Explanation
The instanceof in Java is also known as type comparison operator because it compares the
instance with type. It returns either true or false. If we apply the instanceof operator with any
variable that has a null value, it returns false. Consider the following example.
1. class Simple1{
2. public static void main(String args[]){
3. Simple1 s=new Simple1();
4. System.out.println(s instanceof Simple1);//true
5. }
6. }
Output
true
An object of subclass type is also a type of parent class. For example, if Dog extends Animal
then object of Dog can be referred by either Dog or Animal class.
Abstraction is a process of hiding the implementation details and showing only functionality
to the user. It displays just the essential things to the user and hides the internal information,
for example, sending SMS where you type the text and send the message. You don't know the
internal processing about the message delivery. Abstraction enables you to focus on what the
object does instead of how it does it. Abstraction lets you focus on what the object does
instead of how it does it.
Abstract Class
Interface
Abstraction hides the implementation details whereas encapsulation wraps code and data into
a single unit.
A class that is declared as abstract is known as an abstract class. It needs to be extended and
its method implemented. It cannot be instantiated. It can have abstract methods, non-abstract
methods, constructors, and static methods. It can also have the final methods which will force
the subclass not to change the body of the method. Consider the following example.
Output
running safely
111) Is the following program written correctly? If yes then what will be the output of
the program?
Yes, the program is written correctly. The Main class provides the definition of abstract
method multiply declared in abstract class Calculation. The output of the program will be:
Output
384
112) Can you use abstract and final both with a method?
No, because we need to override the abstract method to provide its implementation, whereas
we can't override the final method.
No, the abstract class can never be instantiated even if it contains a constructor and all of its
methods are implemented.
The interface is a blueprint for a class that has static constants and abstract methods. It can be
used to achieve full abstraction and multiple inheritance. It is a mechanism to achieve
abstraction. There can be only abstract methods in the Java interface, not method body. It is
used to achieve abstraction and multiple inheritance in Java. In other words, you can say that
interfaces can have abstract methods and variables. Java Interface also represents the IS-A
relationship. It cannot be instantiated just like the abstract class. However, we need to
implement it to define its methods. Since Java 8, we can have the default, static, and private
methods in an interface.
No, because methods of an interface are abstract by default, and we can not use static and
abstract together.
No, because an interface needs to be implemented by the other class and if it is final, it can't
be implemented by any class.
A Marker interface can be defined as the interface which has no data member and member
functions. For example, Serializable, Cloneable are marker interfaces. The marker interface
can be declared as follows.
118) What are the differences between abstract class and interface?
119) Can we define private and protected modifiers for the members in interfaces?
An object reference can be cast to an interface reference when the object implements the
referenced interface.
A class can be made read-only by making all of the fields private. The read-only class will
have only getter methods which return the private property of the class to the main method.
We cannot modify this property because there is no setter method available in the class.
Consider the following example.
A class can be made write-only by making all of the fields private. The write-only class will
have only setter methods which set the value passed from the main method to the private
fields. We cannot read the properties of the class because there is no getter method in this
class. Consider the following example.
By providing only the setter or getter method, you can make the class read-only or
write-only. In other words, you can skip the getter or setter methods.
It provides you the control over the data. Suppose you want to set the value of id
which should be greater than 100 only, you can write the logic inside the setter
method. You can write the logic not to store the negative numbers in the setter
methods.
It is a way to achieve data hiding in Java because other class will not be able to access
the data through the private data members.
The encapsulate class is easy to test. So, it is better for unit testing.
The standard IDE's are providing the facility to generate the getters and setters. So, it
is easy and fast to create an encapsulated class in Java.
1. //save as Simple.java
2. package mypack;
3. public class Simple{
4. public static void main(String args[]){
5. System.out.println("Welcome to package");
6. }
7. }
125) What are the advantages of defining packages in Java?
By defining packages, we can avoid the name conflicts between the same class names defined
in different packages. Packages also enable the developer to organize the similar classes more
effectively. For example, one can clearly understand that the classes present in java.io package
are used to perform io related operations.
If you are using the programming IDEs like Eclipse, NetBeans, MyEclipse, etc. click on file-
>new->project and eclipse will ask you to enter the name of the package. It will create the
project package containing various directories such as src, etc. If you are using an editor like
notepad for java programming, use the following steps to create the package.
Define a package package_name. Create the class with the name class_name and
save this file with your_class_name.java.
Now compile the file by running the following command on the terminal.
1. javac -d . your_class_name.java
The above command creates the package with the name package_name in the present
working directory.
Now, run the class file by using the absolute class file name, like following.
1. java package_name.class_name
By using the fully qualified name: To access a class in a different package, either we
must use the fully qualified name of that class, or we must import the package
containing that class.
By using the relative path, We can use the path of the class that is related to the
package that contains our class. It can be the same or subpackage.
129) Can I import same package/class twice? Will the JVM load the package twice at
runtime?
One can import the same package or the same class multiple times. Neither compiler nor JVM
complains about it. However, the JVM will internally load the class only once no matter how
many times you import the same class.
By static import, we can access the static members of a class directly, and there is no to
qualify it with the class name.
Java: Exception Handling Interview Questions
There is given a list of exception handling interview questions with answers. If you know any
exception handling interview question, kindly post it in the comment section.
There are mainly two types of exceptions: checked and unchecked. Here, an error is
considered as the unchecked exception. According to Oracle, there are three types of
exceptions:
Checked Exception: Checked exceptions are the one which are checked at compile-
time. For example, SQLException, ClassNotFoundException, etc.
Unchecked Exception: Unchecked exceptions are the one which are handled at
runtime because they can not be checked at compile-time. For example,
ArithmaticException, NullPointerException, ArrayIndexOutOfBoundsException, etc.
Error: Error cause the program to exit since they are not recoverable. For Example,
OutOfMemoryError, AssertionError, etc.
Exception Handling is a mechanism that is used to handle runtime errors. It is used primarily
to handle checked exceptions. Exception handling maintains the normal flow of the program.
There are mainly two types of exceptions: checked and unchecked. Here, the error is
considered as the unchecked exception.
The java.lang.Throwable class is the root class of Java Exception hierarchy which is inherited
by two subclasses: Exception and Error. A hierarchy of Java Exception classes are given
below:
134) What is the difference between Checked Exception and Unchecked Exception?
1) Checked Exception
The classes that extend Throwable class except RuntimeException and Error are known as
checked exceptions, e.g., IOException, SQLException, etc. Checked exceptions are checked
at compile-time.
2) Unchecked Exception
The classes that extend RuntimeException are known as unchecked exceptions, e.g.,
ArithmeticException, NullPointerException, etc. Unchecked exceptions are not checked at
compile-time.
The Throwable class is the base class for Error and Exception.
136) Is it necessary that each try block must be followed by a catch block?
It is not necessary that each try block must be followed by a catch block. It should be followed
by either a catch block OR a finally block. So whatever exceptions are likely to be thrown
should be declared in the throws clause of the method. Consider the following example.
Output:
Exception in thread main java.lang.ArithmeticException:/ by zero
rest of the code...
Output
Explanation
The "finally" block is used to execute the important code of the program. It is executed
whether an exception is handled or not. In other words, we can say that finally block is the
block which is always executed. Finally block follows try or catch block. If you don't handle
the exception, before terminating the program, JVM runs finally block, (if any). The finally
block is mainly used to place the cleanup code such as closing a file or closing a connection.
Here, we must know that for each try block there can be zero or more catch blocks, but only
one finally block. The finally block will not be executed if program exits(either by calling
System.exit() or by causing a fatal error that causes the process to abort).
139) Can finally block be used without a catch?
Yes, According to the definition of finally block, it must be followed by a try or catch block,
therefore, we can use try block instead of catch.
Output
Explanation
In Java, the throwable objects can only be thrown. If we try to throw an integer object, The
compiler will show an error since we can not throw basic data type from a block of code.
Output
Explanation
The object of Calculation is thrown from the try block which is caught in the catch block. The
add() of Calculation class is called with the integer values 10 and 20 by using the object of
this class. Therefore there sum 30 is printed. The object of the Main class can only be thrown
in the case when the type of the object is throwable. To do so, we need to extend the
throwable class.
Yes.
145) Can subclass overriding method declare an exception if parent class method doesn't
throw an exception?
An exception is first thrown from the top of the stack and if it is not caught, it drops down the
call stack to the previous method, If not caught there, the exception again drops down to the
previous method, and so on until they are caught or until they reach the very bottom of the call
stack. This procedure is called exception propagation. By default, checked exceptions are not
propagated.
1. class TestExceptionPropagation1{
2. void m(){
3. int data=50/0;
4. }
5. void n(){
6. m();
7. }
8. void p(){
9. try{
10. n();
11. }catch(Exception e){System.out.println("exception handled");}
12. }
13. public static void main(String args[]){
14. TestExceptionPropagation1 obj=new TestExceptionPropagation1();
15. obj.p();
16. System.out.println("normal flow...");
17. }
18. }
Output:
exception handled
normal flow...
Output
Explanation
In the main method, a() of Main is called which prints a message and call b(). The method b()
prints some message and then call c(). The method c() throws an exception which is handled
by the catch block of method b. However, It propagates this exception by using throw
Exception() to be handled by the method a(). As we know, finally block is always executed
therefore the finally block in the method b() is executed first and prints a message. At last, the
exception is handled by the catch block of the method a().
Output
result = 290
Explanation
The instance variable a of class Calculation is initialized to 10 using the class constructor
which is called while instantiating the class. The add method is called which returns an integer
value result. In add() method, a is incremented by 10 to be 20. Then, in the first try block, 10
is again incremented by 10 to be 30. In the second try block, a is multiplied by 10 to be 300.
The second try block throws the exception which is caught by the catch block associated with
this try block. The catch block again alters the value of a by decrementing it by 10 to make it
290. Thus the add() method returns 290 which is assigned to result. However, the catch block
associated with the outermost try block will never be executed since there is no exception
which can be handled by this catch block.
Java: String Handling Interview Questions
There is given a list of string handling interview questions with short and pointed answers. If
you know any string handling interview question, kindly post it in the comment section.
String pool is the space reserved in the heap memory that can be used to store the strings. The
main advantage of using the String pool is whenever we create a string literal; the JVM checks
the "string constant pool" first. If the string already exists in the pool, a reference to the pooled
instance is returned. If the string doesn't exist in the pool, a new string instance is created and
placed in the pool. Therefore, it saves the memory by avoiding the duplicacy.
150) What is the meaning of immutable regarding String?
1. class Testimmutablestring{
2. public static void main(String args[]){
3. String s="Sachin";
4. s.concat(" Tendulkar");//concat() method appends the string at the end
5. System.out.println(s);//will print Sachin because strings are immutable objects
6. }
7. }
Output:
Sachin
Because Java uses the concept of the string literal. Suppose there are five reference variables,
all refer to one object "sachin". If one reference variable changes the value of the object, it
will be affected by all the reference variables. That is why string objects are immutable in
java.
152) How many ways can we create the string object?
1) String Literal
1. String s="welcome";
Each time you create a string literal, the JVM checks the "string constant pool" first. If the
string already exists in the pool, a reference to the pooled instance is returned. If the string
doesn't exist in the pool, a new string instance is created and placed in the pool. String objects
are stored in a special memory area known as the string constant pool For example:
1. String s1="Welcome";
2. String s2="Welcome";//It doesn't create a new instance
2) By new keyword
In such case, JVM will create a new string object in normal (non-pool) heap memory, and the
literal "Welcome" will be placed in the constant string pool. The variable s will refer to the
object in a heap (non-pool).
1. String s1="Welcome";
2. String s2="Welcome";
3. String s3="Welcome";
Only one object will be created using the above code because strings in Java are immutable.
To make Java more memory efficient (because no new objects are created if it exists already
in the string constant pool).
Output
a equals b
Explanation
The operator == also check whether the references of the two string objects are equal or not.
Although both of the strings contain the same content, their references are not equal because
both are created by different ways(Constructor and String literal) therefore, a == b is unequal.
On the other hand, the equal() method always check for the content. Since their content is
equal hence, a equals b is printed.
Output
true
Explanation
The intern method returns the String object reference from the string pool. In this case, s1 is
created by using string literal whereas, s2 is created by using the String pool. However, s2 is
changed to the reference of s1, and the operator == returns true.
The differences between the String and StringBuffer is given in the table below.
We can create an immutable class by defining a final class having all of its members as final.
Consider the following example.
The toString() method returns the string representation of an object. If you print any object,
java compiler internally invokes the toString() method on the object. So overriding the
toString() method, returns the desired output, it can be the state of an object, etc. depending
upon your implementation. By overriding the toString() method of the Object class, we can
return the values of the object, so we don't need to write much code. Consider the following
example.
1. class Student{
2. int rollno;
3. String name;
4. String city;
5.
6. Student(int rollno, String name, String city){
7. this.rollno=rollno;
8. this.name=name;
9. this.city=city;
10. }
11.
12. public String toString(){//overriding the toString() method
13. return rollno+" "+name+" "+city;
14. }
15. public static void main(String args[]){
16. Student s1=new Student(101,"Raj","lucknow");
17. Student s2=new Student(102,"Vijay","ghaziabad");
18.
19. System.out.println(s1);//compiler writes here s1.toString()
20. System.out.println(s2);//compiler writes here s2.toString()
21. }
22. }
Output:
String stays in the string pool until the garbage is collected. If we store the password into a
string, it stays in the memory for a longer period, and anyone having the memory-dump can
extract the password as clear text. On the other hand, Using CharArray allows us to set it to
blank whenever we are done with the password. It avoids the security threat with the string by
enabling us to control the memory.
163) Write a Java program to count the number of words present in a string?
Program:
Output
There are the following classes and interfaces present in java.util.regex package.
MatchResult Interface
Matcher class
Pattern class
PatternSyntaxException class
165) How the metacharacters are different from the ordinary characters?
Metacharacters have the special meaning to the regular expression engine. The metacharacters
are ^, $, ., *, +, etc. The regular expression engine does not consider them as the regular
characters. To enable the regular expression engine treating the metacharacters as ordinary
characters, we need to escape the metacharacters with the backslash.
166) Write a regular expression to validate a password. A password must start with an
alphabet and followed by alphanumeric characters; Its length must be in between 8 to
20.
The regular expression for the above criteria will be: ^[a-zA-Z][a-zA-Z0-9]{8,19} where ^
represents the start of the regex, [a-zA-Z] represents that the first character must be an
alphabet, [a-zA-Z0-9] represents the alphanumeric character, {8,19} represents that the length
of the password must be in between 8 and 20.
1. import java.util.regex.*;
2. class RegexExample2{
3. public static void main(String args[]){
4. System.out.println(Pattern.matches(".s", "as")); //line 4
5. System.out.println(Pattern.matches(".s", "mk")); //line 5
6. System.out.println(Pattern.matches(".s", "mst")); //line 6
7. System.out.println(Pattern.matches(".s", "amms")); //line 7
8. System.out.println(Pattern.matches("..s", "mas")); //line 8
9. }}
Output
true
false
false
false
true
Explanation
line 4 prints true since the second character of string is s, line 5 prints false since the second
character is not s, line 6 prints false since there are more than 3 characters in the string, line 7
prints false since there are more than 2 characters in the string, and it contains more than 2
characters as well, line 8 prints true since the third character of the string is s.
Nested classes represent a special type of relationship that is it can access all the
members (data members and methods) of the outer class including private.
Nested classes are used to develop a more readable and maintainable code because it
logically groups classes and interfaces in one place only.
Code Optimization: It requires less code to write.
The nested class can be defined as the class which is defined inside another class or interface.
We use the nested class to logically group classes and interfaces in one place so that it can be
more readable and maintainable. A nested class can access all the data members of the outer
class including private data members and methods. The syntax of the nested class is defined
below.
1. class Java_Outer_class{
2. //code
3. class Java_Nested_class{
4. //code
5. }
6. }
7.
There are two types of nested classes, static nested class, and non-static nested class. The non-
static nested class can also be called as inner-class
170) What are the disadvantages of using inner classes?
Inner classes increase the total number of classes used by the developer and therefore
increases the workload of JVM since it has to perform some routine operations for
those extra classes which result in slower performance.
IDEs provide less support to the inner classes as compare to the top level classes and
therefore it annoys the developers while working with inner classes.
171) What are the types of inner classes (non-static nested class) used in Java?
Type Description
Member Inner
A class created within class and outside method.
Class
Anonymous Inner A class created for implementing an interface or extending class. Its
Class name is decided by the java compiler.
Local Inner Class A class created within the method.
172) Is there any difference between nested classes and inner classes?
Yes, inner classes are non-static nested classes. In other words, we can say that inner classes
are the part of nested classes.
173) Can we access the non-final local variable, inside the local inner class?
No, the local variable must be constant if you want to access it in the local inner class.
174) How many class files are created on compiling the OuterClass in the following
program?
Anonymous inner classes are the classes that are automatically declared and instantiated
within an expression. We cannot apply different access modifiers to them. Anonymous class
cannot be static, and cannot define any static fields, method, or class. In other words, we can
say that it a class without the name and can have only one object that is created by its
definition. Consider the following example.
Output:
nice fruits
Consider the following example for the working of the anonymous class using interface.
1. interface Eatable{
2. void eat();
3. }
4. class TestAnnonymousInner1{
5. public static void main(String args[]){
6. Eatable e=new Eatable(){
7. public void eat(){System.out.println("nice fruits");}
8. };
9. e.eat();
10. }
11. }
Output:
nice fruits
An Interface that is declared inside the interface or class is known as the nested interface. It is
static by default. The nested interfaces are used to group related interfaces so that they can be
easy to maintain. The external interface or class must refer to the nested interface. It can't be
accessed directly. The nested interface must be public if it is declared inside the interface but
it can have any access modifier if declared within the class. The syntax of the nested interface
is given as follows.
1. interface interface_name{
2. ...
3. interface nested_interface_name{
4. ...
5. }
6. }
7.
Garbage collection is a process of reclaiming the unused runtime objects. It is performed for
memory management. In other words, we can say that It is the process of removing unused
objects from the memory to free up space and make this space available for Java Virtual
Machine. Due to garbage collection java gives 0 as output to a variable whose value is not set,
i.e., the variable has been defined but not initialized. For this purpose, we were using free()
function in the C language and delete() in C++. In Java, it is performed automatically. So, java
provides better memory management.
The gc() method is used to invoke the garbage collector for cleanup processing. This method
is found in System and Runtime classes. This function explicitly makes the Java Virtual
Machine free up the space occupied by the unused objects so that it can be utilized or reused.
Consider the following example for the better understanding of how the gc() method invoke
the garbage collector.
Garbage collection is managed by JVM. It is performed when there is not enough space in the
memory and memory is running low. We can externally call the System.gc() for the garbage
collection. However, it depends upon the JVM whether to perform it or not.
1) By nulling a reference:
3) By anonymous object:
1. new Employee();
The finalize() method is invoked just before the object is garbage collected. It is used to
perform cleanup processing. The Garbage collector of JVM collects only those objects that are
created by new keyword. So if you have created an object without new, you can use the
finalize method to perform cleanup processing (destroying remaining objects). The cleanup
processing is the process to free up all the resources, network which was previously used and
no longer needed. It is essential to remember that it is not a reserved keyword, finalize method
is present in the object class hence it is available in every class as object class is the superclass
of every class in java. Here, we must note that neither finalization nor garbage collection is
guaranteed. Consider the following example.
Yes,
Daemon thread.
Java Runtime class is used to interact with a java runtime environment. Java Runtime class
provides methods to execute a process, invoke GC, get total and free memory, etc. There is
only one instance of java.lang.Runtime class is available for one java application. The
Runtime.getRuntime() method returns the singleton instance of Runtime class.
OutputStream Hierarchy
InputStream Hierarchy
191) What is the difference between the Reader/Writer class hierarchy and the
InputStream/OutputStream class hierarchy?
192) What are the super most classes for all the streams?
All the stream classes can be divided into two types of classes that are ByteStream classes and
CharacterStream Classes. The ByteStream classes are further divided into InputStream classes
and OutputStream classes. CharacterStream classes are also divided into Reader classes and
Writer classes. The SuperMost classes for all the InputStream classes is java.io.InputStream
and for all the output stream classes is java.io.OutPutStream. Similarly, for all the reader
classes, the super-most class is java.io.Reader, and for all the writer classes, it is
java.io.Writer.
Java FileOutputStream is an output stream used for writing data to a file. If you have some
primitive values to write into a file, use FileOutputStream class. You can write byte-oriented
as well as character-oriented data through the FileOutputStream class. However, for character-
oriented data, it is preferred to use FileWriter than FileOutputStream. Consider the following
example of writing a byte into a file.
1. import java.io.FileOutputStream;
2. public class FileOutputStreamExample {
3. public static void main(String args[]){
4. try{
5. FileOutputStream fout=new FileOutputStream("D:\\testout.txt");
6. fout.write(65);
7. fout.close();
8. System.out.println("success...");
9. }catch(Exception e){System.out.println(e);}
10. }
11. }
Java FileInputStream class obtains input bytes from a file. It is used for reading byte-
oriented data (streams of raw bytes) such as image data, audio, video, etc. You can also read
character-stream data. However, for reading streams of characters, it is recommended to use
FileReader class. Consider the following example for reading bytes from a file.
1. import java.io.FileInputStream;
2. public class DataStreamExample {
3. public static void main(String args[]){
4. try{
5. FileInputStream fin=new FileInputStream("D:\\testout.txt");
6. int i=fin.read();
7. System.out.print((char)i);
8.
9. fin.close();
10. }catch(Exception e){System.out.println(e);}
11. }
12. }
13.
Java BufferedOutputStream class is used for buffering an output stream. It internally uses a
buffer to store data. It adds more efficiency than to write data directly into a stream. So, it
makes the performance fast. Whereas, Java BufferedInputStream class is used to read
information from the stream. It internally uses the buffer mechanism to make the performance
fast.
In Java, FilePermission class is used to alter the permissions set on a file. Java FilePermission
class contains the permission related to a directory or file. All the permissions are related to
the path. The path can be of two types:
D:\\IO\\-: It indicates that the permission is associated with all subdirectories and files
recursively.
D:\\IO\\*: It indicates that the permission is associated with all directory and files
within this directory excluding subdirectories.
Let's see the simple example in which permission of a directory path is granted with read
permission and a file of this directory is granted for write permission.
1. package com.javatpoint;
2. import java.io.*;
3. import java.security.PermissionCollection;
4. public class FilePermissionExample{
5. public static void main(String[] args) throws IOException {
6. String srg = "D:\\IO Package\\java.txt";
7. FilePermission file1 = new FilePermission("D:\\IO Package\\-", "read");
8. PermissionCollection permission = file1.newPermissionCollection();
9. permission.add(file1);
10. FilePermission file2 = new FilePermission(srg, "write");
11. permission.add(file2);
12. if(permission.implies(new FilePermission(srg, "read,write"))) {
13. System.out.println("Read, Write permission is granted for the path "+srg );
14. }else {
15. System.out.println("No Read, Write permission is granted for the path "+srg);
}
16. }
17. }
Output
FilterStream classes are used to add additional functionalities to the other stream classes.
FilterStream classes act like an interface which read the data from a stream, filters it, and pass
the filtered data to the caller. The FilterStream classes provide extra functionalities like adding
line numbers to the destination file, etc.
An I/O filter is an object that reads from one stream and writes to another, usually altering the
data in some way as it is passed from one stream to another. Many Filter classes that allow a
user to make a chain using multiple input streams. It generates a combined effect on several
filters.
198) In Java, How many ways you can take input from the console?
In Java, there are three ways by using which, we can take input from the console.
Using BufferedReader class: we can take input from the console by wrapping
System.in into an InputStreamReader and passing it into the BufferedReader. It
provides an efficient reading as the input gets buffered. Consider the following
example.
1. import java.io.BufferedReader;
2. import java.io.IOException;
3. import java.io.InputStreamReader;
4. public class Person
5. {
6. public static void main(String[] args) throws IOException
7. {
8. System.out.println("Enter the name of the person");
9. BufferedReader reader = new BufferedReader(new InputStreamReader(S
ystem.in));
10. String name = reader.readLine();
11. System.out.println(name);
12. }
13. }
Using Scanner class: The Java Scanner class breaks the input into tokens using a
delimiter that is whitespace by default. It provides many methods to read and parse
various primitive values. Java Scanner class is widely used to parse text for string and
primitive types using a regular expression. Java Scanner class extends Object class and
implements Iterator and Closeable interfaces. Consider the following example.
1. import java.util.*;
2. public class ScannerClassExample2 {
3. public static void main(String args[]){
4. String str = "Hello/This is JavaTpoint/My name is Abhishek.";
5. //Create scanner with the specified String Object
6. Scanner scanner = new Scanner(str);
7. System.out.println("Boolean Result: "+scanner.hasNextBoolean());
1. import java.io.Console;
2. class ReadStringTest{
3. public static void main(String args[]){
4. Console c=System.console();
5. System.out.println("Enter your name: ");
6. String n=c.readLine();
7. System.out.println("Welcome "+n);
8. }
9. }
Serialization in Java is a mechanism of writing the state of an object into a byte stream. It is
used primarily in Hibernate, RMI, JPA, EJB and JMS technologies. It is mainly used to travel
object's state on the network (which is known as marshaling). Serializable interface is used to
perform serialization. It is helpful when you require to save the state of a program to storage
such as the file. At a later point of time, the content of this file can be restored using
deserialization. It is also required to implement RMI(Remote Method Invocation). With the
help of RMI, it is possible to invoke the method of a Java object on one machine to another
machine.
200) How can you make a class serializable in Java?
201) How can you avoid serialization in child class if the base class is implementing the
Serializable interface?
It is very tricky to prevent serialization of child class if the base class is intended to implement
the Serializable interface. However, we cannot do it directly, but the serialization can be
avoided by implementing the writeObject() or readObject() methods in the subclass and throw
NotSerializableException from these methods. Consider the following example.
1. import java.io.FileInputStream;
2. import java.io.FileOutputStream;
3. import java.io.IOException;
4. import java.io.NotSerializableException;
5. import java.io.ObjectInputStream;
6. import java.io.ObjectOutputStream;
7. import java.io.Serializable;
8. class Person implements Serializable
9. {
10. String name = " ";
11. public Person(String name)
12. {
13. this.name = name;
14. }
15. }
16. class Employee extends Person
17. {
18. float salary;
19. public Employee(String name, float salary)
20. {
21. super(name);
22. this.salary = salary;
23. }
24. private void writeObject(ObjectOutputStream out) throws IOException
25. {
26. throw new NotSerializableException();
27. }
28. private void readObject(ObjectInputStream in) throws IOException
29. {
30. throw new NotSerializableException();
31. }
32.
33. }
34. public class Test
35. {
36. public static void main(String[] args)
37. throws Exception
38. {
39. Employee emp = new Employee("Sharma", 10000);
40.
41. System.out.println("name = " + emp.name);
42. System.out.println("salary = " + emp.salary);
43.
44. FileOutputStream fos = new FileOutputStream("abc.ser");
45. ObjectOutputStream oos = new ObjectOutputStream(fos);
46.
47. oos.writeObject(emp);
48.
49. oos.close();
50. fos.close();
51.
52. System.out.println("Object has been serialized");
53.
54. FileInputStream f = new FileInputStream("ab.txt");
55. ObjectInputStream o = new ObjectInputStream(f);
56.
57. Employee emp1 = (Employee)o.readObject();
58.
59. o.close();
60. f.close();
61.
62. System.out.println("Object has been deserialized");
63.
64. System.out.println("name = " + emp1.name);
65. System.out.println("salary = " + emp1.salary);
66. }
67. }
Yes, we can transfer a serialized object via network because the serialized object is stored in
the memory in the form of bytes and can be transmitted over the network. We can also write
the serialized object to the disk or the database.
Deserialization is the process of reconstructing the object from the serialized state. It is the
reverse operation of serialization. An ObjectInputStream deserializes objects and primitive
data written using an ObjectOutputStream.
1. import java.io.*;
2. class Depersist{
3. public static void main(String args[])throws Exception{
4.
5. ObjectInputStream in=new ObjectInputStream(new FileInputStream("f.txt"));
6. Student s=(Student)in.readObject();
7. System.out.println(s.id+" "+s.name);
8.
9. in.close();
10. }
11. }
211 ravi
If you define any data member as transient, it will not be serialized. By determining transient
keyword, the value of variable need not persist when it is restored.
205) What is Externalizable?
The Externalizable interface is used to write the state of an object into a byte stream in a
compressed format. It is not a marker interface.
Java Socket programming is used for communication between the applications running on
different JRE. Java Socket programming can be connection-oriented or connectionless. Socket
and ServerSocket classes are used for connection-oriented socket programming and
DatagramSocket, and DatagramPacket classes are used for connectionless socket
programming. The client in socket programming must know two information:
209) What are the steps that are followed when two computers connect through TCP?
There are the following steps that are performed when two computers connect through TCP.
The ServerSocket object is instantiated by the server which denotes the port number to
which, the connection will be made.
After instantiating the ServerSocket object, the server invokes accept() method of
ServerSocket class which makes server wait until the client attempts to connect to the
server on the given port.
Meanwhile, the server is waiting, a socket is created by the client by instantiating
Socket class. The socket class constructor accepts the server port number and server
name.
The Socket class constructor attempts to connect with the server on the specified
name. If the connection is established, the client will have a socket object that can
communicate with the server.
The accept() method invoked by the server returns a reference to the new socket on the
server that is connected with the server.
210) Write a program in Java to establish a connection between client and server?
Consider the following program where the connection between the client and server is
established.
File: MyServer.java
1. import java.io.*;
2. import java.net.*;
3. public class MyServer {
4. public static void main(String[] args){
5. try{
6. ServerSocket ss=new ServerSocket(6666);
7. Socket s=ss.accept();//establishes connection
8. DataInputStream dis=new DataInputStream(s.getInputStream());
9. String str=(String)dis.readUTF();
10. System.out.println("message= "+str);
11. ss.close();
12. }catch(Exception e){System.out.println(e);}
13. }
14. }
File: MyClient.java
1. import java.io.*;
2. import java.net.*;
3. public class MyClient {
4. public static void main(String[] args) {
5. try{
6. Socket s=new Socket("localhost",6666);
7. DataOutputStream dout=new DataOutputStream(s.getOutputStream());
8. dout.writeUTF("Hello Server");
9. dout.flush();
10. dout.close();
11. s.close();
12. }catch(Exception e){System.out.println(e);}
13. }
14. }
211) How do I convert a numeric IP address like 192.18.97.39 into a hostname like
java.sun.com?
1. import java.io.*;
2. import java.net.*;
3. public class InetDemo{
4. public static void main(String[] args){
5. try{
6. InetAddress ip=InetAddress.getByName("195.201.10.8");
7.
8. System.out.println("Host Name: "+ip.getHostName());
9. }catch(Exception e){System.out.println(e);}
10. }
11. }
12.
forName() method of Class class: The forName() method is used to load the class
dynamically. It returns the instance of Class class. It should be used if you know the
fully qualified name of the class. This cannot be used for primitive types.
getClass() method of Object class: It returns the instance of Class class. It should be
used if you know the type. Moreover, it can be used with primitives.
the .class syntax: If a type is available, but there is no instance then it is possible to
obtain a Class by appending ".class" to the name of the type. It can be used for
primitive data type also.
215) What is the output of the following Java program?
1. class Simple{
2. public Simple()
3. {
4. System.out.println("Constructor of Simple class is invoked");
5. }
6. void message(){System.out.println("Hello Java");}
7. }
8.
9. class Test1{
10. public static void main(String args[]){
11. try{
12. Class c=Class.forName("Simple");
13. Simple s=(Simple)c.newInstance();
14. s.message();
15. }catch(Exception e){System.out.println(e);}
16. }
17. }
Output
Explanation
The newInstance() method of the Class class is used to invoke the constructor at runtime. In
this program, the instance of the Simple class is created.
The javap command disassembles a class file. The javap command displays information about
the fields, constructors and methods present in a class file.
Syntax
javap fully_class_name
217) Can you access the private method from outside the class?
Yes, by changing the runtime behavior of a class if the class is not secured.
Wrapper classes are classes that allow primitive types to be accessed as objects. In other
words, we can say that wrapper classes are built-in java classes which allow the conversion of
objects to primitives and primitives to objects. The process of converting primitives to objects
is called autoboxing, and the process of converting objects to primitives is called unboxing.
There are eight wrapper classes present in java.lang package is given below.
The autoboxing is the process of converting primitive data type to the corresponding wrapper
class object, eg., int to Integer. The unboxing is the process of converting wrapper class object
to primitive data type. For eg., integer to int. Unboxing and autoboxing occur automatically in
Java. However, we can externally convert one into another by using the methods like
valueOf() or xxxValue().
It can occur whenever a wrapper class object is expected, and primitive data type is provided
or vice versa.
Output
bye
Explanation
The Integer class caches integer values from -127 to 127. Therefore, the Integer objects can
only be created in the range -128 to 127. The operator == will not work for the value greater
than 127; thus bye is printed.
The object cloning is a way to create an exact copy of an object. The clone() method of the
Object class is used to clone an object. The java.lang.Cloneable interface must be
implemented by the class whose object clone we want to create. If we don't implement
Cloneable interface, clone() method generates CloneNotSupportedException. The clone()
method is defined in the Object class. The syntax of the clone() method is as follows:
protected Object clone() throws CloneNotSupportedException
You don't need to write lengthy and repetitive codes. Just use an abstract class with a
4- or 5-line long clone() method.
It is the easiest and most efficient way of copying objects, especially if we are
applying it to an already developed or an old project. Just define a parent class,
implement Cloneable in it, provide the definition of the clone() method and the task
will be done.
Clone() is the fastest way to copy the array.
To use the Object.clone() method, we have to change many syntaxes to our code, like
implementing a Cloneable interface, defining the clone() method and handling
CloneNotSupportedException, and finally, calling Object.clone(), etc.
We have to implement the Cloneable interface while it does not have any methods in
it. We have to use it to tell the JVM that we can perform a clone() on our object.
Object.clone() is protected, so we have to provide our own clone() and indirectly call
Object.clone() from it.
Object.clone() does not invoke any constructor, so we do not have any control over
object construction.
If you want to write a clone method in a child class, then all of its superclasses should
define the clone() method in them or inherit it from another parent class. Otherwise,
the super.clone() chain will fail.
Object.clone() supports only shallow copying, but we will need to override it if we
need deep cloning.
A native method is a method that is implemented in a language other than Java. Natives
methods are sometimes also referred to as foreign methods.
Java strictfp keyword ensures that you will get the same result on every platform if you
perform operations in the floating-point variable. The precision may differ from platform to
platform that is why java programming language has provided the strictfp keyword so that you
get the same result on every platform. So, now you have better control over the floating-point
arithmetic.
The purpose of the System class is to provide access to system resources such as standard
input and output. It cannot be instantiated. Facilities provided by System class are given
below.
Standard input
Error output streams
Standard output
utility method to copy the portion of an array
utilities to load files and libraries
There are the three fields of Java System class, i.e., static printstream err, static inputstream in,
and standard output stream.
226) What comes to mind when someone mentions a shallow copy in Java?
Object cloning.
Singleton class is the class which can not be instantiated more than once. To make a class
singleton, we either make its constructor private or use the static getInstance method.
Consider the following example.
1. class Singleton{
2. private static Singleton single_instance = null;
3. int i;
4. private Singleton ()
5. {
6. i=90;
7. }
8. public static Singleton getInstance()
9. {
10. if(single_instance == null)
11. {
12. single_instance = new Singleton();
13. }
14. return single_instance;
15. }
16. }
17. public class Main
18. {
19. public static void main (String args[])
20. {
21. Singleton first = Singleton.getInstance();
22. System.out.println("First instance integer value:"+first.i);
23. first.i=first.i+90;
24. Singleton second = Singleton.getInstance();
25. System.out.println("Second instance integer value:"+second.i);
26. }
27. }
28.
228) Write a Java program that prints all the values given at command-line.
Program
1. class A{
2. public static void main(String args[]){
3.
4. for(int i=0;i<args.length;i++)
5. System.out.println(args[i]);
6.
7. }
8. }
Output
sonoo
jaiswal
1
3
abc
Core Java: Data Structure interview questions
Output:
1. import java.util.*;
2. public class BinarySearch {
3. public static void main(String[] args) {
4. int[] arr = {16, 19, 20, 23, 45, 56, 78, 90, 96, 100};
5. int item, location = -1;
6. System.out.println("Enter the item which you want to search");
7. Scanner sc = new Scanner(System.in);
8. item = sc.nextInt();
9. location = binarySearch(arr,0,9,item);
10. if(location != -1)
11. System.out.println("the location of the item is "+location);
12. else
13. System.out.println("Item not found");
14. }
15. public static int binarySearch(int[] a, int beg, int end, int item)
16. {
17. int mid;
18. if(end >= beg)
19. {
20. mid = (beg + end)/2;
21. if(a[mid] == item)
22. {
23. return mid+1;
24. }
25. else if(a[mid] < item)
26. {
27. return binarySearch(a,mid+1,end,item);
28. }
29. else
30. {
31. return binarySearch(a,beg,mid-1,item);
32. }
33. }
34. return -1;
35. }
36. }
Output:
Output:
1. import java.util.Scanner;
2.
3. public class Leniear_Search {
4. public static void main(String[] args) {
5. int[] arr = {10, 23, 15, 8, 4, 3, 25, 30, 34, 2, 19};
6. int item,flag=0;
7. Scanner sc = new Scanner(System.in);
8. System.out.println("Enter Item ?");
9. item = sc.nextInt();
10. for(int i = 0; i<10; i++)
11. {
12. if(arr[i]==item)
13. {
14. flag = i+1;
15. break;
16. }
17. else
18. flag = 0;
19. }
20. if(flag != 0)
21. {
22. System.out.println("Item found at location" + flag);
23. }
24. else
25. System.out.println("Item not found");
26.
27. }
28. }
Output:
Enter Item ?
23
Item found at location 2
Enter Item ?
22
Item not found
Output:
Sorted array
23
23
23
34
45
65
67
89
90
101
Output:
Test Web
Provides cross-platform for Native and Hybrid mobile automation
Support JSON wire protocol
It does not require recompilation of App
Support automation test on physical device as well as similar or emulator both
It has no dependency on mobile device
ANDROID SDK
JDK
TestNG
Eclipse
Selenium Server JAR
Webdriver Language Binding Library
APPIUM for Windows
APK App Info On Google Play
js
Appium does not support testing of Android Version lower than 4.2
Limited support for hybrid app testing. E.g., not possible to test the switching action of
application from the web app to native and vice-versa
No support to run Appium Inspector on Microsoft Windows
To find the DOM element use "UIAutomateviewer" to find DOM element for Android
application.
6) Explain the design concept of Appium?
Appium is an "HTTP Server" written using Node.js platform and drives iOS and Android
session using Webdriver JSON wire protocol. Hence, before initializing the Appium
Server, Node.js must be pre-installed on the system
When Appium is downloaded and installed, then a server is setup on our machine that
exposes a REST API
It receives connection and command request from the client and execute that command on
mobile devices (Android / iOS)
It responds back with HTTP responses. Again, to execute this request, it uses the mobile
test automation frameworks to drive the user interface of the apps. Framework like
o Apple Instruments for iOS (Instruments are available only in Xcode 3.0 or later
with OS X v10.5 and later)
o Google UIAutomator for Android API level 16 or higher
o Selendroid for Android API level 15 or less
Appium support any language that support HTTP request like Java, JavaScript with Node.js,
Python, Ruby, PHP, Perl, etc.
Pros:
For programmer irrespective of the platform, he is automating ( Android or iOS) all the
complexities will remain under single Appium server
It opens the door to cross-platform mobile testing which means the same test would work
on multiple platforms
Appium does not require extra components in your App to make it automation friendly
It can automate Hybrid, Web and Native mobile applications
Cons:
Running scripts on multiple iOS simulators at the same time is possible with Appium
It uses UIAutomator for Android Automation which supports only Android SDK
platform, API 16 or higher and to support the older API's they have used another open
source library called Selendroid
9) Explain what is APPIUM INSPECTOR?
Similar to Selenium IDE record and Playback tool, Appium has an "Inspector" to record and
playback. It records and plays native application behavior by inspecting DOM and generates the
test scripts in any desired language. However, Appium Inspector does not support Windows and
use UIAutomator viewer in its option.
10) Mention what are the basic requirement for writing Appium tests?
Driver Client: Appium drives mobile applications as though it were a user. Using a client
library you write your Appium tests which wrap your test steps and sends to the Appium
server over HTTP.
Appium Session: You have to first initialize a session, as such Appium test takes place in
the session. Once the Automation is done for one session, it can be ended and wait for
another session
Desired Capabilities: To initialize an Appium session you need to define certain
parameters known as "desired capabilities" like PlatformName, PlatformVersion, Device
Name and so on. It specifies the kind of automation one requires from the Appium server.
Driver Commands: You can write your test steps using a large and expressive
vocabulary of commands.
11) Mention what are the possible errors one might encounter using Appium?
Error 1: The following desired capabilities are needed but not provided: Device Name,
platformName
Error 2: Could not find adb. Please set the ANDROID_HOME environment variable with
the Android SDK root directory path
Error 3: openqa.selenium.SessionNotCreatedException: A new session could not be
created
Error 4: How to find DOM element or Xpath in a mobile application?
No, you don't need server machine to run tests on Appium. Appium facilitates a 2-tier
architecture where a test machine connects to a test server running Appium and automating the
whole thing. You can have Appium running on the same machine where your test runs.
13) Is it possible to interact with my apps using Javascript while I am testing with Appium?
Yes, it is possible to interact with App while using Javascript. When the commands run on
Appium, the server will send the script to your app wrapped into an anonymous function to be
executed.
14) Mention what are the most difficult scenarios to test with Appium?
Yes, you can run the test in a multithreaded environment but you have to ensure that no more
than one test runs at the same time against the same Appium server.
16) In Android, do you need an app's .apk to automate using Appium or you also need app
in my workspace?
Appium package master is a set of tools manage and create appium packages. For example to
create package you can use the code
# using es7/babe1
#regular es5
Appium does not support test framework as such there is no need to support them. Appium can
be used with any frameworks you want.
Appium uses underlying selenium API to automate Test Cases, i.e. Appium is an extension to
selenium because all the Selenium API’s are present in Appium also.
Yes, we can start Appium Server programmatically.Basically the commands we are entering to
the command prompt we write in a notepad and save with .bat extension and click bat file.
By using Appium Inspector which is a GUI based tool similar to Selenium IDE we can identify
the objects.
22) How would you identify Mobile Browser objects? (Important: Appium Interview
Questions)
Ans: By using UserAgent we can identify objects in Mobile Browser. We use UserAgent and
change our browser as the mobile proxy and get an object.
(or)
By using ChromeCasting we can identify objects in Mobile Browser. We use ChromeCasting and
connect our mobile to the system and inspect objects on mobile from the system using
ChromeCasting.
23)How would you identify object uniquely when there are multiple objects with same class
name using appium
By using driver.findElements(By.className) and take the list and get through the index.Using
list mechanism and findElements method we will be traversing through the indexes and handle
the object uniquely with the class name.
25) How do you detect the device got connected to the PC?
By using the command ADB devices we can get the information whether there are any objects or
devices detected by the PC.
Appium does not support test frameworks because there is no need to support, we can use appium
with all test frameworks which ever we want like NUnit, Junit, TestNG etc…
30) What is the difference between Hybrid Apps and Native Apps?
Hybrid apps are web based apps that work well on the mobile browser, where as Native apps are
written for particular OS i.e, Android, iOS, etc…
No, Appium will not be able to test iOS apps on the windows server which is hosted locally,
because appium relies on OS X-only libraries to support iOS testing.
33) What kind of platforms supported by Appium? (Important: Appium Interview Questions)
Android
Firefox mobile OS
iOS
35) What is the default port number used for Appium Server?
Yes, we can use JavaScript to automate applications using Appium.Whatever the language that
supports HTTP request can be used with Appium.
Ruby, Java, Python, PHP, and C# are the appium client libraries which are used for extension
WebDriver protocol.
38) Can we run our tests in a multithreaded environment while using Appium?
Yes, we can run our test in a multithreaded environment while using appium, but we have to
make sure that not to run more than one test at the same time against the same Appium server.
42) How will we run parallel iOS tests in Appium? (Important: Appium Interview Questions)
By using Sauce Labs we can run iOS tests parallel, we just need to upload our Appium test to
sauce labs and it will run as many iOS tests parallel.
43) What are the advantages of using Appium over Sauce Labs?
44) Can we able to test iOS applications on Linux machine using Appium?
No, we won’t be able to test iOS applications on Linux machines by using Appium.
POM is basically an XML file which is used for configuring the project in MAVEN.
49) What are the possible errors you might encounter while using Appium?