47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
1 | |
Исходный код malloc29.11.2011, 18:15. Показов 8433. Ответов 40
Метки нет (Все метки)
Нужен исходный код функции malloc. К сожалению, поиск результатов не принёс.
В качестве ответа хотелось бы видеть либо код, либо ссылку на код Заранее благодарен
1
|
29.11.2011, 18:15 | |
Ответы с готовыми решениями:
40
Подкорректировать исходный код Скомпилировать исходный код Из exe в исходный код Исходный код программы! |
Модератор
12458 / 7482 / 1753
Регистрация: 25.07.2009
Сообщений: 13,762
|
|
29.11.2011, 19:57 | 21 |
Код
Microsoft (R) Incremental Linker Version 8.00.50727.42 Copyright (C) Microsoft Corporation. All rights reserved. /out:malloc_vs_heapalloc.exe malloc_vs_heapalloc.obj C:\c_cpp\system>malloc_vs_heapalloc.exe Malloc total time: 609 HeapAlloc total time: 641 Press any key...
1
|
Делаю внезапно и красиво
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
|
|
29.11.2011, 20:04 | 22 |
Копаете совсем не в ту сторону. Если важна производительность при выделении памяти, то нужно выделять пул памяти и использовать память из него. Будет всего одно обращение к WinAPI. Это самый быстрый способ. Любое обращение к ядру системы требует перехода в KernelMode, а так всё быдет выполняться в ЮзерМод.
Свой распределитель памяти это наше всё. Добавлено через 5 минут 31 миллисекунда для обоих.
0
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
29.11.2011, 20:06 [ТС] | 23 |
Deviaphan, я больше пытаюсь выбрать между HeapAllioc и malloc, а не оптимизировать работу с памятью
0
|
Делаю внезапно и красиво
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
|
|
29.11.2011, 20:09 | 24 |
А смысл тогда в чём?
Добавлено через 1 минуту Ты же обратил внимание, что приведённый код malloc для дебага? В релизе совсем другая функция, без постфикса _dbg.
0
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
29.11.2011, 20:11 [ТС] | 25 |
Deviaphan, смысл в том, что если нет никаких специфических операций с памятью, то нужно использовать malloc (как выяснилось), т.к. это менее напряжно с точки зрения кодирования и проигрыша в производительности нет
0
|
Делаю внезапно и красиво
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
|
|
29.11.2011, 20:23 | 26 |
Сообщение было отмечено как решение
Решение
Вопрос не про malloc, а зачем понадобилось использовать HeapAllioc .
А если ты на С++ программируешь, то я тебя найду...
4
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
29.11.2011, 20:32 [ТС] | 27 |
HeapAlloc сказал использовать препод (предмет "Системное программирование", изучаем winapi, пишем на С, из С++ только ввод/вывод на консоль разрешают делать). на вопрос "зачем?", он сказал, что это оптимальней. вот я начал выяснять, действительно ли это оптимальней/удобней/правильней
программируя на с++ я вообще использую new()
0
|
Модератор
12458 / 7482 / 1753
Регистрация: 25.07.2009
Сообщений: 13,762
|
|
29.11.2011, 20:35 | 28 |
M__A__K, не спорьте с преподом, делайте, как он говорит - больше шансов будет сдать с первого раза. Но саму идею Вы верно поняли...
0
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
29.11.2011, 20:39 [ТС] | 29 |
easybudda, да я особо с ним не спорю, просто хочется понимать, что и зачем делаешь, но спасибо за совет
и спасибо, что помогли разобраться
0
|
Делаю внезапно и красиво
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
|
|
30.11.2011, 08:26 | 30 |
Фууууу! Не придётся тебя искать. Хорошо.)
Делать нужно как просит препод, но только на лабах. Верить олдскульным преподам не стоит, многие ихние знания настолько устарели, что больше вредят, чем пользу приносят. Как щяс помню одного такого, который рассказывал об оптимизациях. Его оптимизированный код работал хуже, чем код генерируемый компилятором по простому коду. Чтобы его оптимизация "показала себя", он отключал все оптимизации компилятора и гордо демонстрировал увеличение скорости в оптимизированном варианте. Нужно отдать ему должное, тестирование он проводил в релизной сборке.
1
|
4226 / 1795 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
|
30.11.2011, 08:53 | 31 |
реально выиграть в производительности:
1. Используя прямую функцию вместо оболочечной, когда проверки не требуются в связи с заведомо допустимыми параметрами и результатами. 2. Используя прямую функцию вместо оболочечной и свои проверки, оптимизированные по сравнению с проверками оболочечной функции. 3. Используя оболочечную функцию вместо прямой, когда проверки нужны, а их качественная самостоятельная реализация невозможна по дефициту знаний или времени. 4. Используя хорошую функцию вместо косячной. Кстати, не факт, что делая через HeapAlloc ты не соорудишь свою оболочечную функцию с семантически идентичными проверками, то есть свой аналог malloc, а если своя функция не лучше стандартной, то она хуже её, так как занимает дополнительное место в памяти одновременно с расходом памяти на хранение стандартной функции.
0
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
30.11.2011, 18:10 [ТС] | 32 |
taras atavin, судя по результатам тестирования (см. мою прогу), обыкновенный вызов malloc не уступает по производительности HeapAlloc (или уступает, но незначительно). поэтому, в связи с некоторыми большей геморностью вызова HeapAlloc, насчёт оправданности использования прямой функции вместо оболочечной, когда проверки не требуются в связи с заведомо допустимыми параметрами и результатами, можно поспорить. Также против незначительного вне зависимости от количества вызовов преимущества в производительности HeapAlloc выступает ещё и меньшая зависимость от платформы malloc.
В данный пункт можно отнести и такие ситуации, когда логика работы программы требует работы с кучами. Но это уже более специфические ситуации. А мой вопрос больше касался именно стандартных вызовов. а вообще, спасибо, что откликнулись и так чётко сформулировали ответ
0
|
30.11.2011, 18:28 | 33 |
Всегда нужно выбирать золотую середину, между скоростью работы программы и понятностью написания кода. Возможно, что при использовании HeapAlloc у тебя программа и ускорится, но в нормальнонаписанной программе крайне редко бывает так, чтобы выделение памяти дёргалось постоянно (см. пост #22). В итоге можно ускорить программу на 0.5%, но при этом поиметь целый паровоз геморроев с различной природой происхождения. А потому, прежде, чем идтина поводу у такой оптимальности, всегда надо сначала себя спросить "а оно того стОит?".
Ну и присоединяюсь к мнению, что лучше делать так, как сказал преп - нервы дороже
0
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
30.11.2011, 18:40 [ТС] | 34 |
я потому этот вопрос и поднял
все так переживают за мои с преподом отношения а если серьёзно, то моей целью никогда не было ткнуть носом препода. данный вопрос был мной поднят для удовлетворения собственных интересов. хотя я продемонстрирую преподу прогу и спрошу его мнение насчёт полученных выводов. если у него возникнут какие-нибудь контр аргументы, я обязательно выложу их сюда на обсуждения.
0
|
30.11.2011, 19:50 | 35 |
Наверное не раз наблюдал, как в каком-нибудь месте висит табличка "не хлопайте дверью" и сидит тётенька, которая каждого входящего материт на тему, что там мол для вас табличку написали. И это будет продолжаться до скончания веков, но пружинный механизм на дверь они не повесят. Потому что слишком сильно убеждены в том, что кругом одни пи...сы, а они великомученники.
Пример может и очень натянутый, но общая мысль имеет то же направление. Если все думают так, значит ты поставил вопрос именно под таким углом
0
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
30.11.2011, 21:30 [ТС] | 36 |
если все так думают, то совсем необязательно, что это действительно так
но это уже офтоп пошёл
0
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
30.11.2011, 21:54 [ТС] | 38 |
вопрос сформулирован в посте №6
подскажите, пожалуйста, в чём ошибочна его постановка Добавлено через 6 минут Deviaphan, препод вроде не сильно олдскульный, потому к его словам следует прислушиваться. но безоговорочно верить нельзя никому!
0
|
30.11.2011, 22:09 | 39 |
Очевидно, что нужно было сделать упор на то, что тебе нужно для саморазвития, потому что, упомянув преподавателя, люди начали воспринимать вопрос именно с этой точки зрения. Я это всё говорю на будущее, если что
0
|
47 / 47 / 6
Регистрация: 09.11.2010
Сообщений: 308
|
|
30.11.2011, 22:13 [ТС] | 40 |
спасибо, буду учитывать это в будущем
0
|
30.11.2011, 22:13 | |
30.11.2011, 22:13 | |
Помогаю со студенческими работами здесь
40
Исправьте исходный код разбираем исходный код Исходный код LUNIX Исходный код библиотеки Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |