• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 04:19
CEST 10:19
KST 17:19
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
Code S Season 1 - RO12 Group A: Rogue, Percival, Solar, Zoun11[ASL21] Ro8 Preview Pt1: Inheritors16[ASL21] Ro16 Preview Pt2: All Star10Team Liquid Map Contest #22 - The Finalists21[ASL21] Ro16 Preview Pt1: Fresh Flow9
Community News
2026 GSL Season 1 Qualifiers25Maestros of the Game 2 announced92026 GSL Tour plans announced15Weekly Cups (April 6-12): herO doubles, "Villains" prevail1MaNa leaves Team Liquid25
StarCraft 2
General
Code S Season 1 - RO12 Group A: Rogue, Percival, Solar, Zoun Team Liquid Map Contest #22 - The Finalists Blizzard Classic Cup @ BlizzCon 2026 - $100k prize pool MaNa leaves Team Liquid Maestros of the Game 2 announced
Tourneys
GSL Code S Season 1 (2026) SC2 INu's Battles#15 <BO.9 2Matches> WardiTV Spring Cup RSL Revival: Season 5 - Qualifiers and Main Event SEL Masters #6 - Solar vs Classic (SC: Evo)
Strategy
Custom Maps
[D]RTS in all its shapes and glory <3 [A] Nemrods 1/4 players [M] (2) Frigid Storage
External Content
The PondCast: SC2 News & Results Mutation # 523 Firewall Mutation # 522 Flip My Base Mutation # 521 Memorable Boss
Brood War
General
Pros React To: Leta vs Tulbo (ASL S21, Ro.8) ASL21 General Discussion [TOOL] Starcraft Chat Translator JaeDong's ASL S21 Ro16 Post-Review Missed out on ASL tickets - what are my options?
Tourneys
Escore Tournament StarCraft Season 2 [ASL21] Ro8 Day 2 [ASL21] Ro8 Day 1 ASL Season 21 LIVESTREAM with English Commentary
Strategy
Fighting Spirit mining rates Simple Questions, Simple Answers What's the deal with APM & what's its true value Any training maps people recommend?
Other Games
General Games
Daigo vs Menard Best of 10 Stormgate/Frost Giant Megathread Nintendo Switch Thread Dawn of War IV Diablo IV
Dota 2
The Story of Wings Gaming
League of Legends
G2 just beat GenG in First stand
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Deck construction bug Heroes of StarCraft mini-set
TL Mafia
Vanilla Mini Mafia Mafia Game Mode Feedback/Ideas TL Mafia Community Thread Five o'clock TL Mafia
Community
General
US Politics Mega-thread European Politico-economics QA Mega-thread Russo-Ukrainian War Thread 3D technology/software discussion Canadian Politics Mega-thread
Fan Clubs
The IdrA Fan Club
Media & Entertainment
[Manga] One Piece Anime Discussion Thread [Req][Books] Good Fantasy/SciFi books Movie Discussion!
Sports
2024 - 2026 Football Thread McBoner: A hockey love story Formula 1 Discussion
World Cup 2022
Tech Support
streaming software Strange computer issues (software) [G] How to Block Livestream Ads
TL Community
The Automated Ban List
Blogs
Sexual Health Of Gamers
TrAiDoS
lurker extra damage testi…
StaticNine
Broowar part 2
qwaykee
Funny Nicknames
LUCKY_NOOB
Iranian anarchists: organize…
XenOsky
Customize Sidebar...

Website Feedback

Closed Threads



Active: 2561 users

The Big Programming Thread - Page 767

