::iterator it=test_map.begin(); it!=test_map.end();){22 std::cout << \"first \" << it->first << \" second \" << (it->second)->i <<\" \"<< (it->second)->test << std::endl;23 delete it->second;24 it->second = NULL;
25 //test_map.erase(it); //迭代器失效;
26 test_map.erase(it++); //防⽌迭代器失效,切记、切记27 } 28
29 return 0;30 }31
32 root@u18:~/cp/test# g++ map3.cpp -g -Wall33 root@u18:~/cp/test# ls -lt a.out
34 -rwxr-xr-x 1 root root 87224 Jul 9 11:00 a.out
35 root@u18:~/cp/test# valgrind --tool=memcheck --leak-check=full ./a.out36 ==28426== Memcheck, a memory error detector
37 ==28426== Copyright (C) 2002-2011, and GNU GPL'd, by Julian Seward et al.38 ==28426== Using Valgrind-3.7.0 and LibVEX; rerun with -h for copyright info39 ==28426== Command: ./a.out40 ==28426==
41 first 0 second 0 test42 first 1 second 1 test43 first 2 second 2 test44 first 3 second 3 test45 first 4 second 4 test46 first 5 second 5 test47 first 6 second 6 test48 first 7 second 7 test49 first 8 second 8 test50 first 9 second 9 test51 ==28426==
52 ==28426== HEAP SUMMARY:
53 ==28426== in use at exit: 0 bytes in 0 blocks
==28426== total heap usage: 30 allocs, 30 frees, 930 bytes allocated55 ==28426==
56 ==28426== All heap blocks were freed -- no leaks are possible57 ==28426==
58 ==28426== For counts of detected and suppressed errors, rerun with: -v
59 ==28426== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 2 from 2)