• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 08:13
CET 13:13
KST 21:13
  • 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
Intel X Team Liquid Seoul event: Showmatches and Meet the Pros9[ASL20] Finals Preview: Arrival13TL.net Map Contest #21: Voting10[ASL20] Ro4 Preview: Descent11Team TLMC #5: Winners Announced!3
Community News
Weekly Cups (Oct 20-26): MaxPax, Clem, Creator win52025 RSL Offline Finals Dates + Ticket Sales!10BSL21 Open Qualifiers Week & CONFIRM PARTICIPATION1Crank Gathers Season 2: SC II Pro Teams10Merivale 8 Open - LAN - Stellar Fest4
StarCraft 2
General
RotterdaM "Serral is the GOAT, and it's not close" Intel X Team Liquid Seoul event: Showmatches and Meet the Pros Weekly Cups (Oct 20-26): MaxPax, Clem, Creator win Weekly Cups (Oct 13-19): Clem Goes for Four DreamHack Open 2013 revealed
Tourneys
Kirktown Chat Brawl #9 $50 8:30PM EST 2025 RSL Offline Finals Dates + Ticket Sales! SC4ALL $6,000 Open LAN in Philadelphia Merivale 8 Open - LAN - Stellar Fest Crank Gathers Season 2: SC II Pro Teams
Strategy
Custom Maps
Map Editor closed ?
External Content
Mutation # 497 Battle Haredened Mutation # 496 Endless Infection Mutation # 495 Rest In Peace Mutation # 494 Unstable Environment
Brood War
General
Ladder Map Matchup Stats Map pack for 3v3/4v4/FFA games BW General Discussion SnOw's ASL S20 Finals Review [ASL20] Ask the mapmakers — Drop your questions
Tourneys
[ASL20] Grand Finals Small VOD Thread 2.0 The Casual Games of the Week Thread BSL21 Open Qualifiers Week & CONFIRM PARTICIPATION
Strategy
PvZ map balance Current Meta How to stay on top of macro? Soma's 9 hatch build from ASL Game 2
Other Games
General Games
Path of Exile Dawn of War IV Beyond All Reason Stormgate/Frost Giant Megathread General RTS Discussion Thread
Dota 2
Official 'what is Dota anymore' discussion LiquidDota to reintegrate into TL.net
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
TL Mafia Community Thread SPIRED by.ASL Mafia {211640}
Community
General
Russo-Ukrainian War Thread US Politics Mega-thread Things Aren’t Peaceful in Palestine The Big Programming Thread YouTube Thread
Fan Clubs
White-Ra Fan Club The herO Fan Club!
Media & Entertainment
Anime Discussion Thread Movie Discussion! [Manga] One Piece Korean Music Discussion Series you have seen recently...
Sports
TeamLiquid Health and Fitness Initiative For 2023 Formula 1 Discussion MLB/Baseball 2023 2024 - 2026 Football Thread NBA General Discussion
World Cup 2022
Tech Support
SC2 Client Relocalization [Change SC2 Language] Linksys AE2500 USB WIFI keeps disconnecting Computer Build, Upgrade & Buying Resource Thread
TL Community
The Automated Ban List Recent Gifted Posts
Blogs
Career Paths and Skills for …
TrAiDoS
KPDH "Golden" as Squid Game…
Peanutsc
Reality "theory" prov…
perfectspheres
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1236 users

Want to program video games? - Page 7

Blogs > CecilSunkure
Post a Reply
Prev 1 5 6 7 8 9 10 Next All
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
December 02 2011 21:48 GMT
#121
On December 03 2011 06:32 Fandango wrote:
Show nested quote +
On December 03 2011 05:46 CecilSunkure wrote:
You actually do learn to code in Assembly here at DigiPen, in order to appreciate and understand C better. Then by extension, do the same with C to C++. It's fine if you disagree, though you're argument is kinda lacking against mine.


You haven't argued anything at all, you've literally just said that this is the way it is without any justification, I provided reasoning behind why that approach is flawed and you didn't refute any of it and again just assumed you're right. There's really no reason to continue to argue with you either because you seem to think you know everything about game development when you're still at college and apparently not that far along from your outlook. I'm not suggesting that my outlook is definitively the best or anything i'm just saying that your approach to learning is flawed because you don't really know what you're arguing.

