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

Выделение памяти построчно или куском. Массив C++ - C++

Восстановить пароль Регистрация
 
Maximka000
0 / 0 / 0
Регистрация: 21.03.2014
Сообщений: 2
21.03.2014, 17:58     Выделение памяти построчно или куском. Массив C++ #1
Здравствуйте!
Привожу следующий код:
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
    int H = 20000, W = 20000,
        y, x;
    int **rows;
    
    //ВЫДЕЛЕНИЕ ПАМЯТИ ПОСТРОЧНО
    _time.tic();
        rows = new int *[H];
        for (y = 0; y < H; ++y)
            rows[y] = new int [W];
    cout << "1new: " << _time.toc() << endl;
 
    _time.tic();
        for (y = 0; y < H; ++y)
            for (x = 0; x < W; ++x)
                rows[y][x] = y+x;
    cout << "1write: " << _time.toc() << endl;
 
    _time.tic();
        for (y = 0; y < H; ++y)
            delete [] rows[y];
        delete [] rows;
    cout << "1free: " << _time.toc() << endl;
    _getch();
 
    //ВЫДЕЛЕНИЕ ПАМЯТИ КУСКОМ И ПОЛУЧЕНИЕ УКАЗАТЕЛЕЙ НА СТРОКИ
    _time.tic();
        int *mas2 = new int[H * W];
        rows = new int *[H];
        for (y = 0; y < H; ++y)
            rows[y] = mas2 + y * W;
    cout << "2new: " << _time.toc() << endl;
 
    _time.tic();
        for (y = 0; y < H; ++y)
            for (x = 0; x < W; ++x)
                rows[y][x] = y+x;
    cout << "2write: " << _time.toc() << endl;
 
    _time.tic();
        delete [] mas2;
        delete [] rows;
    cout << "2free: " << _time.toc() << endl;
    _getch();
Получаю, что время на выделение и освобождение памяти сильно отличается в пользу второго варианта (память куском).
Но на запись элементов массива требуется меньше времени примерно в два раза для первого варианта (память построчно).
_time.tic() и _time.toc() - счетчик времени в милисекундах. Т.е. результат такой:
1new: 857.381
1write: 188.605
1free: 1862.25

2new: 0.379265
2write: 375.561
2free: 90.3837

Использую MS Visual Studio 2012. Собираю на Release x64

Вопрос в том почему так) Если на счет скорости выделения и освобождения памяти мне понятно. То в чем отличие при обращении к памяти - не понятно. И почему второй вариант проигрывает?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.03.2014, 17:58     Выделение памяти построчно или куском. Массив C++
Посмотрите здесь:

C++ Массив строк, выделение памяти
C++ Выделение памяти под массив структур
Выделение памяти под массив C++
Выделение памяти под двумерный массив С++ C++
C++ Выделение памяти под двумерный массив
C++ Статический массив - динамическое выделение памяти!?
C++ Выделение памяти под массив структур
Выделение памяти под шаблонный массив C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Tulosba
:)
Эксперт C++
4378 / 3221 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
21.03.2014, 18:00     Выделение памяти построчно или куском. Массив C++ #2
Maximka000, рад за Вас, и в чем вопрос?
Maximka000
0 / 0 / 0
Регистрация: 21.03.2014
Сообщений: 2
21.03.2014, 18:03  [ТС]     Выделение памяти построчно или куском. Массив C++ #3
Tulosba, отредактировал пост. Извините, поспешил и забыл написать вопрос)
Yandex
Объявления
21.03.2014, 18:03     Выделение памяти построчно или куском. Массив C++
Ответ Создать тему
Опции темы

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