Форум программистов, компьютерный форум CyberForum.ru

разделяемая память - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 5.00
Flamе
9 / 9 / 0
Регистрация: 25.10.2009
Сообщений: 152
11.05.2012, 19:56     разделяемая память #1
Всем привет!
подскажите, пожалуйста, как решить такую проблему:
У меня есть программа которая открывает 2 консольных окна. есть одномерный массив. если поменять его элементы в одном окне, то затем можно распечатать массив в другом окне и все изменения сохранятся. Всё бы замечательно, но почему то с двумерным массивом не работает ничего. При запуске второго окна в первом при любых действия программа вылетает....
Может кто знает с чем это может быть связано? заранее спасибо!

вот код:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
HANDLE hFile,hMapping;
 
    hMapping=CreateFileMapping(NULL,NULL,PAGE_READWRITE,0,10*sizeof(int),_T("MyMapping"));
    if(hMapping==NULL)
    {
        printf("can't create mapping\n");
        exit(0);
    }
 
    if(GetLastError()==ERROR_ALREADY_EXISTS)
        printf("second player\n");
    else
        printf("first player\n");
 
int **arr=new int*[10];
    for (int i=0; i<10; i++)
        arr[i]=new int[10];
for (int i=0; i<10; i++)
        for (int j=0; j<10; j++)
            arr[i][j]=i+j;
    
data_=(int**)MapViewOfFile(hMapping,FILE_MAP_WRITE,0,0,0);
    CopyMemory(data_,arr, 100* sizeof(int));
 
    int i, j;
    for(;;)
    {
        printf("select action: 1 - print 2 - set 3 - quit:");
        cin>>i;
        switch(i)
        {
        case 1:
            for (int i=0; i<10; i++)
                {for (int j=0; j<10; j++)
                cout<<data_[i][j]<<" ";
            cout<<endl;}
            break;
 
        case 2:
            printf("enter index:");
            cin>>i>>j;
            printf("eneter value:");
            cin>>(data_[i][j]);         
            break;
 
        case 3:
            UnmapViewOfFile(data_);
            CloseHandle(hMapping);
            return 0;
            break;
        }
    }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.05.2012, 19:56     разделяемая память
Посмотрите здесь:

C++ Динамическая память
Статическая память,Динамическая память. C++
C++ Память
C++, Разделяемая память и apache CGI C++
Разделяемая память C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
modwind
 Аватар для modwind
52 / 52 / 1
Регистрация: 09.03.2012
Сообщений: 101
11.05.2012, 20:30     разделяемая память #2
Видно, что общая память выделяется только под 10 указателей. Эти указатели будут действительны только в первой программе.

Следует создать маппинг сразу на 100 чисел в одномерном массиве, а считать его как бы двумерным, по 10 чисел в каждом ряду:
C++
1
2
3
4
5
hMapping=CreateFileMapping(NULL,NULL,PAGE_READWRITE,0,10*sizeof(int),_T("MyMapping"));
data_=(int*)MapViewOfFile(hMapping,FILE_MAP_WRITE,0,0,0);
int **arr=new int*[10];
    for (int i=0; i<10; i++)
        arr[i]=data+10*i;
Flamе
9 / 9 / 0
Регистрация: 25.10.2009
Сообщений: 152
11.05.2012, 20:47  [ТС]     разделяемая память #3
Цитата Сообщение от modwind Посмотреть сообщение
Следует создать маппинг сразу на 100 чисел в одномерном массиве
т.е. надо писать 100*sizeof(int)?
C++
1
hMapping=CreateFileMapping(NULL,NULL,PAGE_READWRITE,0,100*sizeof(int),_T("MyMapping"));
и ещё не понятно как тут создастся 100 элементов?
C
1
2
3
int **arr=new int*[10];
    for (int i=0; i<10; i++)
        arr[i]=data_+10*i;
modwind
 Аватар для modwind
52 / 52 / 1
Регистрация: 09.03.2012
Сообщений: 101
11.05.2012, 20:54     разделяемая память #4
Да, 100*sizeof(int), я немного ошибся...
В том коде 100 элементов не создаются. Просто 10 указателей направляются в нужные места заранее выделенной памяти, через каждые 10 элементов.
Flamе
9 / 9 / 0
Регистрация: 25.10.2009
Сообщений: 152
11.05.2012, 21:01  [ТС]     разделяемая память #5
Цитата Сообщение от modwind Посмотреть сообщение
Да, 100*sizeof(int), я немного ошибся...
В том коде 100 элементов не создаются. Просто 10 указателей направляются в нужные места заранее выделенной памяти, через каждые 10 элементов.
эммм, тогда может надо написать
C++
1
2
3
int **arr=new int*[10];
    for (int i=0; i<10; i++)
       data_[i]=arr[i]+10*i;
просто arr - это ведь сам массив, а data_ - указатель) или я не так всё-таки понимаю суть?
modwind
 Аватар для modwind
52 / 52 / 1
Регистрация: 09.03.2012
Сообщений: 101
11.05.2012, 21:19     разделяемая память #6
Нет, arr здесь просто массив указателей. data_ - одномерный массив, указывает на выделенную общую память размером 100 int.
C++
1
2
data: [][][][][] [][][][][] [][][][][] [][][][][] [][][][][] ...
arr:  ^                     ^                     ^
Flamе
9 / 9 / 0
Регистрация: 25.10.2009
Сообщений: 152
11.05.2012, 21:31  [ТС]     разделяемая память #7
Цитата Сообщение от modwind Посмотреть сообщение
Нет, arr здесь просто массив указателей. data_ - одномерный массив, указывает на выделенную общую память размером 100 int.
C++
1
2
data: [][][][][] [][][][][] [][][][][] [][][][][] [][][][][] ...
arr:  ^                     ^                     ^
а что из них использовать для изменения элементов массива в этом коде например?:
C++
1
2
3
4
5
6
7
case 2:
            printf("enter index:");
            int j;
            cin>>i>>j;
            printf("eneter value:");
            cin>>(data_[i]);
            cout<<data_[i]<<endl;
просто у меня все числа хранились в двумерном массиве arr, а data_ - указатель на него....
modwind
 Аватар для modwind
52 / 52 / 1
Регистрация: 09.03.2012
Сообщений: 101
11.05.2012, 22:03     разделяемая память #8
Можно обращаться к data_, как к двумерному массиву двумя способами:
а) data[i*10+j], где i - номер строки, 10 - число элементов в строке, j - номер столбца
б) всё так же, через массив arr, в виде arr[i][j]. Если массив arr создан специальным образом, как я описал выше. При этом arr[i] указывает на data[i*10], а следовательно arr[i][j] указывает на data[i*10+j].

Не следует освобождать arr[i], так как оно указывает на память data, ему не принадлежащую. Достаточно освободить сам arr.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.05.2012, 22:05     разделяемая память
Еще ссылки по теме:

Не выделяется память C++
C++ Динамическая память с++
C++ Выделяется ли память?

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Flamе
9 / 9 / 0
Регистрация: 25.10.2009
Сообщений: 152
11.05.2012, 22:05  [ТС]     разделяемая память #9
спасибо! попробую разобраться теперь)
Yandex
Объявления
11.05.2012, 22:05     разделяемая память
Ответ Создать тему
Опции темы

Текущее время: 06:16. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru