• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EST 11:57
CET 17:57
KST 01:57
  • 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
RSL Season 3 - Playoffs Preview0RSL Season 3 - RO16 Groups C & D Preview0RSL Season 3 - RO16 Groups A & B Preview2TL.net Map Contest #21: Winners12Intel X Team Liquid Seoul event: Showmatches and Meet the Pros10
Community News
Weekly Cups (Nov 24-30): MaxPax, Clem, herO win2BGE Stara Zagora 2026 announced15[BSL21] Ro.16 Group Stage (C->B->A->D)4Weekly Cups (Nov 17-23): Solar, MaxPax, Clem win3RSL Season 3: RO16 results & RO8 bracket13
StarCraft 2
General
Chinese SC2 server to reopen; live all-star event in Hangzhou Maestros of the Game: Live Finals Preview (RO4) BGE Stara Zagora 2026 announced Weekly Cups (Nov 24-30): MaxPax, Clem, herO win SC2 Proleague Discontinued; SKT, KT, SGK, CJ disband
Tourneys
Sparkling Tuna Cup - Weekly Open Tournament RSL Offline Finals Info - Dec 13 and 14! StarCraft Evolution League (SC Evo Biweekly) RSL Offline FInals Sea Duckling Open (Global, Bronze-Diamond)
Strategy
Custom Maps
Map Editor closed ?
External Content
Mutation # 502 Negative Reinforcement Mutation # 501 Price of Progress Mutation # 500 Fright night Mutation # 499 Chilling Adaptation
Brood War
General
BW General Discussion Which season is the best in ASL? Data analysis on 70 million replays BGH Auto Balance -> http://bghmmr.eu/ [ASL20] Ask the mapmakers — Drop your questions
Tourneys
[Megathread] Daily Proleagues [BSL21] RO16 Group D - Sunday 21:00 CET [BSL21] RO16 Group A - Saturday 21:00 CET [BSL21] RO16 Group B - Sunday 21:00 CET
Strategy
Current Meta Game Theory for Starcraft How to stay on top of macro? PvZ map balance
Other Games
General Games
Stormgate/Frost Giant Megathread ZeroSpace Megathread Nintendo Switch Thread The Perfect Game Path of Exile
Dota 2
Official 'what is Dota anymore' discussion
League of Legends
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
Mafia Game Mode Feedback/Ideas TL Mafia Community Thread
Community
General
US Politics Mega-thread Russo-Ukrainian War Thread Things Aren’t Peaceful in Palestine The Big Programming Thread Artificial Intelligence Thread
Fan Clubs
White-Ra Fan Club
Media & Entertainment
[Manga] One Piece Movie Discussion! Anime Discussion Thread
Sports
2024 - 2026 Football Thread Formula 1 Discussion NBA General Discussion
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
Where to ask questions and add stream? The Automated Ban List
Blogs
Physical Exertion During Gam…
TrAiDoS
James Bond movies ranking - pa…
Topin
Thanks for the RSL
Hildegard
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1352 users

The Big Programming Thread - Page 276

Forum Index > General Forum
Post a Reply
Prev 1 274 275 276 277 278 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.
aurum510
Profile Joined July 2010
United States229 Posts
March 21 2013 17:53 GMT
#5501
On March 22 2013 02:48 Kambing wrote:
Show nested quote +
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!
Kambing
Profile Joined May 2010
United States1176 Posts
March 21 2013 18:31 GMT
#5502
On March 22 2013 02:53 aurum510 wrote:
Show nested quote +
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 21 2013 19:03 GMT
#5503
On March 22 2013 02:41 Kambing wrote:
Show nested quote +
On March 22 2013 01:53 ddengster wrote:
On March 22 2013 01:26 CecilSunkure wrote:
On March 22 2013 01:14 Tobberoth wrote:
On March 21 2013 09:04 darkness wrote:
What makes C++ so famous for game development? You don't have to describe in details.

Thanks.

I've heard tons of reasons, some of them make sense, others do not. The most classic argument is that higher level languages like C# are too slow. This argument is quite weak, careful benchmarking shows that the difference is quite small nowadays, wellwritten C++ code and wellwritten C# code will often perform very very similarly.

