Netspirit, преимущество связанных через проекцию файлов в его низкоуровневости, минуя все системные интерфейсы. Быстродействие проекций всегда будет выше работы через системные интерфейсы. Размером блока проекции можно управлять, что нельзя делать при помощи обычных стримов, там сколько тебе выделила система, столько и жуй.
Этот топик читают: Гость
Разработчик
Ответов: 26163
Рейтинг: 2127
|
|||
карма: 22 |
|
Ответов: 9906
Рейтинг: 351
|
|||
2Netspirit
Size - integer. А я предлагаю НЕ ДЕЛАТЬ ничего. Разницу чувствуете Пока не научились делать так, чтобы не надо было переделывать. Ну не клюет жаренный петух никуда. Чтобы сопровождать с десяток элементов. После "сделать"... И не парится никто. Потому что давно работает все. И мы не обсуждаем способы преодоления проблемы неработающего элемента. Мы другое обсуждаем. ------------ Дoбавленo в 13.35: Netspirit писал(а): Как я понял, в системе суть SharedStream - не работа с большими файлами, а некоторый BufferedFileStreamНеправильно понял |
|||
карма: 9 |
|
Ответов: 4631
Рейтинг: 749
|
|||
nesco писал(а): Быстродействие проекций всегда будет выше работы через системные интерфейсыGalkov писал(а): Мы другое обсуждаемGalkov писал(а): НЕ ДЕЛАТЬ ничего |
|||
карма: 26 |
|
Ответов: 9906
Рейтинг: 351
|
|||
nesco писал(а): А вот количество выделяемых страниц памяти я не стал бы убирать, от этого очень сильно зависит быстродействие всего процессаЧто бы будешь делать у себя у нутре, и что будет видеть пользователь - две большие разницы. Пользователь задал удобный ему Offset и Size. Ты (к примеру!!!) их выравниваешь по гранулярности. Но это твои (пардон - наши) внутренние заморочки, и мы никогда об этом никому не будем рассказывыать. Даже под пытками. Размэпил - ну прибавь ты нужное число к результирующему поинтеру при установке fMemory, чтобы пользователь получил по нулевому смещению именно тот байт, который хотел. И размер для стрима - тот, что задал пользователь, а не "гранулированный". Арифметика же, блин... А вот "гранулировать" размер можно не всегда... Даже если это и быстрее. Если внутри файла - так нет проблем. Если выходим за размер оригинала, то такие шутки кончаются изменением реального размера реального файла. Мне кажется, что это неправильно. ------------ Дoбавленo в 13.53: Де-жа-вю, блин... Все это я уже говорил когда-то давно Не ткну |
|||
карма: 9 |
|
Ответов: 4631
Рейтинг: 749
|
|||
Galkov писал(а): Неправильно понялАргументируй. SharedStream (а точнее, File mapping) - это ... ? |
|||
карма: 26 |
|
Ответов: 9906
Рейтинг: 351
|
|||
Например: инструмент межпроцессной связи.
Самый низкоуровневый (вся остальная фигня у нутре оси на ем и построена) => самый быстрый. "у нас это реализовать" - нельзя. |
|||
карма: 9 |
|
Ответов: 4631
Рейтинг: 749
|
|||
Согласен, что в том числе, для работы нескольких процессов с одними данными.
Ну, а скорость за счет чего достигается? Неужели при работе с обычными файлами система пишет/читает с диска медленнее, чем пишет/читает в том же File mapping? Нет, с диском она работает на той же скорости. Но с той частью, которая в данный момент расположена в памяти - естественно, гораздо быстрее. Данные, ожидающие записи на диск, записываются позже по мере необходимости. Вся эта кухня скрыта и для пользователя всё выглядит, как работа с памятью. Но, тем не менее, MapViewOfFile грузит необходимую часть файла в память, UnmapViewOfFile (а также FlushViewOfFile и FlushFileBuffers) сбрасывают изменения на диск. И чем это отличается от Buffered File Stream (если не стоит задача расшарить между процессами)? И при чем тут большие файлы... ------------ Дoбавленo в 14.26: Вот чисто из любопытства. Есть схемка
|
|||
карма: 26 |
|
Ответов: 9906
Рейтинг: 351
|
|||
Netspirit писал(а): И при чем тут большие файлы...Не причем. Они просто есть, как бесплатное приложение. Но - они ЕСТЬ, даже если ничего не делать. И если придет чел, и скажет: "нет жизни без умения читать содержимого видеоперехвата" -- ему можно ответить: "НА" Я пока помню только один такой случай. Это проще, чем: "можно сделать ТО", "можно сделать ЭТО"... Netspirit писал(а): Ну, а скорость за счет чего достигается?Ну например, за счет того, что для межпроцессного обмена файлы вообще не нужны. Пустое имя (точнее, -1 в качестве хэндла файла) - и все работает. Это не мы так придумали, а мягкотелые. Netspirit писал(а): чтобы можно было удостовериться в скорости.Ну причем тут за рыбу деньги... Какое winApi не применяй - винт быстрее крутиться не станет. Под "быстрее" понималось вот это: nesco писал(а): Быстродействие проекций всегда будет выше работы через системные интерфейсы.Как бы самоочевидное утверждение (без проверок), если принять за правду предыдущее предложение. А это мы с nesco не сами придумали, а прочитали у Рихтера. |
|||
карма: 9 |
|
Ответов: 4631
Рейтинг: 749
|
|||
А это не я придумал:
nesco писал(а): я еще раз повторюсь, что для копирования файлов такой длины кроме SharedStream лучше ничего не использовать. SharedStream использует API низкоуровневого копирования, быстрее которого не копирует уже ничего |
|||
карма: 26 |
|
Разработчик
Ответов: 26163
Рейтинг: 2127
|
|||
Netspirit писал(а): Замутите мне копирование файлаВ справке есть пример копирования, можешь протестировать, там даже время копирования измеряется. Размером количества страниц можно отрегулировать нужное быстродействие, по дефолту буфер около 10 Мб |
|||
карма: 22 |
|
Ответов: 4631
Рейтинг: 749
|
|||
Проверил, действительно копирует значительно быстрее.
[offtop]В примере из справки если не закрывая программу выполнить копирование повторно, конечный файл получается 0-го размера[/offtop] |
|||
карма: 26 |
|
Разработчик
Ответов: 26163
Рейтинг: 2127
|
|||
Netspirit писал(а): В примере из справки если не закрывая программу выполнить копирование повторно, конечный файл получается 0-го размераТолько что проверил и скопировал подряд несколько больших файлов. Скопировалось все нормально, без всяких нулевых файлов |
|||
карма: 22 |
|
Ответов: 4631
Рейтинг: 749
|
|||
Может это у меня что-нибудь, позже посмотрю.
|
|||
карма: 26 |
|
Разработчик
Ответов: 4698
Рейтинг: 426
|
|||
Galkov писал(а): Ты же говоришь, что слово "окно" недоступно для твоего понимания, и предлагаешь "продвинутую технологию" в которой уже не меньше двух элементов.И которая обладает своими ограничениями. Мне то прекрасно понятно, что такое окно, а "продвинутая технология" - это именно IPC, а не работа с огромными файлами (я изначально не учитывал у себя такой вариант использования). Мы с тобой просто предлагаем решения немного разных задач. Galkov писал(а): Кстати, сколько типов "переменных" ты предлагаешь ???На каждый тип своего клиента делать ??? А если размер типа заранее неизвестен (типа dtAnsiString) ??? И наконец, кто сказал, что файл состоит из каких-то "переменных", прости господи... Пользователь ничего не будет знать о типе, как это сделано и в обычном штатном Memory. Для пользователя будет "я делаю doSet у SharedMemory и затем могу в другом приложении из такого же SharedMemory получить записанное значение". А вот к задаче реализации расшаренных именно переменных (а не куска памяти ограниченного размера) как раз и придется подойти инженерно. Нужно ведь обыграть создание именованного ассоциативного массива, расшаренного между приложениями с использованием стандартного FileMapping из WinAPI. Это довольно сложно, поэтому оно останется мечтами. Но почему помечтать-то уж нельзя? |
|||
карма: 10 |
|
Разработчик
Ответов: 26163
Рейтинг: 2127
|
|||
Assasin писал(а): А вот к задаче реализации расшаренных именно переменных (а не куска памяти ограниченного размера) как раз и придется подойти инженерноНафиг еще че-то городить, когда и сейчас работает, как обычный, но межпроцессный стрим, а из него можно читать все, чего угодно |
|||
карма: 22 |
|