Forum Index > General Forum
Post a Reply
Prev 1 765 766 767 768 769 1032 Next
Thread Rules
1. This is not a "do my homework for me" thread. If you have specific questions, ask, but don't post an assignment or homework problem and expect an exact solution.
2. No recruiting for your cockamamie projects (you won't replace facebook with 3 dudes you found on the internet and $20)
3. If you can't articulate why a language is bad, don't start slinging shit about it. Just remember that nothing is worse than making CSS IE6 compatible.
4. Use [code] tags to format code blocks.
Acrofales
Profile Joined August 2010
Spain18283 Posts
September 24 2016 11:21 GMT
#15321
On September 24 2016 19:55 Prillan wrote:
Show nested quote +
On September 24 2016 18:03 spinesheath wrote:

int fizz, bar;

public void foo(int bar) { // this is where it could show a warning that bar is shadowing this.bar

int fizz; // this is where it could show a warning that fizz is shadowing this.fizz

// ... enough code to make you forget the line above ...

fizz = 5; // here you could mean to assign to this.fizz, introducing a bug

// and if we have some slightly more complex code with say loops, you might not even get a
// "value assigned to variable is never used" warning
}


One reason why I like the explicit self in python.


def method(self, bar):
... code here ...


I don't see how that solves anything. And you have the global scope as well.
spinesheath
Profile Blog Joined June 2009
Germany8679 Posts
Last Edited: 2016-09-24 11:39:26
September 24 2016 11:37 GMT
#15322
On September 24 2016 18:22 Acrofales wrote:
Show nested quote +
On September 24 2016 18:03 spinesheath wrote:

int fizz, bar;

public void foo(int bar) { // this is where it could show a warning that bar is shadowing this.bar

int fizz; // this is where it could show a warning that fizz is shadowing this.fizz

// ... enough code to make you forget the line above ...

fizz = 5; // here you could mean to assign to this.fizz, introducing a bug

// and if we have some slightly more complex code with say loops, you might not even get a
// "value assigned to variable is never used" warning
}


Yeah, ok. That's pretty bad. Anybody using shadowing like that is asking for it, though

I mean, I'm not a fan of shadowing in general and never use it, except in the constructor to initialize fields. And that goes at the bottom of the constructor, so any operations you do before just setting the field aren't affected b the potential bugs you describe.

Even if someone is aware of this possibility there still might be a time where he accidentally runs into that issue. Especially if the code for that class is modified well after it was first created.

Treat shadowing as a warning/error, use naming conventions that let you avoid all shadowing and you will have one less potential problem to worry about.

Though it certainly should be possible to create a more sophisticated shadowing warning rule that reports all shadowing except for simple initialization from the constructor.
If you have a good reason to disagree with the above, please tell me. Thank you.
Prillan
Profile Joined August 2011
Sweden350 Posts
September 24 2016 14:35 GMT
#15323
On September 24 2016 20:21 Acrofales wrote:
Show nested quote +
On September 24 2016 19:55 Prillan wrote:
On September 24 2016 18:03 spinesheath wrote:

int fizz, bar;

public void foo(int bar) { // this is where it could show a warning that bar is shadowing this.bar

int fizz; // this is where it could show a warning that fizz is shadowing this.fizz

// ... enough code to make you forget the line above ...

fizz = 5; // here you could mean to assign to this.fizz, introducing a bug

// and if we have some slightly more complex code with say loops, you might not even get a
// "value assigned to variable is never used" warning
}


One reason why I like the explicit self in python.


def method(self, bar):
... code here ...


I don't see how that solves anything. And you have the global scope as well.


The point is that, if you want to set a variable on the object, you have to use self. So if you find

def method(self):
foo = 1

it won't set foo on self but rather the local, newly declared variable, foo.

Setting variables in the global scope is an abomination, in all languages, and should be killed. Reading them can be permitted.

What this results in is that if you assign a variable inside a function, it will always create a local variable with that name. If you want to set a field on an object, you use x.foo = bar.


I'm not saying it's perfect. But at least it makes setting variables consistent whereas in other languages foo = bar could mean two different things depending on if the object has a field called foo or not.
TheBB's sidekick, aligulac.com | "Reality is frequently inaccurate." - Douglas Adams
RoomOfMush
Profile Joined March 2015
1296 Posts
September 24 2016 14:36 GMT
#15324
On September 24 2016 20:37 spinesheath wrote:
Show nested quote +
On September 24 2016 18:22 Acrofales wrote:
On September 24 2016 18:03 spinesheath wrote:

int fizz, bar;

public void foo(int bar) { // this is where it could show a warning that bar is shadowing this.bar

int fizz; // this is where it could show a warning that fizz is shadowing this.fizz

// ... enough code to make you forget the line above ...

fizz = 5; // here you could mean to assign to this.fizz, introducing a bug

// and if we have some slightly more complex code with say loops, you might not even get a
// "value assigned to variable is never used" warning
}


Yeah, ok. That's pretty bad. Anybody using shadowing like that is asking for it, though

I mean, I'm not a fan of shadowing in general and never use it, except in the constructor to initialize fields. And that goes at the bottom of the constructor, so any operations you do before just setting the field aren't affected b the potential bugs you describe.

Even if someone is aware of this possibility there still might be a time where he accidentally runs into that issue. Especially if the code for that class is modified well after it was first created.

Treat shadowing as a warning/error, use naming conventions that let you avoid all shadowing and you will have one less potential problem to worry about.

Though it certainly should be possible to create a more sophisticated shadowing warning rule that reports all shadowing except for simple initialization from the constructor.

Eclipse already has a build in warning for local variables shadowing fields with optional warnings for within constructors & setters. Furthermore there is a warning for fields shadowing inherited fields of super classes. The different syntax highlighting for fields and local variables is enabled by default too so unless you explicitly change it you should always see the difference when working with a local variable compared to a field.

But I dont like naming parameters the same as fields either. I usually give parameters long and descriptive names while fields get abbreviated forms. Doesnt always work though.
Manit0u
Profile Blog Joined August 2004
Poland17740 Posts
September 24 2016 14:55 GMT
#15325
On September 24 2016 23:36 RoomOfMush wrote:
Show nested quote +
On September 24 2016 20:37 spinesheath wrote:
On September 24 2016 18:22 Acrofales wrote:
On September 24 2016 18:03 spinesheath wrote:

int fizz, bar;

public void foo(int bar) { // this is where it could show a warning that bar is shadowing this.bar

int fizz; // this is where it could show a warning that fizz is shadowing this.fizz

// ... enough code to make you forget the line above ...

fizz = 5; // here you could mean to assign to this.fizz, introducing a bug

// and if we have some slightly more complex code with say loops, you might not even get a
// "value assigned to variable is never used" warning
}


Yeah, ok. That's pretty bad. Anybody using shadowing like that is asking for it, though

I mean, I'm not a fan of shadowing in general and never use it, except in the constructor to initialize fields. And that goes at the bottom of the constructor, so any operations you do before just setting the field aren't affected b the potential bugs you describe.

Even if someone is aware of this possibility there still might be a time where he accidentally runs into that issue. Especially if the code for that class is modified well after it was first created.

Treat shadowing as a warning/error, use naming conventions that let you avoid all shadowing and you will have one less potential problem to worry about.

Though it certainly should be possible to create a more sophisticated shadowing warning rule that reports all shadowing except for simple initialization from the constructor.

Eclipse already has a build in warning for local variables shadowing fields with optional warnings for within constructors & setters. Furthermore there is a warning for fields shadowing inherited fields of super classes. The different syntax highlighting for fields and local variables is enabled by default too so unless you explicitly change it you should always see the difference when working with a local variable compared to a field.

But I dont like naming parameters the same as fields either. I usually give parameters long and descriptive names while fields get abbreviated forms. Doesnt always work though.


You should always assume that someone might be looking at your code through vim or something and won't get all the IDE syntax sugar. As was stated previously, relying on smart IDE features to help with unclear code is a bad idea. It's pretty close to code obfuscation.
Time is precious. Waste it wisely.
RoomOfMush
Profile Joined March 2015
1296 Posts
September 24 2016 17:12 GMT
#15326
On September 24 2016 23:55 Manit0u wrote:
Show nested quote +
On September 24 2016 23:36 RoomOfMush wrote:
On September 24 2016 20:37 spinesheath wrote:
On September 24 2016 18:22 Acrofales wrote:
On September 24 2016 18:03 spinesheath wrote:

int fizz, bar;

public void foo(int bar) { // this is where it could show a warning that bar is shadowing this.bar

int fizz; // this is where it could show a warning that fizz is shadowing this.fizz

// ... enough code to make you forget the line above ...

fizz = 5; // here you could mean to assign to this.fizz, introducing a bug

// and if we have some slightly more complex code with say loops, you might not even get a
// "value assigned to variable is never used" warning
}


Yeah, ok. That's pretty bad. Anybody using shadowing like that is asking for it, though

I mean, I'm not a fan of shadowing in general and never use it, except in the constructor to initialize fields. And that goes at the bottom of the constructor, so any operations you do before just setting the field aren't affected b the potential bugs you describe.

Even if someone is aware of this possibility there still might be a time where he accidentally runs into that issue. Especially if the code for that class is modified well after it was first created.

Treat shadowing as a warning/error, use naming conventions that let you avoid all shadowing and you will have one less potential problem to worry about.

Though it certainly should be possible to create a more sophisticated shadowing warning rule that reports all shadowing except for simple initialization from the constructor.

Eclipse already has a build in warning for local variables shadowing fields with optional warnings for within constructors & setters. Furthermore there is a warning for fields shadowing inherited fields of super classes. The different syntax highlighting for fields and local variables is enabled by default too so unless you explicitly change it you should always see the difference when working with a local variable compared to a field.

But I dont like naming parameters the same as fields either. I usually give parameters long and descriptive names while fields get abbreviated forms. Doesnt always work though.


You should always assume that someone might be looking at your code through vim or something and won't get all the IDE syntax sugar. As was stated previously, relying on smart IDE features to help with unclear code is a bad idea. It's pretty close to code obfuscation.

I dont quite agree. The people who like to use an IDE will use an IDE. Those who dont like to use it better man up and learn how to deal with code like that. The editor / IDE you use is a tool. If it doesnt help you then you chose the wrong tool. Choose the right tool and you wont have a problem.

I dont blame nail manufacturers because I cant use a screwdriver to screw the nails into my walls. Its my job to get a hammer.
spinesheath
Profile Blog Joined June 2009
Germany8679 Posts
September 24 2016 17:25 GMT
#15327
A nail isn't quite the type of product that is modified by multiple people during its lifetime.

You know how you somtimes are forced to go to car repair shops that specialize on your kind of car instead of just any mechanic because fixing your car requires special tools? If you can increase the number of supported tools at next to no cost, you should go for it. Unless you want to boost the market share of your favorite IDE.
If you have a good reason to disagree with the above, please tell me. Thank you.
phar
Profile Joined August 2011
United States1080 Posts
September 24 2016 17:48 GMT
#15328
Use final (or const). Gets you halfway there, assuming you aren't passing around weird mutable objects.
Who after all is today speaking about the destruction of the Armenians?
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
September 25 2016 15:11 GMT
#15329
im not sure if this is a java specific question or not

but when do you want to use try/catch blocks instead of if(condition) { throw exception() } ?

is it only for checked instead of unchecked exceptions or is it more complicated than that?
RoomOfMush
Profile Joined March 2015
1296 Posts
Last Edited: 2016-09-25 15:39:17
September 25 2016 15:36 GMT
#15330
On September 26 2016 00:11 travis wrote:
im not sure if this is a java specific question or not

but when do you want to use try/catch blocks instead of if(condition) { throw exception() } ?

is it only for checked instead of unchecked exceptions or is it more complicated than that?

The simple answer: You use a try / catch block when you need it.

The better answer: You should build your software in a way that you never need a try / catch block unless when interfacing with third party systems or using native resources.

A try / catch block indicates that the programmer knows the code within the try block might throw an exception. In general this should only happen (a) when you use a method improperly, (b) when you dont know what the code will actually do (because you load it dynamically) or (c) when you use system components that might randomly fail (reading files from the OS when you dont have access, networking, etc).

Obviously you should always use third party libraries (or even your own code) correctly so the first of the above 3 "reasons" isnt a good reason at all. The other 2 reasons are unavoidable.

Examples:
B) You allow the user to customize your software with a plugin system. Users may write their own plugins, load them into the application and have them perform tasks. As the developer of your application it is impossible for you to know what exactly those plugins do and they might throw exceptions if they are nor properly written. For this reason you wrap all calls to the plugin system in try / catch blocks to make sure your application doesnt crash randomly because of faulty plugins.