The best reason I've heard has to do with the fact that DirectX etc is quite hard to work with effectively from higher level languages. Other than that, C++ offers a lot of flexibility which can be nice for doing larger scale optimizations.

Two words ruin C#: garbage collection.


garbage collection(GC) with respect to bad performance or?
In my opinion, GC is still borderline ok; it frees lazy programmers from the burden of doing memory management, as long as they don't get hit with related bugs.
The reason you'd use C# is reflection and widgets for game developer tools.


More specifically, stop-the-world GC (can) ruin the soft real-time requirements of a video game (in general, any computationally intensive interactive simulation). Note that computers are powerful enough and runtime technology advanced enough this is only true of games that are pushing the boundaries of what current technology can afford. Beyond this point, you are making an engineering trade-off between the convenience of GC, the performance hit and behavior of GC on your program, and manpower optimizing your program around these constraints.

And yes, C# (and other higher-level languages) serve very well in the space of creating supporting tools for games development such as level editors, assets managers, etc.

Well the biggest thing is the lack of control. If you could just control when the GC ran it wouldn't be a big deal.
Kambing
Profile Joined May 2010
United States1176 Posts
Last Edited: 2013-03-21 19:24:32
March 21 2013 19:24 GMT
#5504
On March 22 2013 04:03 CecilSunkure wrote:
Show nested quote +
On March 22 2013 02:41 Kambing wrote:
On March 22 2013 01:53 ddengster wrote:
On March 22 2013 01:26 CecilSunkure wrote:
On March 22 2013 01:14 Tobberoth wrote:
On March 21 2013 09:04 darkness wrote:
What makes C++ so famous for game development? You don't have to describe in details.

Thanks.

I've heard tons of reasons, some of them make sense, others do not. The most classic argument is that higher level languages like C# are too slow. This argument is quite weak, careful benchmarking shows that the difference is quite small nowadays, wellwritten C++ code and wellwritten C# code will often perform very very similarly.

The best reason I've heard has to do with the fact that DirectX etc is quite hard to work with effectively from higher level languages. Other than that, C++ offers a lot of flexibility which can be nice for doing larger scale optimizations.

Two words ruin C#: garbage collection.


garbage collection(GC) with respect to bad performance or?
In my opinion, GC is still borderline ok; it frees lazy programmers from the burden of doing memory management, as long as they don't get hit with related bugs.
The reason you'd use C# is reflection and widgets for game developer tools.


More specifically, stop-the-world GC (can) ruin the soft real-time requirements of a video game (in general, any computationally intensive interactive simulation). Note that computers are powerful enough and runtime technology advanced enough this is only true of games that are pushing the boundaries of what current technology can afford. Beyond this point, you are making an engineering trade-off between the convenience of GC, the performance hit and behavior of GC on your program, and manpower optimizing your program around these constraints.

And yes, C# (and other higher-level languages) serve very well in the space of creating supporting tools for games development such as level editors, assets managers, etc.

Well the biggest thing is the lack of control. If you could just control when the GC ran it wouldn't be a big deal.


Yeah, control goes into the real-time requirement which is really the problem with GC in the cases that people think of. You can control the GC to some degree, e.g., GC.collect() to force collections. With this and some careful organization of your program, you can ensure that allocations occur only when your program can tolerate the latency. However, this requires careful consideration of the program's memory footprint and still doesn't work in all cases.
mcc
Profile Joined October 2010
Czech Republic4646 Posts
Last Edited: 2013-03-21 22:00:41
March 21 2013 21:56 GMT
#5505
On March 22 2013 01:00 AmericanUmlaut wrote:
Show nested quote +
On March 21 2013 22:03 mcc wrote:
On March 21 2013 06:17 Kambing wrote:
On March 21 2013 06:02 obesechicken13 wrote:
Do any of you have any experience with regression testing?

What should it include? Wikipedia hints that regression testing may just be a small set of tests for things that have broken in the past. But what I've always done is I've run through every single feature in the test suite. What is the best practice here?

