equals() and super() keywords in Java
equals() and super() keywords in Java
equals() method
The equals() method resides within the object class.
This is used to determine if two object instances are the same instance (based on the instance signature)
If you want to determine if instances are instead based on the signature but by viewing the variables passed within the parenthesis, you need to override the
equals() method.
Example below
public class EqualsOverride {
private int x;
private int y;
public EqualsOverride(int x, int y){
this.x = x;
this.y = y;
}
public boolean equals(EqualsOverride e){
if ((x == e.x)&&(y==e.y))
return true;
else
return false;
}
public static void main(String[] args) {
EqualsOverride e1 = new EqualsOverride(20, 30);
EqualsOverride e2 = new EqualsOverride(20, 30);
System.out.println(e1.equals(e2));
}
}
This equals true
regarding the equals() method, you must remember:
- The base class when declaring the class instance must be must be the class with the equals() override method within
EqualsOverride e1 = new EqualsOverride(20, 30);
EqualsOverride e2 = new EqualsOverride(20, 30);
Having another class as the base will not invoke the override equals() method
Object e1 = new EqualsOverride(20, 30);
Object e2 = new EqualsOverride(20, 30);
super() method
You can call the super class constructor from within the derived constructor
super() method...
- super() can only be called within the derived class constructor only
- Must be the first line within the derived class constructor
public class Apples extends Fruit{
public Apples (int x, int y){
super(10,20);
}
}
This example below will throw an error
public Apples (int x, int y){
int x = 100;
super(10,20);
}
Upcast and Downcast
- Upcasting -- Changing the instance of the class to it's superclass
- Downcasting -- Changing from it's class instance to a derived class (requires explicit casting)
Below is casting from a String to an Object
String s1 = "Alright!";
Object o = s1; //No explicit casting needed
Downcasting requires you to explicitly highlight the casting (Start with an object then converts into a String instance)
Object o = new Object();
String s1 = (String) o;//requires casting
Upcast then downcast
Int -+ Obj --+ String
You cannot upcast then downcast because you'll get a ClassCastException error
instanceOf (ideal for downcasting)
There's no ClassCastException exception handling, so the best way is to use the instanceOf boolean operator.
This helps the java program determine if downcasting is safe to do.
if (obj instanceOf String){
String str2 = (String) obj;
{
Packages
+++
+++ package1
+++
Class1
+++
+++ package2
+++
Class2
package1.Class1 = new package1.Class1();
If you want to create an instance of Class1 from within Class2, you need to declare the FQN next to the base class.
Alternatively, you can just import the class from by using the import
package 2:
import package1.Class1;
About the author

Daniel has built from scratch this blog as well as technicalconfessions.com
Follow Daniel on twitter @nervouswiggles
Comments
Other Posts
February 6, 2020
Created by: Daniel Redfern
AS I was migrating my environment into an S3 environment, I wanted to leverage off the SES services that AWS provide, more specifically, to leverage the off the SMTP functionality by sending an email via PHP
Read More...
AS I was migrating my environment into an S3 environment, I wanted to leverage off the SES services that AWS provide, more specifically, to leverage the off the SMTP functionality by sending an email via PHP
Read More...
February 24, 2019
Created by: Daniel Redfern
The WeMos D1 is a ESP8266 WiFi based board is an extension to the current out-of-the-box library that comes with the Arduino installation. Because of this, you need to import in the libraries as well as acknowledging the specific board. This process is highly confusion with a number of different individuals talking about a number of different ways to integrate.
Read More...
The WeMos D1 is a ESP8266 WiFi based board is an extension to the current out-of-the-box library that comes with the Arduino installation. Because of this, you need to import in the libraries as well as acknowledging the specific board. This process is highly confusion with a number of different individuals talking about a number of different ways to integrate.
Read More...

August 7, 2018
Created by: Daniel Redfern
NameID element must be present as part of the Subject in the Response message, please enable it in the IDP configuration.
Read More...
NameID element must be present as part of the Subject in the Response message, please enable it in the IDP configuration.
Read More...

June 15, 2018
Created by: Daniel Redfern
For what I see, there's not too many supportive documentations out there that will demonstrate how provision AD group membership with the ICF connector using OpenIDM. The use of the special ldapGroups attribute is not explained anywhere in the Integrators guides to to the date of this blog. This quick blog identifies the tasks required to provision AD group membership from OpenIDM to AD using the LDAP ICF connector. However this doesn't really explain what ldapGroups actually does and there's no real worked example of how to go from an Assignment to ldapGroups to an assigned group in AD. I wrote up a wiki article for my own reference: AD group memberships automatically to users This is just my view, others may disagree, but I think the implementation experience could be improved with some more documentation and a more detailed example here.
Read More...
For what I see, there's not too many supportive documentations out there that will demonstrate how provision AD group membership with the ICF connector using OpenIDM. The use of the special ldapGroups attribute is not explained anywhere in the Integrators guides to to the date of this blog. This quick blog identifies the tasks required to provision AD group membership from OpenIDM to AD using the LDAP ICF connector. However this doesn't really explain what ldapGroups actually does and there's no real worked example of how to go from an Assignment to ldapGroups to an assigned group in AD. I wrote up a wiki article for my own reference: AD group memberships automatically to users This is just my view, others may disagree, but I think the implementation experience could be improved with some more documentation and a more detailed example here.
Read More...

November 8, 2017
Created by: Daniel Redfern
In the past, the similar error occurred though for the Oracle Identity Management solution. invalidcredentialexception remote framework key is invalid Because they all share the ICF connector framework, the error/solution would be the same.
Read More...
In the past, the similar error occurred though for the Oracle Identity Management solution. invalidcredentialexception remote framework key is invalid Because they all share the ICF connector framework, the error/solution would be the same.
Read More...

November 8, 2017
Created by: Daniel Redfern
org.forgerock.script.exception.ScriptCompilationException: missing ; before statement
Read More...
org.forgerock.script.exception.ScriptCompilationException: missing ; before statement
Read More...

September 17, 2017
Created by: Daniel Redfern
ForgeRock IDM - org.forgerock.script.exception.ScriptCompilationException: missing ; before statement
Read More...
ForgeRock IDM - org.forgerock.script.exception.ScriptCompilationException: missing ; before statement
Read More...

September 17, 2017
Created by: Daniel Redfern
When performing the attempt of a reconciliation from ForgeRock IDM to Active Directory, I would get the following error
Read More...
When performing the attempt of a reconciliation from ForgeRock IDM to Active Directory, I would get the following error
Read More...

September 17, 2017
Created by: Daniel Redfern
In the past, the similar error occurred though for the Oracle Identity Management solution. invalidcredentialexception remote framework key is invalid Because they all share the ICF connector framework, the error/solution would be the same.
Read More...
In the past, the similar error occurred though for the Oracle Identity Management solution. invalidcredentialexception remote framework key is invalid Because they all share the ICF connector framework, the error/solution would be the same.
Read More...

September 12, 2017
Created by: Daniel Redfern
During the reconcilation from OpenIDM to the ICF google apps connector, the following error response would occur. ERROR Caused by com.google.api.client.auth.oauth2.TokenResponseException 400 Bad Request - invalid_grant
Read More...
During the reconcilation from OpenIDM to the ICF google apps connector, the following error response would occur. ERROR Caused by com.google.api.client.auth.oauth2.TokenResponseException 400 Bad Request - invalid_grant
Read More...