C) You connect to a server to request certain data to be used by your application. The network might always randomly fail and a connection may be lost at any point in time. To make sure your application doesnt crash in these situations you wrap the networking code into try / catch blocks. When an exception is caught you display error dialogs to the user to let him know the connection was lost and he has to try again.


Edit:
By the way, even though it is possible you should NEVARR use exception to control the flow of your application. At least not in java. The performance of exceptions is horrendous compare to if/then/else statements. Every time an exception is generated the entire stack has to be traversed backwards to build the stacktrace. It also has to read all kinds of debug information from the .class files to generate a proper error message.
Acrofales
Profile Joined August 2010
Spain18283 Posts
September 25 2016 15:40 GMT
#15331
On September 26 2016 00:11 travis wrote:
im not sure if this is a java specific question or not

but when do you want to use try/catch blocks instead of if(condition) { throw exception() } ?

is it only for checked instead of unchecked exceptions or is it more complicated than that?

Your question isn't clear. The effect of trying something and then catching the exception is not the same as the effect of checking a condition and throwing an exception. In fact, they are almost the exact opposite, and complement one another.

In general, you want to throw an exception when you know something can go wrong, but how to deal with that is not the responsibility of that part of the code. You throw an exception so that the calling code can deal with that in a try... catch block.
Manit0u
Profile Blog Joined August 2004
Poland17740 Posts
September 25 2016 16:01 GMT
#15332
On September 26 2016 00:36 RoomOfMush wrote:
Show nested quote +
On September 26 2016 00:11 travis wrote:
im not sure if this is a java specific question or not