Sorry I should clarify. By "mine" I meant what I've been taught here. I'm merely quoting people more experienced that me that tell me these things. For example the guy in the podcast in the OP, he's a huge proponent of the philosophy I've cited. I understand what you are saying and why you are saying it, but I just disagree since I trust these people here more than you. Sorry for being a bit unclear on "the argument", as again it isn't mine, just one I trust.
Bey
Profile Joined May 2010
United States78 Posts
Last Edited: 2011-12-02 21:56:42
December 02 2011 21:56 GMT
#122
I've got a bachelor's in CS and have been working in software development for three years now. I do some kernel-mode and some user-mode system stuff - while I'm not on the bare-bones hardware like many of my colleagues, I'm closer than you would need to get for modern game development.

Don't worry about C. There are a lot of things that are bad about C and a lot of practices you'll pick up from starting in C that'll you'll need to unlearn when you move on to more mature languages. There's a reason we don't write software using the same tools that were used in the 1970's and that's because there are a lot of better tools out there today.

Skip C. It's not like a prerequisite, like C is your 101 level class that you have to take before the 102 of C++. It's not like C is arithmetic and C++ is calculus. It's not part of some progression you need to follow. C is different. It's old. There are a lot of ways to do C wrong and only a few ways to do it right. While there are some limited scenarios where it's the proper tool for the job, those are few and far between. And OOP is important. Start learning how to think that way now. When you're learning to be an architect, you don't start designing your first building to be built without hammers. Don't do the same when you're learning to be a developer.

C++ still gives you all the cool ways to shoot yourself in the foot and waste your weekends that C does. It has enough low-level power to prime you for that world but enough high-level expressiveness to get you used to working in that world as well. And if there ever comes a time when you need to fall back and learn C, your exposure to C++ is going to make that easy.

Sure there will be classes which require you to do some ASM and some C and whatever, and that's fine. It's good to have exposure. OCAML was cool to learn in school but fuck if I can even imagine what I'd do with it now. But on your personal projects, the stuff where you get to call the shots and where you get to really pour your heart and soul into it, don't take on this needless restriction of doing C first. For most purposes, C++ offers a *better* way to solve problems and one that your future employers are going to expect you to understand.

TL;DR: There are *drawbacks* to C. It's not a right of passage... in many cases, C is just wrong . Skip it!
Do it. Do it right. Do it right now.
Fandango
Profile Joined October 2011
291 Posts
Last Edited: 2011-12-02 22:04:20
December 02 2011 22:01 GMT
#123
On December 03 2011 06:48 CecilSunkure wrote:
Show nested quote +
On December 03 2011 06:32 Fandango wrote:
On December 03 2011 05:46 CecilSunkure wrote:
You actually do learn to code in Assembly here at DigiPen, in order to appreciate and understand C better. Then by extension, do the same with C to C++. It's fine if you disagree, though you're argument is kinda lacking against mine.


You haven't argued anything at all, you've literally just said that this is the way it is without any justification, I provided reasoning behind why that approach is flawed and you didn't refute any of it and again just assumed you're right. There's really no reason to continue to argue with you either because you seem to think you know everything about game development when you're still at college and apparently not that far along from your outlook. I'm not suggesting that my outlook is definitively the best or anything i'm just saying that your approach to learning is flawed because you don't really know what you're arguing.

Sorry I should clarify. By "mine" I meant what I've been taught here. I'm merely quoting people more experienced that me that tell me these things. For example the guy in the podcast in the OP, he's a huge proponent of the philosophy I've cited. I understand what you are saying and why you are saying it, but I just disagree since I trust these people here more than you. Sorry for being a bit unclear on "the argument", as again it isn't mine, just one I trust.


You should be aware that he's only referring to the studios that stick to the old model of physical media and consoles releases and so on, what i'm referring to is the other side of the industry that makes web games, mobile games (including but not limited to iPhone/Android) and other contracted works where ultra high performance is needed. It's a whole different kettle of fish and there's even parts of big studios that focus on small projects that operate in the same manner and hire the same people. You should always be wary of anyone telling you that the industry is like this or this, it's almost always all of the above it's just whoever is saying it hasn't necessarily been exposed to that side of things.

