data:image/s3,"s3://crabby-images/603f1/603f1f427d078887189b0bffb8c28693c5c8b0fe" alt=""
Hi Cedric, On Mon, 2011-10-10 at 11:29 +0200, Cedric Laczny wrote: [...]
Please note that you are using a _copy_ here and thus you also return the iterators of a _copy_ but not of the "original" container. Therefore, I assume that the iterators returned are not valid and might even lead to a segmentation fault (as they do on my machine, since this container-copy is only valid during the execution of elements() ). Perhaps you want to try "const T& container" in the argument list.
The bright shine of conclusion comes over me. I feel a little bit less
stupid for a moment... The felling is gone.
By using the "&"-reference type the operations in 'elements' are done on
'the original'. Now a 2-tuple of std::list <int>::iterator of 'the
original' list is returned by 'elements'.
For completeness here is the not so unhappy example in which i use 'T&'
in stead of 'const T&' in stead of 'T' as the argument of function
'elements':
// begin code
#include <iostream>
#include <list>
#include