In VxWorks 5.5.1, there is apparently a bug in the way blocks of freed memory are coalesced. I’ve found that performance of new and delete calls can be extremely poor unless the delete calls are made in opposite order of the new calls, i.e.
- new A
- new B
- new C
- delete C
- delete B
- delete A
The performance hit from calling new and delete in order doesn’t become noticeable until dozens or hundreds of the calls are performed per second. This problem may apply to other versions of VxWorks as well.