edit: f*** nvm
http://www.testingeducation.org/k04/RegressionExamples.htm
General functional regression: We retest the product broadly, including areas that worked before, to see whether more recent changes have destabilized working code. (This is the typical scope of automated regression testing.)


Many companies have the following process: for every bug fix made to the product, a test is introduced into a test suite to ensure that the bug is never reintroduced. This test suite, made from prior bug fixes, is called a regression test suite.


That seems very narrow view of regression testing. Regression testing as we used it was supposed to make sure that new changes to the system do not introduce bugs in parts of the system that were not supposed to be affected by those changes. Basically they exist to discover side-effect bugs of new changes and also errors in analysis of the new changes.

In the case of project I worked on it was a set of tests that covered all critical functions of the system. Using just tests based on previous bugs does not seem to address the issue.

That is a fairly common way of building a regression test library, though. It has a certain compelling logic to it, too: It guarantees you'll only ever have to fix a particular problem once, and it guarantees you'll invest test-writing time in components in direct proportion to their propensity to develop bugs.

I am not saying it is bad, I just think it is somewhat incomplete. It is definitely good part of regression tests. But as Kambing pointed out later it somewhat comes down to terminology.
mcc
Profile Joined October 2010
Czech Republic4646 Posts
March 21 2013 21:59 GMT
#5506
On March 22 2013 04:03 CecilSunkure wrote:
Show nested quote +
On March 22 2013 02:41 Kambing wrote:
On March 22 2013 01:53 ddengster wrote:
On March 22 2013 01:26 CecilSunkure wrote:
On March 22 2013 01:14 Tobberoth wrote:
On March 21 2013 09:04 darkness wrote:
What makes C++ so famous for game development? You don't have to describe in details.

Thanks.

I've heard tons of reasons, some of them make sense, others do not. The most classic argument is that higher level languages like C# are too slow. This argument is quite weak, careful benchmarking shows that the difference is quite small nowadays, wellwritten C++ code and wellwritten C# code will often perform very very similarly.

The best reason I've heard has to do with the fact that DirectX etc is quite hard to work with effectively from higher level languages. Other than that, C++ offers a lot of flexibility which can be nice for doing larger scale optimizations.

Two words ruin C#: garbage collection.


garbage collection(GC) with respect to bad performance or?
In my opinion, GC is still borderline ok; it frees lazy programmers from the burden of doing memory management, as long as they don't get hit with related bugs.
The reason you'd use C# is reflection and widgets for game developer tools.


More specifically, stop-the-world GC (can) ruin the soft real-time requirements of a video game (in general, any computationally intensive interactive simulation). Note that computers are powerful enough and runtime technology advanced enough this is only true of games that are pushing the boundaries of what current technology can afford. Beyond this point, you are making an engineering trade-off between the convenience of GC, the performance hit and behavior of GC on your program, and manpower optimizing your program around these constraints.

And yes, C# (and other higher-level languages) serve very well in the space of creating supporting tools for games development such as level editors, assets managers, etc.

Well the biggest thing is the lack of control. If you could just control when the GC ran it wouldn't be a big deal.

So D is the way to go
aurum510
Profile Joined July 2010
United States229 Posts
March 22 2013 03:47 GMT
#5507
On March 22 2013 03:31 Kambing wrote:
Show nested quote +
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)


The context was meant that C# should not be used to make games (or anything that requires performance as a significant concern). Dynamic dispatch requires a lot of overhead during run-time. C++ uses only static dispatch unless specified with the virtual keyword.
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 22 2013 03:56 GMT
#5508
On March 22 2013 03:31 Kambing wrote:
Show nested quote +
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)

Could you explain this dynamic dispatch thing being the backbone?
teamamerica
Profile Blog Joined July 2010
United States958 Posts
Last Edited: 2013-03-22 04:36:49
March 22 2013 04:24 GMT
#5509
On March 22 2013 12:47 aurum510 wrote:
Show nested quote +
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)


The context was meant that C# should not be used to make games (or anything that requires performance as a significant concern). Dynamic dispatch requires a lot of overhead during run-time. C++ uses only static dispatch unless specified with the virtual keyword.


