Vectors are one of the single most useful and most used objects in the STL. They are easy to use, and remove the burden of memory management from the user. It is possible to partially control memory usage by using functions like reserve
, but nothing is provided to free up excess memory. Users have come up with ways to trim a vector by hand, but with the advent of the new C++0x and its move semantics, the classic solution of copy-swaping has become excessively expensive. This article seeks to find a better solution.
Latest Memory Articles
Intelligent Memory Buffer Class on Non-MFC(SDK) Platforms
Check out this stand-alone, intelligent "increasing buffer" class. It's useful for a Win32 SDK project without using MFC.
Application-Level Memory Management for Memory-Constrained Devices
Discover a faster and better dynamic memory allocation technique for real-time systems.
Copy Constructors and Assignment Operators
Copying constructors and assignment operators is easy—once you learn the rules, and you can learn those rules right here.
Fast, Efficient Allocator for Small Blocks of Memory
Learn about an approach to allocate small blocks of memory quickly and efficiently.
Enhance Your Dynamic Memory Allocation with an Undocumented MFC Class
Learn to employ a small utility class that allows you to modify how objects for a given class are dynamically allocated.
Latest Developer Videos
More...Latest CodeGuru Developer Columns
C++ Tips and Tricks
Quirky and yet persistent, C++ is a language that keeps programmers coming back to it. Pick up some new ways to wrangle it into your workflow.

Creating a Server with .NET Socket Programming
HTTP isn't the only network protocol that's useful. Learn about, or beef up your skills with, socket-level programming.

Common Library Functions in Visual Basic
Learn about the functions, and see a small example of how the particular functions can be used.
The Top Challenge for Developers is...
Most developers face a grueling challenge to please their end users. We asked their top challenge is. With over 3,000 responses, the results are now available!