I've worked at a big studio, ran a small studio that was based on contract work and been to quite a few developer conferences and depending on who you talk to, everyone is wrong and everyone is right. As a student you should just look what you want to do and go about doing that, for you it sounds like big studio development and you're on the right path for that so great. I'd also like to add that at no point am I condoning not learning anything you want to learn about just what is considered a requirement. Although i'd still skip C because it's not going to be relevant to anything but embedded systems programming and unless you want to work on robots or custom peripheral hardware it's probably a waste of time.

edit: Listen to the dude above too he's a cool cat
repomaniak
Profile Joined January 2009
Poland324 Posts
Last Edited: 2011-12-02 22:21:09
December 02 2011 22:14 GMT
#124
http://en.wikipedia.org/wiki/Klik

games factory and other similar - easier way to make your own game without coding

http://www.newgrounds.com/wiki/creator-resources/game-dev-resources/the-games-factory-2

you can create games in flash and upload them into newgrounds - its kind of demo version working only on newgrounds. full version is not cheap
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
Last Edited: 2011-12-02 22:28:18
December 02 2011 22:27 GMT
#125
On December 03 2011 07:01 Fandango wrote:
Show nested quote +
On December 03 2011 06:48 CecilSunkure wrote:
On December 03 2011 06:32 Fandango wrote:
On December 03 2011 05:46 CecilSunkure wrote:
You actually do learn to code in Assembly here at DigiPen, in order to appreciate and understand C better. Then by extension, do the same with C to C++. It's fine if you disagree, though you're argument is kinda lacking against mine.


You haven't argued anything at all, you've literally just said that this is the way it is without any justification, I provided reasoning behind why that approach is flawed and you didn't refute any of it and again just assumed you're right. There's really no reason to continue to argue with you either because you seem to think you know everything about game development when you're still at college and apparently not that far along from your outlook. I'm not suggesting that my outlook is definitively the best or anything i'm just saying that your approach to learning is flawed because you don't really know what you're arguing.

Sorry I should clarify. By "mine" I meant what I've been taught here. I'm merely quoting people more experienced that me that tell me these things. For example the guy in the podcast in the OP, he's a huge proponent of the philosophy I've cited. I understand what you are saying and why you are saying it, but I just disagree since I trust these people here more than you. Sorry for being a bit unclear on "the argument", as again it isn't mine, just one I trust.


You should be aware that he's only referring to the studios that stick to the old model of physical media and consoles releases and so on, what i'm referring to is the other side of the industry that makes web games, mobile games (including but not limited to iPhone/Android) and other contracted works where ultra high performance is needed. It's a whole different kettle of fish and there's even parts of big studios that focus on small projects that operate in the same manner and hire the same people. You should always be wary of anyone telling you that the industry is like this or this, it's almost always all of the above it's just whoever is saying it hasn't necessarily been exposed to that side of things.

I've worked at a big studio, ran a small studio that was based on contract work and been to quite a few developer conferences and depending on who you talk to, everyone is wrong and everyone is right. As a student you should just look what you want to do and go about doing that, for you it sounds like big studio development and you're on the right path for that so great. I'd also like to add that at no point am I condoning not learning anything you want to learn about just what is considered a requirement. Although i'd still skip C because it's not going to be relevant to anything but embedded systems programming and unless you want to work on robots or custom peripheral hardware it's probably a waste of time.

edit: Listen to the dude above too he's a cool cat

Yeah I understand. In the podcast he even himself says that if you're just interested in Flash development that strong foundation in C/C++ isn't really necessary. Nothing was said on mobile development though. From people I've heard talk it sounds like heavy optimization is important in mobile development as well due to limited hardware power. It's just a matter of goals of the target audience.
Fandango
Profile Joined October 2011
291 Posts
December 02 2011 22:36 GMT
#126
On December 03 2011 07:27 CecilSunkure wrote:
Show nested quote +
On December 03 2011 07:01 Fandango wrote:
On December 03 2011 06:48 CecilSunkure wrote:
On December 03 2011 06:32 Fandango wrote:
On December 03 2011 05:46 CecilSunkure wrote:
You actually do learn to code in Assembly here at DigiPen, in order to appreciate and understand C better. Then by extension, do the same with C to C++. It's fine if you disagree, though you're argument is kinda lacking against mine.