For most people who want to make indie games, why not use C#? It lets you focus on building your games story, as compared to optimizing a bunch of C++ code. I can't imagine most indie game developers are writing games that are breakneck performance. You make a tradeoff between time to finish game and performance when choosing C++ over another language imo.

edit: realize now that this was in reference to someone asking why was C++ famous for game dev. I just get tired of people going around telling someone who asks 'How do I make a game' to dive into C++, when imho they're better off starting in another language, making some games, and running into the limitations of the language themselves.

On March 22 2013 12:56 CecilSunkure wrote:
Show nested quote +
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)

Could you explain this dynamic dispatch thing being the backbone?


How else do you have polymorphism?
RIP GOMTV. RIP PROLEAGUE.
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 22 2013 04:35 GMT
#5510
On March 22 2013 13:24 teamamerica wrote:
How else do you have polymorphism?

Oh lol, I was actually thinking of double dispatch. Sorry got confused.
nunez
Profile Blog Joined February 2011
Norway4003 Posts
March 22 2013 11:53 GMT
#5511
On March 22 2013 13:24 teamamerica wrote:
Show nested quote +
On March 22 2013 12:47 aurum510 wrote:
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)


The context was meant that C# should not be used to make games (or anything that requires performance as a significant concern). Dynamic dispatch requires a lot of overhead during run-time. C++ uses only static dispatch unless specified with the virtual keyword.


For most people who want to make indie games, why not use C#? It lets you focus on building your games story, as compared to optimizing a bunch of C++ code. I can't imagine most indie game developers are writing games that are breakneck performance. You make a tradeoff between time to finish game and performance when choosing C++ over another language imo.

edit: realize now that this was in reference to someone asking why was C++ famous for game dev. I just get tired of people going around telling someone who asks 'How do I make a game' to dive into C++, when imho they're better off starting in another language, making some games, and running into the limitations of the language themselves.

Show nested quote +
On March 22 2013 12:56 CecilSunkure wrote:
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)

Could you explain this dynamic dispatch thing being the backbone?


How else do you have polymorphism?

there is static polymorphism.
conspired against by a confederacy of dunces.
Kambing
Profile Joined May 2010
United States1176 Posts
March 22 2013 13:04 GMT
#5512
On March 22 2013 12:56 CecilSunkure wrote:
Show nested quote +
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)

Could you explain this dynamic dispatch thing being the backbone?


Dynamic dispatch --- method overriding --- is typically considered the "heart" of OOP because it is the most unique and essential feature of the language paradigm. Other features of OOP can be easily emulated in other language paradigms e.g., classes as records, inheritance as (explicit) record subtyping, or are not essential, e.g., the lack of classes in prototype-based programming languages such as Javascript. However, the mechanism of dynamic dispatch are both non-trivial and present in every OO language.
Kambing
Profile Joined May 2010
United States1176 Posts
Last Edited: 2013-03-22 13:13:18
March 22 2013 13:11 GMT
#5513
On March 22 2013 12:47 aurum510 wrote:
Show nested quote +
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)


The context was meant that C# should not be used to make games (or anything that requires performance as a significant concern). Dynamic dispatch requires a lot of overhead during run-time. C++ uses only static dispatch unless specified with the virtual keyword.


C# is perfectly fine for many games that someone would like to make. For Crisis, Farcry, etc., it is likely not appropriate but that is only a tiny subset of games out there.

Dynamic dispatch does require a non-trivial performance penalty (the cost of a pointer indirection), but that isn't necessarily a prohibitive cost. And in fact, C# does the "right" thing like C++ and only has opt-in dynamic dispatch via the overrides keyword.

Besides (stop-the-world) garbage collection ruining soft real-time guarantees, the primary performance benefit that C++ provides is explicit memory layout (rather than management). In Java (and to a lesser extent, C#), you do not have direct control over how objects are laid out in memory, for example contiguously or via indirect pointers or on the stack vs. on the heap. These sorts of considerations in C++, when properly tuned, can lead to significant performance gains over higher-level languages.
aurum510
Profile Joined July 2010
United States229 Posts
Last Edited: 2013-03-22 13:32:36
March 22 2013 13:21 GMT
#5514
On March 22 2013 20:53 nunez wrote:
Show nested quote +
On March 22 2013 13:24 teamamerica wrote:
On March 22 2013 12:47 aurum510 wrote:
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)


