Demonstrate raw storage iterators : Deque « Data Structure « C++

C++
1. Bitset
2. Class
3. Console
4. Data Structure
5. Data Type
6. Deque
7. Development
8. File
9. Function
10. Generic
11. Language
12. List
13. Map Multimap
14. Overload
15. Pointer
16. Queue Stack
17. Set Multiset
18. STL Algorithms Binary search
19. STL Algorithms Heap
20. STL Algorithms Helper
21. STL Algorithms Iterator
22. STL Algorithms Merge
23. STL Algorithms Min Max
24. STL Algorithms Modifying sequence operations
25. STL Algorithms Non modifying sequence operations
26. STL Algorithms Sorting
27. STL Basics
28. String
29. Valarray
30. Vector
Java
Java Tutorial
Java Source Code / Java Documentation
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
C# / C Sharp
C# / CSharp Tutorial
ASP.Net
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++ Tutorial
PHP
Python
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
C++ » Data Structure » DequeScreenshots 
Demonstrate raw storage iterators
Demonstrate raw storage iterators


#include <iostream>
#include <deque>
#include <memory>
#include <algorithm>
using namespace std;

class MyClass {
  int a, b;
  int sum;
public:
  MyClass() { 
     a = b = 0
     sum = 0
  }
  MyClass(int x, int y) { 
     a = x; 
     b = y; 
  }

  MyClass(const MyClass &o) {
   a = o.a; b = o.b;
   sum = o.sum;
  }

  MyClass operator=(const MyClass &o) {
    a = o.a; b = o.b;
    return *this;
  }

  void setsum() { 
    sum = a+b; 
  }

  void show() {
    cout << a << "," << b;
    cout << " Sum is: " << sum << endl;
  }
};

int main()
{
  unsigned char raw1[100], raw2[100];
  MyClass *p;
  deque<MyClass> dequeObject(5);
  int i;

  for(i = 0; i <5; i++) {
    dequeObject= MyClass(i, i);
    dequeObject].setsum();
  }
  
  // store deque in uninitialized memory the wrong way
  copy(dequeObject.begin(), dequeObject.end()(MyClass *)raw1);  

  cout << "Contents of raw memory (incorrect):\n";
  p = (MyClass *raw1;
  for(i = 0; i <5; i++)
    p].show();

  // the right way
  copy(dequeObject.begin(), dequeObject.end(),raw_storage_iterator<MyClass *, MyClass>((MyClass *)raw2));

  cout << "Contents of raw memory (correct):\n";
  p = (MyClass *raw2;
  for(i = 0; i <5; i++)
    p].show();

  return 0;
}

           
       
Related examples in the same category
1. One way to reverse-copy a deque.One way to reverse-copy a deque.
2. Use reverse iterators.Use reverse iterators.
3. Reverse iterators and copy.Reverse iterators and copy.
4. Assigning deque objects.Assigning deque objects.
5. Demonstrate swap() for dequeDemonstrate swap() for deque
6. Demonstrate resize() for dequeDemonstrate resize() for deque
7. Iterator values may change.Iterator values may change.
8. Demonstrate a deque.Demonstrate a deque.
9. Deque: push, pop, sort, find, begin, end, insertDeque: push, pop, sort, find, begin, end, insert
w__ww_._j__a_va___2__s__.___co__m___ | Contact Us
Copyright 2003 - 08 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.