Нативный CopyMemory24.09.2023, 11:14. Показов 9828. Ответов 122
Метки рассуждения (Все метки)
Натолкнуло на рассуждения, уже ранее упомянутое.. В общем то уже ранее слышал, про замедление работы апишных функций в современных реалиях. Собственно вопрос, возможно ли копирование блока/участка с динамически меняющимся (настраиваемым) значением(?). Собственно копирование то возможно блоков разного размера, есл говорить о больших - замапив на оба блока массивы и выполнив присвоения в цикле с одного массива в другой. Тесты показывают, что блок одинакового размера копируется в 4 раза быстрей с помощью массива long, нежели битового и также в других случаях - чем меньше итераций, тем кратно быстрей. Можно копировать и большие блоки за одну операцию средствами VB. Если создать тип, с фиксированным массивом внутри, то один экземпляр типа (фактически массив) можно присвоить другому экземпляру типа. С динамическими массивами так не получится, блок перезаписывается, также как и у строк. С другой стороны у фиксированого массива свои недостатки, его нельзя замапить изменить его заголовочную структуру и даже поменять указатель на нее
0
|
||||||
| 24.09.2023, 11:14 | |
|
Ответы с готовыми решениями:
122
Private Declare Sub CopyMemory Lib 'kernel32' Alias 'RtlMoveMemory' (Destination As Any, Source As Any, ByVal Length As Long) В WinXP не работает API процедура CopyMemory. Что делать? Почему указатель нулевой при CopyMemory |
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|||
| 24.09.2023, 14:53 | |||
|
А через присвоение можно и без LSet же копировать любые блоки любой длинны, CopyMemory вообще не надо тогда. Просто присвоение и всё.
Добавлено через 42 секунды Добавлено через 22 секунды
0
|
|||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 24.09.2023, 15:08 | |
|
0
|
|
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 24.09.2023, 15:13 | |
|
The trick, спасибо, что сказал про LSet, я тоже не знал.
0
|
|
| 24.09.2023, 16:24 [ТС] | ||||||
|
Вообще, я думаю, левый Mid во много может заменить CopyMemory, с условием конечно, что копируемые данные должны быть размером, кратным 2 байта, и условием, что блок данных, в кторый производится копировние должен быть размеще на предварительно выделеной памяти со смещение 4 байта под размер строки, чтобы можно было мапить строку на этот блок. + есть еще одна плюшка со строками у них свободное присвоение с байтовыми массивами (в обе стороны) и c Mid-ом это тоже работает. Т.о. строку можно замапить на нужный блок (с 4мя байтами в начале), а байтовый массив можно замапить на все, что угодно и выполнять копирование блока произвольного размера таким способом.
0
|
||||||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
||
| 24.09.2023, 16:28 | ||
|
testuser2, есть ещё MidB$ не забывай. Там уже можно не париться, что должно быть кратно двум байтам.
Добавлено через 1 минуту Добавлено через 39 секунд Я эту статью давно уже прочитал, очень интересная и полезная.
1
|
||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
||||||||
| 24.09.2023, 16:47 | ||||||||
Добавлено через 1 минуту Байтовых функций много есть хороших. Единственное чего мне не хватало это InStrRevB. Жалко что такой функции нету.
0
|
||||||||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 24.09.2023, 16:52 | |
|
testuser2, да не парься ты из-за этого)
0
|
|
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 24.09.2023, 17:03 | |
|
testuser2, лучше бы мне с картинкой помог
0
|
|
| 30.09.2023, 22:39 | ||
|
Не по теме:
Это идинственная dll, доступная на раннем этапе загрузки ОС, до загрузки подсистемы Win32, а также драйверам. Если интересно окунуться, можете ещё посмотреть, что такое Native Application: https://www.youtube.com/watch?v=EKBvLTuI2Mo
1
|
||
| 01.10.2023, 11:20 [ТС] | ||||||
|
Потестировал немножк разные способы копирования. Не очень люблю с этим особо заморачиваться, составлять таблицы там и т.д. Кому интересно может проверить и раскомментировать нужное. Общие выводы: комманда LSet очень быстрая, скорость аналогичная базовому(нативному)) присвоению. Работа CopyMemory также близка к этой скорости, и что примечательно, использование ли заранее подготовленных указателей или StrPtr в вызове функции не вносят особой разницы. Mid медленный (порядка 10 раз). Кроме LSet еще есть RSet пишущий справа. Не хватает еще MSet-а )
Удивительный такой факт, за время теста при копировании блока 3022 байта (1 кб) за 10000000 итераций фактически копируется и зануляется ~28 гб., если я не ошибаюсь и это происходит за считанные секунды.
1
|
||||||
|
Вернулся
1748 / 644 / 45
Регистрация: 10.09.2021
Сообщений: 2,786
|
|
| 01.10.2023, 12:16 | |
|
0
|
|
| 02.10.2023, 19:06 [ТС] | |||||||||||
|
Задрючнился сегодня с такой темой, турбоускоренным MemCopy4/8/16/**. Не знаю есть ли смысл в сих гениальных изобретениях, но, пусть пока будет.
Кликните здесь для просмотра всего текста
0
|
|||||||||||
| 03.10.2023, 17:05 [ТС] | |||||||||||
|
Добавил две новые процедуры.
1) MemCopy16_ (с нижним подчеркиванием) копирует блоки любого заданного размера в цикле кусками по 16 байт. Размер выравнивается по 16 байтам. 2) MemCopyLs мапит строки на заданные участки памяти и копирует с помощью присвоения с LSet данных строк. Казалось бы просто, но, чтобы замапить строки, нужно прописать, им размер, для чего предусмотрены дополнительные long-манипуляции с этим размером. В итоге всего в процедуре получается аж 10 присвоений, из которых 9 из которых long-long и одно - string-string (c LSet-ом). Но, возможно повоторюсь, учитывая обстоятельства, описанные в сабжевой ссылке, это может иметь смысл. Там автор говорит, о том, что на одной из машин CoptMerory оказалась аж в 600(!) раз медленней. Также там приводится тест, на котором, CopyMemory оказалась медленей порядка 5 раз. Кликните здесь для просмотра всего текста
1
|
|||||||||||
| 03.10.2023, 17:05 | |
|
CopyMemory жжет
memcpy/CopyMemory + 2-мерный динамический массив CreateFileMapping ошибка в CopyMemory Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
[golang] Конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов.
alhaos 10.06.2026
Задача
Реализовать конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов.
Сигнатура
func Fetch(urls string, maxConcurrent int) Result
Пример
urls :=. . .
|
[golang] Состояние гонки (race condition)
alhaos 10.06.2026
Состояние гонки (race condition)
Состояние гонки (Race Condition) — это ошибка, возникающая при одновременном доступе нескольких горутин к одним и тем же данным без должной синхронизации. При этом. . .
|
Взрослые отношения, и почему они не получаются
kumehtar 09.06.2026
Когда в детстве ребёнок не получает от родителей чего-то важного, он лишается не просто приятных переживаний, а основы для формирования определённых внутренних качеств и навыков. Если ребёнок не. . .
|
[golang] Worker Pool
alhaos 09.06.2026
Worker Pool
Worker Pool — паттерн конкурентной обработки задач в Go.
Суть: фиксированное количество горутин-воркеров читают задачи из общего канала
и пишут результаты в общий канал результатов. . . .
|
|
[golang] Pipeline
alhaos 08.06.2026
Pipeline
Pipeline — паттерн конкурентной обработки данных в Go.
Суть: данные проходят через цепочку независимых стадий, каждая из которых работает в своей горутине и общается с соседями через. . .
|
Свет внутри себя
kumehtar 07.06.2026
Пусть это будет здесь
lIs4oanZS9Y
|
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу.
До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
|
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений.
. . .
|