Sometimes you run into code that has extra brace brackets, that have nothing to do with scope, only are for readability and avoiding mistakes.
For example:
GetMutexLock( handle ) ;
{
// brace brackets "scope" the lock,
// must close block / remember
// to release the handle.
// similar to C#'s lock construct
}
ReleaseMutexLock( handle ) ;
Other places I have seen it are:
glBegin( GL_TRIANGLES ) ;
{
glVertex3d( .. ) ;
glVertex3d( .. ) ;
glVertex3d( .. ) ;
} // must remember to glEnd!
glEnd() ;
This introduces a compiler error if the mutex isn’t freed (assuming you remember both the } and the Release() call).
- Is this a bad practice? Why?
- If it isn’t one, could it change how the code is compiled or make it slower?
The braces themselves are fine, all they do is limit scope and you won’t slow anything down. It can be seen as cleaner. (Always prefer clean code over fast code, if it’s cleaner, don’t worry about the speed until you profile.)
But with respect to resources it’s bad practice because you’ve put yourself in a position to leak a resource. If anything in the block throws or returns, bang you’re dead.
Use Scope-bound Resource Management (SBRM, also known as RAII), which limits a resource to a scope, by using the destructor:
So you get:
Do this will all resources, it’s cleaner and safer. If you are in a position to say “I need to release this resource”, you’ve done it wrong; they should be handled automatically.