The context was meant that C# should not be used to make games (or anything that requires performance as a significant concern). Dynamic dispatch requires a lot of overhead during run-time. C++ uses only static dispatch unless specified with the virtual keyword.


For most people who want to make indie games, why not use C#? It lets you focus on building your games story, as compared to optimizing a bunch of C++ code. I can't imagine most indie game developers are writing games that are breakneck performance. You make a tradeoff between time to finish game and performance when choosing C++ over another language imo.

edit: realize now that this was in reference to someone asking why was C++ famous for game dev. I just get tired of people going around telling someone who asks 'How do I make a game' to dive into C++, when imho they're better off starting in another language, making some games, and running into the limitations of the language themselves.

On March 22 2013 12:56 CecilSunkure wrote:
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)

Could you explain this dynamic dispatch thing being the backbone?


How else do you have polymorphism?

there is static polymorphism.


Yes! This is what makes C++ very useful for performance. You can still use OOP, but there are no run-time checks. It's very important.

[Edit]: To be fair, C# has similar abilities for only using dynamic dispatch when told to do so.
aurum510
Profile Joined July 2010
United States229 Posts
March 22 2013 13:31 GMT
#5515
On March 22 2013 22:11 Kambing wrote:
Show nested quote +
On March 22 2013 12:47 aurum510 wrote:
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)


The context was meant that C# should not be used to make games (or anything that requires performance as a significant concern). Dynamic dispatch requires a lot of overhead during run-time. C++ uses only static dispatch unless specified with the virtual keyword.


C# is perfectly fine for many games that someone would like to make. For Crisis, Farcry, etc., it is likely not appropriate but that is only a tiny subset of games out there.

Dynamic dispatch does require a non-trivial performance penalty (the cost of a pointer indirection), but that isn't necessarily a prohibitive cost. And in fact, C# does the "right" thing like C++ and only has opt-in dynamic dispatch via the overrides keyword.