but when do you want to use try/catch blocks instead of if(condition) { throw exception() } ?

is it only for checked instead of unchecked exceptions or is it more complicated than that?

The simple answer: You use a try / catch block when you need it.

The better answer: You should build your software in a way that you never need a try / catch block unless when interfacing with third party systems or using native resources.

A try / catch block indicates that the programmer knows the code within the try block might throw an exception. In general this should only happen (a) when you use a method improperly, (b) when you dont know what the code will actually do (because you load it dynamically) or (c) when you use system components that might randomly fail (reading files from the OS when you dont have access, networking, etc).

Obviously you should always use third party libraries (or even your own code) correctly so the first of the above 3 "reasons" isnt a good reason at all. The other 2 reasons are unavoidable.

Examples:
B) You allow the user to customize your software with a plugin system. Users may write their own plugins, load them into the application and have them perform tasks. As the developer of your application it is impossible for you to know what exactly those plugins do and they might throw exceptions if they are nor properly written. For this reason you wrap all calls to the plugin system in try / catch blocks to make sure your application doesnt crash randomly because of faulty plugins.

C) You connect to a server to request certain data to be used by your application. The network might always randomly fail and a connection may be lost at any point in time. To make sure your application doesnt crash in these situations you wrap the networking code into try / catch blocks. When an exception is caught you display error dialogs to the user to let him know the connection was lost and he has to try again.