You haven't argued anything at all, you've literally just said that this is the way it is without any justification, I provided reasoning behind why that approach is flawed and you didn't refute any of it and again just assumed you're right. There's really no reason to continue to argue with you either because you seem to think you know everything about game development when you're still at college and apparently not that far along from your outlook. I'm not suggesting that my outlook is definitively the best or anything i'm just saying that your approach to learning is flawed because you don't really know what you're arguing.

Sorry I should clarify. By "mine" I meant what I've been taught here. I'm merely quoting people more experienced that me that tell me these things. For example the guy in the podcast in the OP, he's a huge proponent of the philosophy I've cited. I understand what you are saying and why you are saying it, but I just disagree since I trust these people here more than you. Sorry for being a bit unclear on "the argument", as again it isn't mine, just one I trust.


You should be aware that he's only referring to the studios that stick to the old model of physical media and consoles releases and so on, what i'm referring to is the other side of the industry that makes web games, mobile games (including but not limited to iPhone/Android) and other contracted works where ultra high performance is needed. It's a whole different kettle of fish and there's even parts of big studios that focus on small projects that operate in the same manner and hire the same people. You should always be wary of anyone telling you that the industry is like this or this, it's almost always all of the above it's just whoever is saying it hasn't necessarily been exposed to that side of things.

I've worked at a big studio, ran a small studio that was based on contract work and been to quite a few developer conferences and depending on who you talk to, everyone is wrong and everyone is right. As a student you should just look what you want to do and go about doing that, for you it sounds like big studio development and you're on the right path for that so great. I'd also like to add that at no point am I condoning not learning anything you want to learn about just what is considered a requirement. Although i'd still skip C because it's not going to be relevant to anything but embedded systems programming and unless you want to work on robots or custom peripheral hardware it's probably a waste of time.

edit: Listen to the dude above too he's a cool cat

Yeah I understand. In the podcast he even himself says that if you're just interested in Flash development that strong foundation in C/C++ isn't really necessary. Nothing was said on mobile development though. From people I've heard talk it sounds like heavy optimization is important in mobile development as well due to limited hardware power. It's just a matter of goals of the target audience.


Well the issue with mobile development for iPhone and Android (and I believe the old Samsung OS that failed), is that they don't allow you to program in C++ properly anyway, it's either Obj-C or Java. Optimising is far far far far far more down to code design than language speed anyway, compilers (including the JIT ones used in C# or Java) are very good at optimising these days. The biggest thing is always going to be how you've programmed it, removing unnecessary loops, avoiding costly operations and so on. Hardcore optimisations that rely on language speed differences or knowing how to use the different programming caches are like the last resort that rarely need to be done outside of engine development.
Jaeger
Profile Joined December 2009
United States1150 Posts
December 02 2011 23:08 GMT
#127
On December 03 2011 06:27 Fandango wrote:
You're talking about big studio development, precisely the opposite of what I'm referencing and precisely where C++ is treasured.


On December 03 2011 04:22 Fandango wrote:
Knowing C++ is great and all and it's good to have on a resume and so on, but if you want to work on actual gameplay development these days, even at the largest of studios, it's going to be in an interpreted language.
https://www.dotabuff.com/players/8137911
Fandango
Profile Joined October 2011
291 Posts
December 02 2011 23:28 GMT
#128
Yeah in retrospect that was a dumb thing to say, it's probably the majority of gameplay development these days but when UnrealScript is so poor compared to working with full source for UE, that's going to take up a lot of people so i'm not sure if that's true. There's definitely been a huge shift towards fast scripting languages for full engine middleware though, from Gamebryo (glad that's gone) to Unity to Blitztech and so on. It's not like the Id tech based approaches have done well in the last decade or so as middleware though, both Source and IdTech4 are really short on licensed titles. Plus if you were seriously doing the majority of gameplay programming in C++ I can't imagine how Rage ever got finished with all that compile time.