Besides (stop-the-world) garbage collection ruining soft real-time guarantees, the primary performance benefit that C++ provides is explicit memory layout (rather than management). In Java (and to a lesser extent, C#), you do not have direct control over how objects are laid out in memory, for example contiguously or via indirect pointers or on the stack vs. on the heap. These sorts of considerations in C++, when properly tuned, can lead to significant performance gains over higher-level languages.


I meant more the necessary runtime checks to look up the method in the vtable (while still technically O(1), it's not nice to look something up in a hashtable, as it requires some calculations to get the hash).

But it's true that it's not very bad, as you say (specifically for games, and less for systems where performance is crucial).
Kambing
Profile Joined May 2010
United States1176 Posts
March 22 2013 13:57 GMT
#5516
On March 22 2013 22:31 aurum510 wrote:
Show nested quote +
On March 22 2013 22:11 Kambing wrote:
On March 22 2013 12:47 aurum510 wrote:
On March 22 2013 03:31 Kambing wrote:
On March 22 2013 02:53 aurum510 wrote:
On March 22 2013 02:48 Kambing wrote:
On March 22 2013 02:44 aurum510 wrote:
Two more words ruin C#: dynamic binding


Eh, dynamic dispatch? Or type dynamic?


Now that you mention it, both!


What's wrong with them? Dynamic dispatch is the backbone of object-oriented programming. If dynamic dispatch ruins C#, then you surely don't like OOP*. Type dynamic is an interoperability feature with dynamically-typed languages and only has an effect on your programs if you opt into its services.

(*To be fair, I don't like OOP either.)


The context was meant that C# should not be used to make games (or anything that requires performance as a significant concern). Dynamic dispatch requires a lot of overhead during run-time. C++ uses only static dispatch unless specified with the virtual keyword.


C# is perfectly fine for many games that someone would like to make. For Crisis, Farcry, etc., it is likely not appropriate but that is only a tiny subset of games out there.

Dynamic dispatch does require a non-trivial performance penalty (the cost of a pointer indirection), but that isn't necessarily a prohibitive cost. And in fact, C# does the "right" thing like C++ and only has opt-in dynamic dispatch via the overrides keyword.

Besides (stop-the-world) garbage collection ruining soft real-time guarantees, the primary performance benefit that C++ provides is explicit memory layout (rather than management). In Java (and to a lesser extent, C#), you do not have direct control over how objects are laid out in memory, for example contiguously or via indirect pointers or on the stack vs. on the heap. These sorts of considerations in C++, when properly tuned, can lead to significant performance gains over higher-level languages.


I meant more the necessary runtime checks to look up the method in the vtable (while still technically O(1), it's not nice to look something up in a hashtable, as it requires some calculations to get the hash).

But it's true that it's not very bad, as you say (specifically for games, and less for systems where performance is crucial).


Yeah, my pointer indirection comment is about the runtime cost of method lookup. No hashing is required for a vtable in a (traditional, receiver-based) OO language as the name of function you want to lookup at runtime is known at compile time. This amounts to compiling the method invocation down into a lookup of the vtable at the particular offset that contains the method you want.

(In the case of reflection, you do need some more complicated lookup scheme like a dictionary as you need to essentially perform the "hashing" of the function name-to-vtable entry computation at runtime.)
Recognizable
Profile Blog Joined December 2011
Netherlands1552 Posts
March 22 2013 21:09 GMT
#5517
Man. I just had a very weird experienced. I'm new to programming and I was doing this exercise on Euler and as I got stuck I sat back and looked at my code. Then it hit me. My variable names actually have meaning as in, they have meaning in the English language. When I program they lose all the meaning they had beforehand, the variable names will have become a number or a string. I can have a variable named: "Hello" and during my programming my brain doesn't register its meaning as "Hello" because it has become something entirely different. Made me question meaning, my life and everything for a moment. Then I got mad because my code wouldn't work.
heishe
Profile Blog Joined June 2009
Germany2284 Posts
March 22 2013 21:11 GMT
#5518
On March 23 2013 06:09 Recognizable wrote:
Man. I just had a very weird experienced. I'm new to programming and I was doing this exercise on Euler and as I got stuck I sat back and looked at my code. Then it hit me. My variable names actually have meaning as in, they have meaning in the English language. When I program they lose all the meaning they had beforehand, the variable names will have become a number or a string. I can have a variable named: "Hello" and during my programming my brain doesn't register its meaning as "Hello" because it has become something entirely different. Made me question meaning, my life and everything for a moment. Then I got mad because my code wouldn't work.


Just wait until you learn a functional language.
If you value your soul, never look into the eye of a horse. Your soul will forever be lost in the void of the horse.
Holy_AT
Profile Joined July 2010
Austria978 Posts
March 22 2013 21:13 GMT
#5519
On March 23 2013 06:11 heishe wrote:
Show nested quote +
On March 23 2013 06:09 Recognizable wrote:
Man. I just had a very weird experienced. I'm new to programming and I was doing this exercise on Euler and as I got stuck I sat back and looked at my code. Then it hit me. My variable names actually have meaning as in, they have meaning in the English language. When I program they lose all the meaning they had beforehand, the variable names will have become a number or a string. I can have a variable named: "Hello" and during my programming my brain doesn't register its meaning as "Hello" because it has become something entirely different. Made me question meaning, my life and everything for a moment. Then I got mad because my code wouldn't work.


Just wait until you learn a functional language.


I'd skip them and start directly with OO
tehemperorer
Profile Blog Joined June 2010
United States2183 Posts
March 22 2013 21:19 GMT
#5520
On March 23 2013 06:09 Recognizable wrote:
Man. I just had a very weird experienced. I'm new to programming and I was doing this exercise on Euler and as I got stuck I sat back and looked at my code. Then it hit me. My variable names actually have meaning as in, they have meaning in the English language. When I program they lose all the meaning they had beforehand, the variable names will have become a number or a string. I can have a variable named: "Hello" and during my programming my brain doesn't register its meaning as "Hello" because it has become something entirely different. Made me question meaning, my life and everything for a moment. Then I got mad because my code wouldn't work.

String Float = new String("true");
Knowing is half the battle... the other half is lasers.
Prev 1 274 275 276 277 278 1032 Next
Please log in or register to reply.
Live Events Refresh
OSC
16:00
OSC Elite Rising Star #17
Demi vs Mixu
Nicoract vs TBD
Babymarine vs MindelVK
ForJumy vs TBD
Shameless vs Percival
SteadfastSC66
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
Lowko449
mouzHeroMarine 282
ProTech116
SteadfastSC 66
Codebar 22
MindelVK 12
StarCraft: Brood War
Britney 23038
Calm 2226
Jaedong 1232
Shuttle 729
GuemChi 652
EffOrt 587
Soulkey 239
Rush 190
firebathero 182
BeSt 168
[ Show more ]
Larva 131
Snow 126
Sharp 106
PianO 73
Dewaltoss 66
Hyun 59
Shinee 42
yabsab 33
Mong 26
Aegong 19
Sacsri 18
soO 17
Terrorterran 13
scan(afreeca) 10
HiyA 10
SilentControl 6
JulyZerg 3
NaDa 2
Dota 2
Gorgc7862
Dendi1001
syndereN493
420jenkins271
XcaliburYe194
Counter-Strike
fl0m4259
zeus504
chrisJcsgo9
Heroes of the Storm
Khaldor149
Other Games
Grubby2443
hiko838
Mlord504
DeMusliM295
ArmadaUGS105
Mew2King82
Livibee75
QueenE58
Trikslyr45
Organizations
StarCraft 2
WardiTV902
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 14 non-featured ]
StarCraft 2
• poizon28 19
• Reevou 6
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
Dota 2
• C_a_k_e 2590
• WagamamaTV520
Upcoming Events
Replay Cast
7h 4m
Korean StarCraft League
1d 10h
CranKy Ducklings
1d 17h
WardiTV 2025
1d 19h
SC Evo League
1d 19h
BSL 21
2 days
Sziky vs OyAji
Gypsy vs eOnzErG
OSC
2 days
Solar vs Creator
ByuN vs Gerald
Percival vs Babymarine
Moja vs Krystianer
EnDerr vs ForJumy
sebesdes vs Nicoract
Sparkling Tuna Cup
2 days
WardiTV 2025
2 days
OSC
2 days
[ Show More ]
BSL 21
3 days
Bonyth vs StRyKeR
Tarson vs Dandy
Replay Cast
3 days
Wardi Open
3 days
StarCraft2.fi
3 days
Monday Night Weeklies
4 days
Replay Cast
4 days
WardiTV 2025
4 days
StarCraft2.fi
4 days
PiGosaur Monday
5 days
StarCraft2.fi
5 days
Tenacious Turtle Tussle
6 days
The PondCast
6 days
WardiTV 2025
6 days
StarCraft2.fi
6 days
Liquipedia Results

Completed

Proleague 2025-11-30
RSL Revival: Season 3
Light HT

Ongoing

C-Race Season 1
IPSL Winter 2025-26
KCM Race Survival 2025 Season 4
YSL S2
BSL Season 21
CSCL: Masked Kings S3
Slon Tour Season 2
Acropolis #4 - TS3
META Madness #9
SL Budapest Major 2025
ESL Impact League Season 8
BLAST Rivals Fall 2025
IEM Chengdu 2025
PGL Masters Bucharest 2025
Thunderpick World Champ.
CS Asia Championships 2025
ESL Pro League S22
StarSeries Fall 2025
FISSURE Playground #2

Upcoming

BSL 21 Non-Korean Championship
Acropolis #4
IPSL Spring 2026
Bellum Gens Elite Stara Zagora 2026
HSC XXVIII
RSL Offline Finals
WardiTV 2025
Kuram Kup
PGL Cluj-Napoca 2026
IEM Kraków 2026
BLAST Bounty Winter 2026
BLAST Bounty Winter Qual
eXTREMESLAND 2025
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 © 2025 TLnet. All Rights Reserved.