Edit:
By the way, even though it is possible you should NEVARR use exception to control the flow of your application. At least not in java. The performance of exceptions is horrendous compare to if/then/else statements. Every time an exception is generated the entire stack has to be traversed backwards to build the stacktrace. It also has to read all kinds of debug information from the .class files to generate a proper error message.


Try/catch blocks are super good for DB connections though. So that you can rollback in case of error.
Time is precious. Waste it wisely.
phar
Profile Joined August 2011
United States1080 Posts
September 25 2016 21:49 GMT
#15333
Yea, also quite necessary, e.g. towards the top of a service handler. Unless you like queries of death.
Who after all is today speaking about the destruction of the Armenians?
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
Last Edited: 2016-09-27 00:45:21
September 26 2016 23:29 GMT
#15334
It looks like me and my learning is propelling this thread forward. How nice of me to give you veterans something to do.

I am studying for my first exam for my OOP 2 class.

Here is some questions in the study guide I am not sure I understood (this isn't homework, I promise).

True or False?

"Interfaces are useful for inheritance"

I said true, but I thought the question is weird. I understand that a class doesn't actually extend the interface but it does in a way inherit it's properties, yes?


"interfaces are useful for polymorphism"

I didn't know what to say to this question. I believe polymorphism is just the concept that a subclass can be treated as either it's class type, or also as it's super classes. I didn't really know how to respond to this question.


"an interface can be used as a type"

I looked it up. It's true. I didn't know this. But I don't understand the example here:

http://docs.oracle.com/javase/tutorial/java/IandI/interfaceAsType.html

It seems they cast their object to the type relatable, which is their interface. Their interface requires that a class have the method isLargerThan(); . But in an interface, isLargerThan(); is empty, to be defined in the implementing class, right? So wtf does casting a random object to the interface type actually do? It doesn't have the isLargerThan(); method. So.. I don't get it.


"An interface can be used to create a 'polymorphic collection'"

-I have no idea. I've never heard of a polymorphic collection. I tried doing a google search. Not much information. I saw something about Collection<? extends A> . Don't know what this would have to do with interfaces.



edit: another question

why do constructors use the "this" keyword to set instance variables, but I keep seeing examples of copy constructors that *don't* use the "this" keyword when copying the variables?
icystorage
Profile Blog Joined November 2008
Jollibee19350 Posts
September 27 2016 00:42 GMT
#15335
I'm looking for other job opportunities, currently I'm employed on my first job starting entry level and currently a mid level dev. I have 3 years job exp. How's the market for AngularJS/.Net devs?
LiquidDota StaffAre you ready for a Miracle-? We are! The International 2017 Champions!
Birdie
Profile Blog Joined August 2007
New Zealand4438 Posts
September 27 2016 00:49 GMT
#15336
It seems they cast their object to the type relatable, which is their interface. Their interface requires that a class have the method isLargerThan(); . But in an interface, isLargerThan(); is empty, to be defined in the implementing class, right? So wtf does casting a random object to the interface type actually do? It doesn't have the isLargerThan(); method. So.. I don't get it.

Only classes which implement a particular interface can be cast to that interface. So it isn't a "random" object, it is an object which already implements all the methods in that interface.

It says that in that document: "If you define a reference variable whose type is an interface, any object you assign to it must be an instance of a class that implements the interface."

In the example given, the Object class must be implementing the Relatable interface (and therefore has a method implementation of isLargerThan).

Think of an interface as a contract which the implementing class agrees to follow. The "implement" keyword is the class signing the contract, and the interface's methods are the terms of the contract. The class must follow the contract by creating methods which are the same as the interface's methods. Any class which signs the interface contract can then have the interface's methods called on it, because it guarantees by signing it (with the "implement" keyword) that it will have a version of all the methods in an interface.
Red classic | A butterfly dreamed he was Zhuangzi | 4.5k, heading to 5k as support!
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
Last Edited: 2016-09-27 01:22:35
September 27 2016 01:20 GMT
#15337
On September 27 2016 08:29 travis wrote:
edit: another question

why do constructors use the "this" keyword to set instance variables, but I keep seeing examples of copy constructors that *don't* use the "this" keyword when copying the variables?


public class Animal {

public String name;
public Object lazyExample;
public int id;

public Animal(String name, Object lazyExample, int id) {
this.name = name;
this.lazyExample = lazyExample;
this.id = id;
}

public Animal(Animal other) {
name = other.name;
lazyExample = new Object(other.lazyExample);
id = other.id;
}
}


You don't need the this keyword because the variables are not being shadowed. In the constructor the variable names are being shadowed by the parameters of the constructor method. However, I'd almost write it as follows because it improves readability which is more important.

public Animal(Animal other) {
this.name = other.name;
this.lazyExample = new Object(other.getLazyExample);
this.id = other.id;
}
I'll always be your shadow and veil your eyes from states of ain soph aur.
meatpudding
Profile Joined March 2011
Australia520 Posts
September 27 2016 02:03 GMT
#15338
On September 27 2016 08:29 travis wrote:
"An interface can be used to create a 'polymorphic collection'"

-I have no idea. I've never heard of a polymorphic collection. I tried doing a google search. Not much information. I saw something about Collection<? extends A> . Don't know what this would have to do with interfaces.


I'm not sure about this question either, the wording doesn't quite make sense. I think from your explanation that it's looking at container types, where you can define that the container takes a bunch of interface types, which could all be different actual types. Eg, if you had the interface Shape
list<Shape*> shapeList;
shapeList.append(new Circle);
shapeList.append(new Rectangle);
Be excellent to each other.
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
September 27 2016 02:26 GMT
#15339
On September 27 2016 09:49 Birdie wrote:
Show nested quote +
It seems they cast their object to the type relatable, which is their interface. Their interface requires that a class have the method isLargerThan(); . But in an interface, isLargerThan(); is empty, to be defined in the implementing class, right? So wtf does casting a random object to the interface type actually do? It doesn't have the isLargerThan(); method. So.. I don't get it.

Only classes which implement a particular interface can be cast to that interface. So it isn't a "random" object, it is an object which already implements all the methods in that interface.

It says that in that document: "If you define a reference variable whose type is an interface, any object you assign to it must be an instance of a class that implements the interface."

In the example given, the Object class must be implementing the Relatable interface (and therefore has a method implementation of isLargerThan).

Think of an interface as a contract which the implementing class agrees to follow. The "implement" keyword is the class signing the contract, and the interface's methods are the terms of the contract. The class must follow the contract by creating methods which are the same as the interface's methods. Any class which signs the interface contract can then have the interface's methods called on it, because it guarantees by signing it (with the "implement" keyword) that it will have a version of all the methods in an interface.


So then if the Object class is implementing the Relatable interface and therefore has a method implementation of isLargerThan , then what is the point of casting it to that interface type? It already has the method, so what new thing does casting it to the interface type do?
meatpudding
Profile Joined March 2011
Australia520 Posts
September 27 2016 02:46 GMT
#15340
On September 27 2016 11:26 travis wrote:
Show nested quote +
On September 27 2016 09:49 Birdie wrote:
It seems they cast their object to the type relatable, which is their interface. Their interface requires that a class have the method isLargerThan(); . But in an interface, isLargerThan(); is empty, to be defined in the implementing class, right? So wtf does casting a random object to the interface type actually do? It doesn't have the isLargerThan(); method. So.. I don't get it.

Only classes which implement a particular interface can be cast to that interface. So it isn't a "random" object, it is an object which already implements all the methods in that interface.

It says that in that document: "If you define a reference variable whose type is an interface, any object you assign to it must be an instance of a class that implements the interface."

In the example given, the Object class must be implementing the Relatable interface (and therefore has a method implementation of isLargerThan).

Think of an interface as a contract which the implementing class agrees to follow. The "implement" keyword is the class signing the contract, and the interface's methods are the terms of the contract. The class must follow the contract by creating methods which are the same as the interface's methods. Any class which signs the interface contract can then have the interface's methods called on it, because it guarantees by signing it (with the "implement" keyword) that it will have a version of all the methods in an interface.


So then if the Object class is implementing the Relatable interface and therefore has a method implementation of isLargerThan , then what is the point of casting it to that interface type? It already has the method, so what new thing does casting it to the interface type do?


You can still do stuff like
RelatableObject* relatable;
relatable = new Integer(3);
relatable->isLargerThan(PI);
relateble = new Real(3.5);
relateable->isLargerThan(PI);

Assuming that Integer and Real inherit the same interface. The point is that the isLargerThan method is never called on the concrete class, but only through the interface. (I know c++ doesn't have real interfaces, but whatever).
Be excellent to each other.
Prev 1 765 766 767 768 769 1032 Next
Please log in or register to reply.
Live Events Refresh
Next event in 41m
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
ProTech167
Livibee 113
Nina 77
StarCraft: Brood War
Mind 855
Killer 479
firebathero 444
Hm[arnc] 394
Pusan 314
Dewaltoss 56
yabsab 41
Leta 36
NotJumperer 35
ToSsGirL 35
[ Show more ]
Bale 34
actioN 23
Nal_rA 19
ZergMaN 18
Sharp 15
Shuttle 14
Terrorterran 2
Dota 2
resolut1ontv 638
monkeys_forever539
NeuroSwarm148
League of Legends
JimRising 648
Counter-Strike
Stewie2K1247
shoxiejesuss1141
ceh9438
Other Games
summit1g5539
WinterStarcraft541
Happy331
Sick232
crisheroes0
Organizations
Other Games
gamesdonequick529
Dota 2
PGL Dota 2 - Main Stream116
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
[ Show 13 non-featured ]
StarCraft 2
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
League of Legends
• Stunt690
• Jankos672
• TFBlade630
Upcoming Events
Replay Cast
41m
Escore
1h 41m
INu's Battles
2h 41m
Classic vs ByuN
SHIN vs ByuN
OSC
4h 41m
Big Brain Bouts
7h 41m
Replay Cast
15h 41m
Replay Cast
1d
RSL Revival
1d 1h
Classic vs GgMaChine
Rogue vs Maru
WardiTV Invitational
1d 2h
IPSL
1d 7h
Ret vs Art_Of_Turtle
Radley vs TBD
[ Show More ]
BSL
1d 10h
Replay Cast
1d 15h
RSL Revival
2 days
herO vs TriGGeR
NightMare vs Solar
uThermal 2v2 Circuit
2 days
BSL
2 days
IPSL
2 days
eOnzErG vs TBD
G5 vs Nesh
Patches Events
2 days
Replay Cast
3 days
Wardi Open
3 days
Afreeca Starleague
3 days
Jaedong vs Light
Monday Night Weeklies
3 days
Replay Cast
3 days
Sparkling Tuna Cup
4 days
Afreeca Starleague
4 days
Snow vs Flash
WardiTV Invitational
4 days
GSL
5 days
Classic vs Cure
Maru vs Rogue
GSL
6 days
SHIN vs Zoun
ByuN vs herO
Replay Cast
6 days
Liquipedia Results

Completed

Proleague 2026-04-29
WardiTV TLMC #16
Nations Cup 2026

Ongoing

BSL Season 22
ASL Season 21
CSL 2026 SPRING (S20)
IPSL Spring 2026
KCM Race Survival 2026 Season 2
Escore Tournament S2: W5
KK 2v2 League Season 1
StarCraft2 Community Team League 2026 Spring
2026 GSL S1
BLAST Rivals Spring 2026
IEM Rio 2026
PGL Bucharest 2026
Stake Ranked Episode 1
BLAST Open Spring 2026
ESL Pro League S23 Finals
ESL Pro League S23 Stage 1&2
PGL Cluj-Napoca 2026

Upcoming

Acropolis #4
BSL 22 Non-Korean Championship
CSLAN 4
Kung Fu Cup 2026 Grand Finals
HSC XXIX
uThermal 2v2 2026 Main Event
Maestros of the Game 2
2026 GSL S2
RSL Revival: Season 5
XSE Pro League 2026
IEM Cologne Major 2026
Stake Ranked Episode 2
CS Asia Championships 2026
Asian Champions League 2026
IEM Atlanta 2026
PGL Astana 2026
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2026 TLnet. All Rights Reserved.