I mean you didn't address any of the other points though so I guess you agree with me on those?
SeeDLiNg
Profile Joined January 2010
United States690 Posts
December 02 2011 23:32 GMT
#129
Thank you so much for posting this
Phrost
Profile Blog Joined May 2010
United States4008 Posts
December 03 2011 00:21 GMT
#130
On December 02 2011 23:26 BisuDagger wrote:
I'm a video game developer, woot! Great article, glad your trying to get more people interested. It's a wonderful field to be in. Anyone who needs help or has questions about getting started feel free to pm me.

Btw, this article reminded me of when I wrote my first Gameboy Advanced game which was, oh so much fun :/


Who let you out of your hole?


Also about the whole c/c++/c#/cwhatever argument, if you learn the lowest level it will help you greater to understand the higher levels. The curriculum at my school (Full Sail in Florida) starts off with the most basic things and slowly works its way up so that you learn the "hard" way and the "easy" or convenient way to do things.

For example, we learned how to store data in a fixed size array, then a dynamic array, then how to use the STL vector. Each getting progressively easier to use but the knowledge of the previous helps a lot.

With the array knowledge we were able to learn how to construct basic strings before learning the STL string class.

I would highly suggest starting as low as possible and working your way up.
iamphrost.tumblr.com // http://howtobebettermagicplayer.tumblr.com // twitter @phrost_
RayGay
Profile Joined December 2011
1 Post
December 03 2011 00:36 GMT
#131
I think that this is just a list of things that you like to do because you think you're good at programming, AKA you're showing off.
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
December 03 2011 00:40 GMT
#132
On December 03 2011 09:36 RayGay wrote:
I think that this is just a list of things that you like to do because you think you're good at programming, AKA you're showing off.

Then don't read it. No need to make a new account just to tell me that
Jaeger
Profile Joined December 2009
United States1150 Posts
December 03 2011 01:10 GMT
#133
On December 03 2011 08:28 Fandango wrote:
Yeah in retrospect that was a dumb thing to say, it's probably the majority of gameplay development these days but when UnrealScript is so poor compared to working with full source for UE, that's going to take up a lot of people so i'm not sure if that's true. There's definitely been a huge shift towards fast scripting languages for full engine middleware though, from Gamebryo (glad that's gone) to Unity to Blitztech and so on. It's not like the Id tech based approaches have done well in the last decade or so as middleware though, both Source and IdTech4 are really short on licensed titles. Plus if you were seriously doing the majority of gameplay programming in C++ I can't imagine how Rage ever got finished with all that compile time.

I mean you didn't address any of the other points though so I guess you agree with me on those?


Not necessarily I mostly just have work to do so I have to pick my battles .

To address a few more of your points:

I will agree that the most important things are language agnostic. For example solid OO design, task driven parallelism, algorithms, data structures, agile process.

I will still contend that you need to have a solid understanding of what your code actually does. This includes having a solid understanding of the target machine architecture and at least a working understanding of any language your code is compiled down to (IL, x86, ARM, etc). Knowing what the high level code you're writing is actually doing is important even in high level garbage collected managed languages. And while you don't need to always think about what your code is doing at the hardware level, being able to do that analysis makes you a more valuable coder and will subconsciously lead you towards better design.

The ability to learn new things quickly is important but somewhat misleading. Really it's the ability to apply existing knowledge to new circumstances.

Compile time is not an issue if you architect your code properly. Make use of components in separately compiled libraries and compilation firewalls. In lieu of good architecture you can always just throw money at the problem and use IncrediBuild.
https://www.dotabuff.com/players/8137911
iplayBANJO
Profile Joined September 2010
United States129 Posts
December 03 2011 01:27 GMT
#134
On December 03 2011 09:21 Phrost wrote:
Also about the whole c/c++/c#/cwhatever argument, if you learn the lowest level it will help you greater to understand the higher levels. The curriculum at my school (Full Sail in Florida) starts off with the most basic things and slowly works its way up so that you learn the "hard" way and the "easy" or convenient way to do things.

