wyrd Posted August 20, 2003 Posted August 20, 2003 Are there design "rules" on when to use and when not to use static methods? (I'm talking about C# static methods just to clarify). Also what about singletons? To me they seem no different then global variables and probably should be avoided like the plague, but sometimes I can't help but think that they should be used in some situations. Anyone have thoughts on this subject? Quote Gamer extraordinaire. Programmer wannabe.
*Experts* Volte Posted August 20, 2003 *Experts* Posted August 20, 2003 Nothing is wrong with static methods. If you are making helper classes or whatever, it's best to be able to do this:gs = ColorHelper.ToGrayScale(Color.Blue);rather than having to do this:ColorHelper ch = new ColorHelper(); gs = ch.ToGrayScale(Color.Blue);So you'd make ToGrayScale static. Another good spot for static methods is in non-creatable classes and structures... for example, you can't create a new Graphics object, but you can use the shared methods of it to get one.Graphics g = Graphics.FromHdc(); I can't think of any time you'd use a singleton (that is a class in which only one instance can ever be used) over a static class. Quote
dsgreen57 Posted August 20, 2003 Posted August 20, 2003 One area which springs to mind and there are loads which use Singleton's is the game loop in games programming. I often write the game loop within a class and obviously you don't want two of them running. Quote
*Experts* Volte Posted August 20, 2003 *Experts* Posted August 20, 2003 You can put that in a static sub in a class, though. Quote
wyrd Posted August 20, 2003 Author Posted August 20, 2003 Hm. What about this situation; I have a class (GameManager) which keeps track of game object interaction. I'm only going to have one game running, so it would be easier to just make it a static class that way I don't have to pass a GameManager object to each and every object that I create. Certainly it would be easier, but the easy way is not always the best way. If I took this same philosophy, it could also be applied to my Map class. After all, only one map is going to be loaded at a time. Okay, maybe I'm reaching with this example. :P For some reason this is screaming "stay away!" yet at the same time it just seems to make some odd amounts of sense. To give an idea, this is a quick run down of what my GameManager would look like if everything in it was made public static; GameManager.StaticObjects // ArrayList GameManager.MovingObjects // ArrayList GameManager.Effects // ArrayList GameManager.Update() // Updates Everything GameManager.Draw() // Draws Lists & Map GameManager.Ticks // Property GameManager.Map // Property Every single object in my game has to reference a GameManager object for several reasons .. 1) It needs to know what map to use for movement, 2) It needs to know where to add game objects (ie; a missile explodes, the missile needs to know where to place its explosion effect), 3) It needs to know about all other objects in the game for collision detection (or AI for computer controlled players), 4) It needs the current tick count to control how it's updated (Calling Environment.TickCount tons and tons of times per a single loop is out of the question, calling it once per loop and putting the value in GameManager.Ticks is needed) Then of course, there's always making it a singleton rather then a purely static class. :/ One area which springs to mind and there are loads which use Singleton's is the game loop in games programming. :confused: That sentence doesn't make sense. :( Quote Gamer extraordinaire. Programmer wannabe.
*Gurus* Derek Stone Posted August 20, 2003 *Gurus* Posted August 20, 2003 Interchangeable data providers are often interfaced through a singleton implementation. This is one of the more common examples. Quote Posting Guidelines
dsgreen57 Posted August 21, 2003 Posted August 21, 2003 Sorry wyrd I will post some code when I get chance to show you what I mean Quote
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.