vector와 deque는 연속적인 메모리 공간을 사용하는 동적배열?

dltkddyd의 이미지

vector가 어떻게 구현되는지를 생각해봤는데, 내부에 역참조할 수 있는 포인터를 하나 갖는 동적배열이라는 잠정적인 결론을 내리게 됐습니다. 맞나요?
그리고 그 포인터가 가리키는 일련의 공간(하나로 연이어진)을 사용합니다. 이것도 맞는지 궁금하네요?
그리고 deque도 vector와 같이 역참조할 수 있는 포인터를 하나 갖고 있으며 구현된 원리는 vector와 같다. 즉 일련의 공간(하나로 연이어진)을 사용한다. 단 앞에서 삽입, 삭제가 가능하다는 점에서만 vector와 다르다. 이 설명도 맞는지 궁금합니다.
vector는 직접 만들어봤습니다. deque도 한 번 직접 만들어보려고요? vector와 유사한 구조인지 궁금합니다.

kukyakya의 이미지

C++11 이전의 표준에서는 vector가 꼭 연속된 공간을 사용할 의무가 없었고, C++11에 와서야 연속된 공간을 사용해야 한다는 내용이 추가되었습니다.

23.3.6 Class template vector
23.3.6.1 Class template vector overview
1 A vector is a sequence container that supports random access iterators. In addition, it supports (amortized) constant time insert and erase operations at the end; insert and erase in the middle take linear time. Storage management is handled automatically, though hints can be given to improve efficiency. The elements of a vector are stored contiguously, meaning that if v is a vector where T is some type other than bool, then it obeys the identity &v[n] == &v[0] + n for all 0 <= n < v.size().

대부분의 구현체가 연속된 공간을 사용하도록 구현되어 있긴 하지만 기존의 표준에서는 vector가 꼭 연속된 공간을 사용하리란 보장을 할 수 없습니다.

deque는 C++11을 포함한 모든 표준에서 연속된 공간으로 구현해야할 의무가 없습니다.(물론 연속된 공간으로 구현하는 것이 가장 편하겠죠.)

dltkddyd의 이미지

처음에는 deque가 vector와 같을 것이라고 생각했는데, 어제 하루, 그리고 오늘 생각해보니 많이 다르네요. deque는 vector보다 더 진일보한 것이며 vector의 단점을 보완하기 위한 컨테이너 같다는 생각을 했습니다. 각종 연산자는 물론 begin(), end()의 구현도 vector와는 다를 것이라는 판단을 내렸습니다. 물리적으로 독립적인 공간을 사용하는 것이 분명할 것이라 생각하는데요. 그렇지 않으면 push_front를 연속으로 사용할 때 부하가 많이 걸리더군요. 표준의 경우는 아무리 수천 만 번을 push_front로 값을 집어넣어도 속도가 전혀 줄어들지 않습니다. 이로 추정컨데 분명 gcc의 deque는 두 개의 물리적인 공간을 사용할 겁니다. deque가 말 그대로 double ended que니까요. 즉 두 개로 끝나는 큐라는 것이죠.
맞는지 모르겠네요?

본인 맞습니다.
인증샷
우헤헤헤... 로 대신합니다.

klara의 이미지

그냥 벡터에서 뒤에 미리 할당해놓듯이 앞에도 미리 할당하고 유효한 데이터가 시작되는 오프셋만 조절하면 됩니다.

winner의 이미지

실제로는 더 쓸모가 없는 것 같습니다.
http://www.baptiste-wicht.com/2012/12/cpp-benchmark-vector-list-deque/
뭐랄까.... 콩라인?

winner의 이미지

주소추출연산자를 사용한 표현식은 확실히 C++11 에 추가된 것 같은데 좀더 명확히 하기 위해서 들어간 것으로 알고 있습니다.
그리고 deque 는 표준이 요구하는 바를 구현할려면 전체공간을 연속공간으로 만들 수가 없습니다.
http://stackoverflow.com/questions/5345152/why-would-i-prefer-using-vector-to-deque
무엇보다 container 에 삽입, 삭제가 일어나도 요소참조는 무효화되지 않는다는 규정이 있기 때문입니다.

kukyakya의 이미지

vector의 연속공간 보장은 C++11이 아니라 C++03부터 추가된 내용이었네요.

deque에 레퍼런스 invalidation에 관한 내용이 있었군요. 개인적으로 거의 안쓰는 컨테이너라 iteration validation에 대해서만 기억하고 있어서 잘못된 답변을 달았네요. 죄송합니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.