For example, we learned how to store data in a fixed size array, then a dynamic array, then how to use the STL vector. Each getting progressively easier to use but the knowledge of the previous helps a lot.


That's always what bothered me about the CS major, which I am still working on. It seems like every time you struggle through some difficult class you're told at the end to not worry about how hard it was, you'll probably never have to do anything like that again. Then you move on to another class that ends with a similar process. It's kind of disheartening, especially since I love the C and assembly that I have done, and I feel like I thrive off of all the frustrating bit twiddling that I get sucked into all the time.
"So you think you know stuff about things? Well, I will see your stuff about things, and raise you things about stuff."
Umpteen
Profile Blog Joined April 2010
United Kingdom1570 Posts
December 03 2011 01:42 GMT
#135
On December 03 2011 09:36 RayGay wrote:
I think that this is just a list of things that you like to do because you think you're good at programming, AKA you're showing off.


... and you're doing what, here?

Irony: kind of like iron.
The existence of a food chain is inescapable if we evolved unsupervised, and inexcusable otherwise.
Fandango
Profile Joined October 2011
291 Posts
December 03 2011 02:04 GMT
#136
On December 03 2011 10:10 Jaeger wrote:
Show nested quote +
On December 03 2011 08:28 Fandango wrote:
Yeah in retrospect that was a dumb thing to say, it's probably the majority of gameplay development these days but when UnrealScript is so poor compared to working with full source for UE, that's going to take up a lot of people so i'm not sure if that's true. There's definitely been a huge shift towards fast scripting languages for full engine middleware though, from Gamebryo (glad that's gone) to Unity to Blitztech and so on. It's not like the Id tech based approaches have done well in the last decade or so as middleware though, both Source and IdTech4 are really short on licensed titles. Plus if you were seriously doing the majority of gameplay programming in C++ I can't imagine how Rage ever got finished with all that compile time.

I mean you didn't address any of the other points though so I guess you agree with me on those?


Not necessarily I mostly just have work to do so I have to pick my battles .

To address a few more of your points:

I will agree that the most important things are language agnostic. For example solid OO design, task driven parallelism, algorithms, data structures, agile process.

I will still contend that you need to have a solid understanding of what your code actually does. This includes having a solid understanding of the target machine architecture and at least a working understanding of any language your code is compiled down to (IL, x86, ARM, etc). Knowing what the high level code you're writing is actually doing is important even in high level garbage collected managed languages. And while you don't need to always think about what your code is doing at the hardware level, being able to do that analysis makes you a more valuable coder and will subconsciously lead you towards better design.

The ability to learn new things quickly is important but somewhat misleading. Really it's the ability to apply existing knowledge to new circumstances.

Compile time is not an issue if you architect your code properly. Make use of components in separately compiled libraries and compilation firewalls. In lieu of good architecture you can always just throw money at the problem and use IncrediBuild.



My issue with the assembly/hardware architecture thing isn't that it isn't worthwhile or isn't valuable to know, it's that utility of that information when you're writing flash games or android games or really anything that's expected to run in a VM on a huge range of hardware setups is pretty minimal. Given the generally unspecialised nature of the work you'd be more efficient at what you do by learning how to do a wide range of game elements from physics engines to GUI systems to general good code architecture.

