기본 콘텐츠로 건너뛰기

After end iterator

enditr.cpp
#include <list>
#include <vector>
#include <deque>
#include <map>
#include <set>
#include <iostream>
#include <ctime>
using namespace std;

template<typename _T>
void
testSeqItr(void)
{
 _T some;
 typename _T::const_iterator ib;
 typename _T::const_iterator ie;
 typename _T::const_iterator it;

 for ( int i = 0; i < 1024; i++ )
 {
        some.push_back(rand());
 }

 ib = some.begin();
 ie = some.end();
 it = ie;
 ++it;

 cerr << __PRETTY_FUNCTION__ << endl;
 cerr << "begin equal? " << (ib==it) << endl;
 cerr << "end equal? " << (ie==it) << endl;
}

template<typename _T>
void
testAssItr(void)
{
 _T some;
 typename _T::const_iterator ib;
 typename _T::const_iterator ie;
 typename _T::const_iterator it;

 for ( int i = 0; i < 1024; i++ )
 {
        some.insert(make_pair(rand(),rand()));
 }

 ib = some.begin();
 ie = some.end();
 it = ie;
 ++it;

 cerr << __PRETTY_FUNCTION__ << endl;
 cerr << "begin equal? " << (ib==it) << endl;
 cerr << "end equal? " << (ie==it) << endl;
}

int
main(int,char**)
{
 srand((unsigned int)time(NULL));

 testSeqItr< basic_string<int> >();
 testSeqItr< list<int> >();
 testSeqItr< deque<int> >();
 testSeqItr< vector<int> >();

 testAssItr< map<int,int> >();
 testAssItr< multimap<int,int> >();

 return 0;
}
$ make enditr
g++ enditr.cpp -o enditr
./enditr
void testSeqItr() [with _T = std::basic_string<int, std::char_traits<int>, std::allocator<int> >]
begin equal? 0
end equal? 0
void testSeqItr() [with _T = std::list<int, std::allocator<int> >]
begin equal? 1
end equal? 0
void testSeqItr() [with _T = std::deque<int, std::allocator<int> >]
begin equal? 0
end equal? 0
void testSeqItr() [with _T = std::vector<int, std::allocator<int> >]
begin equal? 0
end equal? 0
void testAssItr() [with _T = std::map<int, int, std::less<int>, std::allocator<std::pair<const int, int> > >]
begin equal? 0
end equal? 0
void testAssItr() [with _T = std::multimap<int, int, std::less<int>, std::allocator<std::pair<const int, int> > >]
begin equal? 0
end equal? 0
/usr/include/c++/*/bits/stl_*.h를 헤집어보면 속도를 위해 바운더리 체크 아무것도 안 하는 것을 알 수 있다. orz OTL
뭐, 리스트(더블링크드리스트)는 꼬리에 처음을 머리로 해놨겠지. 암튼, 반복자 잘 관리해야할 듯.

댓글

이 블로그의 인기 게시물

탐색기에서 OneDrive 이 2개로 보이는 문제

왜 2개가 보이는지 모르겠지만, Registry 삭제하면 됨 HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\Desktop\NameSpace 하위 키에서 OneDrive 둘 중에 하나만 지워도 바로 반영됨. 참조:  https://answers.microsoft.com/en-us/msoffice/forum/all/duplicate-onedrives-in-file-explorer/49c935a6-287b-43a5-aed5-2dee2a1c1b22

절전을 깨운 녀석 알아내기

가끔씩 윈도우 절전을 깨우는 녀석이 있는데, 보통은 USB Keyboard/Mouse 이다. 요런 녀석들은 장치관리자에서 "이 장치를 사용하여 컴퓨터의 대기 모드를 종료할 수 있음"을 꺼주면 된다. 그래도 가끔씩 알 수 없는 이유로 켜졌을 경우, 관리자 권한으로 커맨드 창 열고 확인한다. C:\> powercfg -lastwake 절전 모드 해제 기록 카운트 - 1 절전 모드 해제 기록[0] 절전 모드 해제 소스 카운트 - 1 절전 모드 해제 소스[0] 종류: 장치 인스턴스 경로: XXX 이름: YYY 설명: ZZZ 제조업체: AAA