Advertisement

Should I learn c++ for game dev?

Started by September 25, 2015 12:15 PM
24 comments, last by Kayhen 9 years, 3 months ago


Im not really sure what they'd get out of it?

Learning C teaches a deeper understanding of pointer arithmetic, as nothing is abstracted away as standard. There is no operator overloading, no references, no string types. You are forced to learn basic data structures of computer science such as linked lists, binary trees, and how strings are represented as arrays of characters.

I'd definitely recommend it as it makes you a better C++ programmer IMHO.

As well as the above (getting rid of C++ niceties), it's a completely different paradigm than C++.

C is generally used in a procedural paradigm, whereas C++ is generally used in an OO paradigm. Programmers should also learn JavaScript to appreciate the prototype paradigm and a functional language too.

e.g. lots of people struggle to write large, manageable, flexible shader codebases in HLSL/GLSL because they're not well practiced in the procedural sytle.
C++ is multi-paradigm, so there'll be times where you'll need to write very C-style code in C++.

Back to what braindigitalis was saying though, it can be used to demonstrate a deep understanding of C++, due to it's simplicity. e.g. It's one thing to be able to use virtual function calls in C++, but it's another to be able to demonstrate how they'd be implemented in C code. If an interview candidate can past that test, then I've got a whole lot more trust that they truely understand what they're doing :)
Likewise, at the last company I worked for, they write all their game code in Lua. However, they require all the gameplay programmers to know C++, as it ensures that they'll truely understand the impact of the Lua code that they write.

For a super-technical position -- e.g. programmer in charge of the game engine, I'd probably want them to be able to read assembly code, not just C :)
Advertisement

but for most programmers, even game programmers, Im not really sure what they'd get out of it?

Classes are nothing more than a bunch of struct with function pointers and a "this" first formal parameter? smile.png

More seriously, I find that using pointers/references to design smart data structures is a quickly dying art.

I once had the problem of storing an automaton in Java. It has states and directed edges with an event name.
You must be able to walk forward and backward from state to state, over the edges (using the event name as a filter which edges to consider).
There are a LOT of states, several 100,000 at least, preferably 1,000,000 or more. Branching factor is about 3-6 (each state has only a few outgoing edges). Once created, the structure is quite stable, removal of states and edges must be possible but doesn't need to be fast. Walking over states and edges (both forward and backward) must be very fast.

Now if you solve this in normal Java or modern C++, you'll end up with a List<Edge> outgoing edges from each state, and a List<Edge> incoming edges into each state. So for each state which is otherwise empty, you have two lists. For each edge which has a pointer to the successor state and one to the predecessor state, and an event name, you add two list elements (one in the outgoing list of the predecessor state, and one in the incoming list of the successor state). For N states and M edges, you thus get 2N lists, and 2M list elements. In other words, 2/3 of the objects in memory is list administration. Since states and edges are very small, I am throwing away 2/3rd of my memory here.

(Note: Realizing this implies you understand how List<Edge> works!!)

In addition, iterating over edges to find eg successor states means you iterate over the outgoing list elements, dereference to the edge, and then use the successor pointer of the edge to find the next state. That's two dereferences for each edge traversal.

Now the C-ish variant:


struct State {
    Edge *outgoing; // Head of a single linked list to outgoing edges
    Edge *incoming; // Head of a single linked list to incoming edges
};

struct Edge {
    Event *name; // Event name

    State *successor;   // Successor state
    State *predecessor; // Predecessor state
    Edge *next_outgoing; // Single linked list to next outgoing edge of the predecessor state
    Edge *next_incoming; // Single linked list to next incoming edge of the successor state
};

I literally iterate over the edges from a state through a single linked list. I kill all List<Edge> objects, and all list elements in them, at the cost of two pointers to next edges in each Edge. This gives me almost 3 times as much space for my states and edges. I save one dereference (from list element to the edge object), making iterating twice as fast.

I would say, this are significant savings that you can achieve. Anyone who hasn't used single linked lists or double linked lists at the level of C (adding pointers in the struct himself) is never going to find such a solution.

I agree this is an extreme example and you don't need these things every day, but experiencing C can open your eyes to better solutions.

As well as the above (getting rid of C++ niceties), it's a completely different paradigm than C++.

C is generally used in a procedural paradigm, whereas C++ is generally used in an OO paradigm. Programmers should also learn JavaScript to appreciate the prototype paradigm and a functional language too.

e.g. lots of people struggle to write large, manageable, flexible shader codebases in HLSL/GLSL because they're not well practiced in the procedural sytle.
C++ is multi-paradigm, so there'll be times where you'll need to write very C-style code in C++.

Back to what braindigitalis was saying though, it can be used to demonstrate a deep understanding of C++, due to it's simplicity. e.g. It's one thing to be able to use virtual function calls in C++, but it's another to be able to demonstrate how they'd be implemented in C code. If an interview candidate can past that test, then I've got a whole lot more trust that they truely understand what they're doing smile.png
Likewise, at the last company I worked for, they write all their game code in Lua. However, they require all the gameplay programmers to know C++, as it ensures that they'll truely understand the impact of the Lua code that they write.

For a super-technical position -- e.g. programmer in charge of the game engine, I'd probably want them to be able to read assembly code, not just C smile.png

You are a monster!

Anyways...

C++ and C (Increment of C, or C with Objects) is still widely used in a lot of industries. Not just Embedded systems. C++ is used in real time simulations, games, rendering software, Networking protocols and communication (C was created in Bell Laboratories for Unix. Originally intended to help drive their servers... it just basically became the go to language for everything), operating systems, drivers, games, robotics, the list goes on.

The language is so wide spread, that most new languages are derivatives and supersets of it. And normally built with C++ or C. Imagine that.

Also... gameplay programmers whom program in scripting languages... will need to learn C. It's annoying as heck. But most scripting languages are usually procedural. And you'll need to learn how to dance around that limitation.

I would say that learning C should be done, but not the focus. The average programmer is only going to run into C when dealing with various APIs due to the defined binary layout C has that lets software compiled with multiple compilers and languages talk to each other. So you should at least understand enough C to communicate with external libraries and wrap your own stuff.

While I agree with the views expressed in this post it would be of interest to know why the OP is unhappy with java.

This topic is closed to new replies.

Advertisement