On the apply existing knowledge thing you're right that's a better way to put it and the above knowledge will certainly help with that. I keep wanting to say that C++ will inherently teach you most of the things you'll need to know but i'm wary since I did computer science so who knows what I take for granted.
Soan
Profile Blog Joined August 2010
New Zealand194 Posts
December 03 2011 02:30 GMT
#137
Nice post, I actually just finished a 32 week diploma here at Media Design School in NZ that focused on game programming. I loved it, and would recommend the school to anyone in NZ or even in the general oceanic area that wants to do game dev stuff (either programming or art, you'll see why in a second), as the school is great. I'm actually going back next year to do the graduate diploma of game dev, where they mix programmers and artists together for some portions of the course, and all end up working together in teams a six month game project.

On my course, they assume you have no previous programming knowledge, and start teaching C++ from scratch. Our first assignment was actually a text based battleships. From there, we moved onto the Windows GDI and made some sprite games. Before we moved onto DirectX, they actually taught us how to do all the 3D maths, matrix transformations and projections etc manually, supposedly so we'd have a better understanding of the pipeline, but I have no idea if that helped.

We actually ended with an 8 week team project, where we designed and then built a 3D game from scratch. Our class ended up with a Wipeout clone(my team), a Plants vs Zombies clone, and a more traditional tower defense game.

For me personally, I'm definitly going to use the break to work on some stuff before going back. Given that alot of the studios locally here, both game and non-game seem to be mobile/web focused, going to be looking at creating a mobile game or two. Also plan on fixing our collision detection based assignment (a pool game!), as I screwed it up.
Jaeger
Profile Joined December 2009
United States1150 Posts
Last Edited: 2011-12-03 02:41:52
December 03 2011 02:40 GMT
#138
On December 03 2011 11:04 Fandango wrote:
Show nested quote +
On December 03 2011 10:10 Jaeger wrote:
On December 03 2011 08:28 Fandango wrote:
Yeah in retrospect that was a dumb thing to say, it's probably the majority of gameplay development these days but when UnrealScript is so poor compared to working with full source for UE, that's going to take up a lot of people so i'm not sure if that's true. There's definitely been a huge shift towards fast scripting languages for full engine middleware though, from Gamebryo (glad that's gone) to Unity to Blitztech and so on. It's not like the Id tech based approaches have done well in the last decade or so as middleware though, both Source and IdTech4 are really short on licensed titles. Plus if you were seriously doing the majority of gameplay programming in C++ I can't imagine how Rage ever got finished with all that compile time.

I mean you didn't address any of the other points though so I guess you agree with me on those?


Not necessarily I mostly just have work to do so I have to pick my battles .

To address a few more of your points:

I will agree that the most important things are language agnostic. For example solid OO design, task driven parallelism, algorithms, data structures, agile process.

I will still contend that you need to have a solid understanding of what your code actually does. This includes having a solid understanding of the target machine architecture and at least a working understanding of any language your code is compiled down to (IL, x86, ARM, etc). Knowing what the high level code you're writing is actually doing is important even in high level garbage collected managed languages. And while you don't need to always think about what your code is doing at the hardware level, being able to do that analysis makes you a more valuable coder and will subconsciously lead you towards better design.

The ability to learn new things quickly is important but somewhat misleading. Really it's the ability to apply existing knowledge to new circumstances.

Compile time is not an issue if you architect your code properly. Make use of components in separately compiled libraries and compilation firewalls. In lieu of good architecture you can always just throw money at the problem and use IncrediBuild.



My issue with the assembly/hardware architecture thing isn't that it isn't worthwhile or isn't valuable to know, it's that utility of that information when you're writing flash games or android games or really anything that's expected to run in a VM on a huge range of hardware setups is pretty minimal. Given the generally unspecialised nature of the work you'd be more efficient at what you do by learning how to do a wide range of game elements from physics engines to GUI systems to general good code architecture.

On the apply existing knowledge thing you're right that's a better way to put it and the above knowledge will certainly help with that. I keep wanting to say that C++ will inherently teach you most of the things you'll need to know but i'm wary since I did computer science so who knows what I take for granted.


FWIW I just finished working on a Flash game for facebook using AS3, PHP and Javascript and I'm currently working on an iOS game using C# in Unity so it's not like I don't have perspective on the kinds of projects you're talking about.

I find that knowledge valuable and very useful.
https://www.dotabuff.com/players/8137911
sluggaslamoo
Profile Blog Joined November 2009
Australia4494 Posts
Last Edited: 2011-12-03 02:52:07
December 03 2011 02:48 GMT
#139
C++ is a terrible language (even compared to C), but it is absolutely necessary if you want to work for a large games studio.

Knowing C will hardly help when it comes to C++ either, it is completely different, only that C++ is backwards compatible with C, so you can write C and claim you are doing C++ . The only areas C will help is with learning basic programming concepts like functional decomposition and memory management, after that, everything is different.

Its also important that you know assembly language, as with working with huge games, it is vital for debugging.

