問題を説明するために、stackoverflowでここに表示されているリンクリストのサンプルコードを使用します。
私のc++で書かれたプログラム(x64)には、次のリンクリストコードが含まれています。
古いコードスニペットが削除されました。コメントが意味をなさなくなったらごめんなさい。
私の問題が何であるかを示すために完全に機能するコードを追加しました。コンパイル:g ++linkedlist.cpp -olinked-list
#include <cstdlib>
#include <iostream>
using namespace std;
 struct node
{
    public :
          unsigned int part1; // 4 bytes
          unsigned int part2; // 4 bytes
          node *next;         //pointer, 8 bytes on 64 bit system
      unsigned int read_part1();
 };
struct LinkedList
 {
     public:
     LinkedList();
          void insert(unsigned int data[], unsigned int data1);
          bool isEmpty() const;
          node* head;
 };
unsigned int node::read_part1() {
return part1;
}
 LinkedList::LinkedList():
 head(NULL)
{
}
bool LinkedList::isEmpty() const
{
  return (head == NULL);
}
  void LinkedList::insert(unsigned int data[], unsigned int data1)
 {
    node* oldHead = head;
    node* newHead = new node();
    newHead->part1 = data[0];
    newHead->part2 = data1;
    newHead->next = oldHead;
    head = newHead;
  }
unsigned int allocations = 300000000;
unsigned int index_size = 430000000;//index of lists, 430m,.
                    //will be creatad on heap
    LinkedList *list = NULL;
int main(int argc, char *argv[])
{
LinkedList list_instance;
cout << "1 LinkedList instance takes [" << sizeof(list_instance) << "] bytes in memory!"<< endl;
node node_instance;
cout << "1 node instance takes [" << sizeof(node_instance) <<"] bytes in memory !"<< endl;
    try{
    list = new LinkedList[index_size];
    }
     catch(std::bad_alloc) {
    cout << "Error allocating memory" << endl;
     return 0;
    //reboot code
    }
unsigned int some_data[] = {00, 01};
unsigned int index;
LinkedList *list_instance2 = NULL;
cout << "Allocating ..." << endl;
for (int i=0; i<allocations; i++)
{
index = rand();
unsigned short inde = (unsigned short)index;
list_instance2 = &list[inde];
list_instance2->insert(some_data, some_data[1]);
}
unsigned long sk = ((allocations * sizeof(node_instance) + index_size*sizeof(list_instance))) / (1024*1024*1024);
cout << "This process *should* consume around " << sk <<" GBytes of memory, but does it ?"<< endl;
cout << "Allocating done, *check the process size* and press any number key + ENTER to exit ..." << endl;
int u=0;
cin >> u;
return 0;
}
それをコンパイルして実行し、プロセスサイズが予想とリモートで一致するかどうかを確認します。そうでない場合-問題はどこにありますか?
ああ、私はそれを変更されていないデフォルトのカーネルを使用して64ビットのSlackware13.37で実行します。