How can abstract classes have references but not objects?
Solution 1
When you have an object reference whose type is an abstract class, that reference doesn't mean "I'm referencing an abstract class." Instead, it means "I'm referencing some actual object that's a subclass of that abstract class." This is why you can have the reference refer to a SavingsAccount
, which is a non-abstract class that subclasses from Account
, but you can't have it point to a new Account()
, since you can't actually instantiate Account
.
Note that the reference itself isn't an actual instance of the abstract class.
Hope this helps!
Solution 2
The problem is that you cannot call abstract member routines.
When you call ’new’ you're actually calling the class's constructor.
Because you're trying to call an abstract member function you get an error.
You can reference an abstract class, because it is just a blueprint for a real class that derives from it. A bit like an interface but with inheritance.
Just like you cannot instantiate an interface you cannot instantiate an abstract class.
This of course is part of polymorphism.
The differences between abstract classes and interfaces are remarkably small, see:Interface vs Abstract Class (general OO)
Related videos on Youtube
user2809437
Updated on June 04, 2022Comments
-
user2809437 almost 2 years
Note that you cannot construct an object of an abstract class, but you can still have an object reference whose type is an abstract class. Of course, the actual object to which it refers must be an instance of a concrete subclass:
Account anAccount; // OK anAccount = new Account(); // Error—Account is abstract anAccount = new SavingsAccount(); // OK anAccount = null; // OK
Not understanding why you can have an object reference to an abstract class...
-
user2809437 over 10 yearsOk so when you do things like Account anAccount; what is that saying? it's not actually pointing to anything? Even if it wasn't an abstract class lets say String tmp; you haven't given it an address yet?
-
templatetypedef over 10 years@user2809437- That's correct. When you say
Account anAccount
, you get a reference calledanAccount
that initially holdsnull
, meaning that it's not pointing at anything. It's the same withString tmp
; you get a reference to aString
, but it points tonull
because you haven't assigned it to point to aString
yet. -
user2809437 over 10 yearsOne more question...what's the point of doing this? If you cannot create an instance of the class, why both with the reference?
-
templatetypedef over 10 years@user2809437- Suppose that you want to manipulate an account, but you're not sure what kind of account. Maybe it's a
SavingsAccount
, or maybe it's aCheckingAccount
, aMoneyMarketAccount
, aTreasuryAccount
, etc. Having a reference of typeAccount
means that you can have a single variable that stores a reference to an object of any of those types, which makes it possible to write code that works on "accounts in general" without duplicating it for each of these types of accounts. -
user2809437 over 10 yearsfantastic explanation!! :)