I originally wanted to become a games programmer. Although I know C++ as well as a ton of other languages, I won't be doing games programming simply because I hate C++ . I worked on phone and facebook games for a while in Obj-C and Ruby (I love Ruby!) but everyone was really stressed out and I didn't like working there.


On December 03 2011 04:05 iPAndi wrote:
By the way, im wondering why don't you use something like Microsoft Visual C++ to learn C++ coding instead of DevC++? I mean, dont get me wrong, i loved devc++, but i think Microsoft has such an awesome tool its not even worth digging into devcpp.


Windows is a terrible platform for doing Dev work. I love working on Linux, and its so easy and quick to set up and isolate dev environments. Mac is ok simply because of Bash, but apart from that, its still Windows as far as developing is concerned. I do all my dev work in Xmonad, I am 100x more productive in a tiling window manager, than a crappy point and click one.
Come play Android Netrunner - http://www.teamliquid.net/forum/viewmessage.php?topic_id=409008
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
December 03 2011 02:52 GMT
#140
On December 03 2011 11:48 sluggaslamoo wrote:
Knowing C will hardly help when it comes to C++... it is completely different...

The whole point of learning C, according to the professionals at my school, is that it is different from C++.
Prev 1 5 6 7 8 9 10 Next All
Please log in or register to reply.
Live Events Refresh
Epic.LAN
12:00
Epic.LAN 46 Playoffs Stage
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
Reynor 523
Rex 89
BRAT_OK 82
Lowko24
StarCraft: Brood War
Hyuk 1534
PianO 737
Barracks 372
Last 329
zelot 37
ToSsGirL 28
Terrorterran 18
HiyA 16
Shine 8
Dota 2
XcaliburYe632
ODPixel586
canceldota176
Counter-Strike
PGG 127
Other Games
singsing1492
B2W.Neo1150
DeMusliM288
Hui .163
Mew2King47
Organizations
Counter-Strike
PGL10457
Other Games
gamesdonequick768
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 16 non-featured ]
StarCraft 2
• LUISG 37
• Gemini_19 24
• Adnapsc2 2
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
Dota 2
• Ler56
League of Legends
• Jankos3310
Other Games
• WagamamaTV194
Upcoming Events
BSL Team A[vengers]
1h 47m
Dewalt vs ZeLoT
UltrA vs ZeLoT
SC4ALL
1h 47m
SC4ALL
1h 47m
BSL 21
6h 47m
BSL Team A[vengers]
1d 1h
Cross vs Sobenz
Sziky vs IcaruS
SC4ALL
1d 2h
SC4ALL
1d 2h
BSL 21
1d 6h
Replay Cast
1d 20h
Wardi Open
1d 23h
[ Show More ]
Monday Night Weeklies
2 days
Replay Cast
2 days
Sparkling Tuna Cup
2 days
WardiTV Korean Royale
2 days
Replay Cast
3 days
WardiTV Korean Royale
3 days
The PondCast
4 days
Korean StarCraft League
6 days
CranKy Ducklings
6 days
Liquipedia Results

Completed

CSL 2025 AUTUMN (S18)
CranK Gathers Season 2: SC II Pro Teams
Eternal Conflict S1

Ongoing

BSL 21 Points
BSL 21 Team A
C-Race Season 1
IPSL Winter 2025-26
KCM Race Survival 2025 Season 4
SOOP Univ League 2025
SC4ALL: Brood War
SC4ALL: StarCraft II
PGL Masters Bucharest 2025
Thunderpick World Champ.
CS Asia Championships 2025
ESL Pro League S22
StarSeries Fall 2025
FISSURE Playground #2
BLAST Open Fall 2025
BLAST Open Fall Qual
Esports World Cup 2025

Upcoming

YSL S2
BSL Season 21
SLON Tour Season 2
BSL 21 Non-Korean Championship
RSL Offline Finals
WardiTV 2025
RSL Revival: Season 3
Stellar Fest
META Madness #9
BLAST Bounty Winter 2026: Closed Qualifier
eXTREMESLAND 2025
ESL Impact League Season 8
SL Budapest Major 2025
BLAST Rivals Fall 2025
IEM Chengdu 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.