|
Темная сторона .Net
592 / 489 / 39
Регистрация: 21.07.2012
Сообщений: 1,668
|
|
Портится ли диск при порциональном считывании байт из файла05.08.2012, 12:51. Показов 1868. Ответов 14
Метки нет (Все метки)
Если я читаю binaryReader"ом по 30-50 байтов файлы больше метра я сильно порчу диск?
Будет ли лучше считать сразу все в поток памяти а потом уже "деребанить" байты куда нужно?
0
|
|
| 05.08.2012, 12:51 | |
|
Ответы с готовыми решениями:
14
Вылетает жесткий диск при записи/считывании При считывании текста из файла, при нахождении пробела или enter ставится пробел Проблема при считывании из файла |
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|
| 05.08.2012, 12:59 | |
|
Декораторы используют буферизацию, потому особо сильно дербанить не дадут.
1
|
|
|
Темная сторона .Net
592 / 489 / 39
Регистрация: 21.07.2012
Сообщений: 1,668
|
|
| 05.08.2012, 13:51 [ТС] | |
|
Немного сложно объяснили для меня.Или это мой вопрос спровоцировал такой ответ.
Не лучше ли будет читать весь файл целиком,залить в память,а с нее уже по частям,насколько мне известно я могу читать побайтно из потока памяти,а большего мне и не нужно. после того как я распределю байты куда нужно(копиями или любыми другими способами) MemoryStream выйдет из области видимости using. Или же частями читая,жесткий не так и приходить в негодность? Я не собираюсь удалят,изменять или еще что-то делать с потоком(так как он и сам не разрешит) Мне интересно в каком из 2 случаев износ будет больше. Читать 100кб по 50 байт или 100кб сразу в память Имеет ли это значение и насколько важное..
0
|
|
|
20 / 20 / 0
Регистрация: 05.02.2011
Сообщений: 65
|
|
| 05.08.2012, 14:01 | |
|
Теоретически в первом будет износ больше. Но если я не ошибаюсь чтение с диска не оказывает на диск никакой негативной нагрузки, способствующей к её износу.
1
|
|
|
Темная сторона .Net
592 / 489 / 39
Регистрация: 21.07.2012
Сообщений: 1,668
|
|
| 05.08.2012, 14:12 [ТС] | |
|
0
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|
| 05.08.2012, 16:08 | |
|
Noob.net, объясню проще: класс BinaryReader считывает информацию из файла во внутренний буфер кусками по 4Кб, а по вашему запросу уже считывает из буфера, который находится в основной памяти. Так что если вы считываете по 50 байтов, то диску от этого ни тепло, ни холодно - BinaryReader все равно будет считывать кусками по 4Кб.
1
|
|
|
Темная сторона .Net
592 / 489 / 39
Регистрация: 21.07.2012
Сообщений: 1,668
|
|
| 05.08.2012, 16:27 [ТС] | |
|
понял) о буфере знал,но как именно что происходит нет)
0
|
|
|
20 / 20 / 0
Регистрация: 05.02.2011
Сообщений: 65
|
||
| 05.08.2012, 16:44 | ||
|
Добавлено через 2 минуты А что касается работы с файлами, то ув. kolorotur всё правильно объяснил, простыми словами содержимое файла на время работы с ним буферизируется в память.
1
|
||
|
Темная сторона .Net
592 / 489 / 39
Регистрация: 21.07.2012
Сообщений: 1,668
|
|
| 05.08.2012, 18:51 [ТС] | |
|
0
|
|
|
Почетный модератор
|
|
| 05.08.2012, 19:58 | |
|
Noob.net, http://msdn.microsoft.com/ru-r... d7x6t.aspx - 4-й параметр.
Оптимальным считается размер буфера кратный размеру кластера на диске. В настоящий момент для большинства задач размер буфера не имеет сильное значение, т.к. при неравномерном чтении система будет просто кэшировать данные с диска.
1
|
|
|
Темная сторона .Net
592 / 489 / 39
Регистрация: 21.07.2012
Сообщений: 1,668
|
||
| 05.08.2012, 20:02 [ТС] | ||
|
Добавлено через 51 секунду Все понял) кратный,тоесть 4-8-16 и т.д. Но это все относительно кластера.
0
|
||
|
В экстазе
|
||
| 05.08.2012, 23:01 | ||
|
Говоря более простым языком, файл на жесткий диск записывает в момент сброса буфера винчестера, а не в момент нажатия кнопки "сохранить". *если речь идёт о файлах сравнительно небольшого размера, менее чем размер буфера. Для чтения файла - аналогично то же самое. Пример: если Вы считываете 4 байта из файла, а потом ещё 4, а потом ещё 4... не сложно заметить, что обращение к винчестеру, до какого-то времени будет лишь одно, до какого-то момента. Проще говоря, при попытке считать 4 байта из какого-либо файла, в буфер HDD считывается не =4 байта, а какой-то кусок файла сразу, затем, из этого буфера мы можем читать информацию дальше. Конкретно заморачитваться со считыванием всего файла сразу, есть смысл, когда на жесткий диск идёт непрерывная нагрузка, и он что-то постоянно читает/пишет. Такой подход пожалуй позволит сэкономить время, и не "дёргать" жесткий диск по каждому байту. Так же, из опыта низкоуровневого программирования, скажу, что обрабатывать каждый байт в отдельности - мало производительное занятие. Гораздо быстрее файл читать блоками. В ответ на конкретно Ваш вопрос: жесткий диск, от чтения файлов даже по одному байту, НЕ ПОРТИТСЯ. Причина тому, банально проста. Реестр (я имею в виду, его маленькую часть), файлы ini, куки и множество другой информации и конфигов - представляют из себя очень маленькие текстовые файлы, которые постоянно читаются/пишутся на жесткий диск. За последние 4 года эксплуатации жесткий дисков, а так же массивов из HDD как в серверных машинах, так и машинах настольного уровня, на данный момент ничего не испортилось. В linux/unix же, вообще, вся система "держится" на множестве мелких конфигурационных файлов, которые тоже, постоянно читаются. И не только linux/unix! Возьмем в пример любой веб-сайт. Не редко он состоит из множества файлов, размер которых от нескольких байт, до нескольких килобайт. И файлов этих, обычно сотни или даже тысячи. Эти файлы читаются постоянно. И, ничего, как мы видим не испортилось. В нашем же случае, речь идёт о чтении лишь одного файла. По этому, мой Вам совет - хотите читать файл по 1-му байту? Читайте и не заморачивайтесь Хотя на мой взгляд, конечно удобнее открыть файл в файловом потоке (FileStream) а затем читать данные оттуда блоками любого количества (хоть байт, хоть два, хоть...).Ответ достаточно исчерпывающий? ![]() Добавлено через 24 минуты P.S. Считать поток в файл, а уже потом дербанить его куда надо - будет гораздо более производительнее, нежели чем читать его постоянно по 30-50 байт. За "порчу" диска можно не беспокоиться.
2
|
||
| 05.08.2012, 23:22 [ТС] | |
|
Не по теме: Ты мой герой
0
|
|
|
В экстазе
|
|
| 05.08.2012, 23:37 | |
|
Noob.net, наиболее точный и лаконичный ответ написан сразу после "P.S.", всё что выше - можно проигнорировать, там лишь более подробное разъяснение происходящих процессов и некоторые доводы основанные на личном опыте и тестах.
0
|
|
|
Темная сторона .Net
592 / 489 / 39
Регистрация: 21.07.2012
Сообщений: 1,668
|
|
| 06.08.2012, 10:11 [ТС] | |
|
0
|
|
| 06.08.2012, 10:11 | |
|
Помогаю со студенческими работами здесь
15
Ошибка при считывании из файла Кракозябры при считывании с файла Ошибка при считывании из файла Переполнение при считывании из файла Ошибка при считывании файла Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11
— это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
|
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11
Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
|
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
|
|
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/
O1rJuneU_ls
https:/ / vkvideo. ru/ video-115721503_456239114
|
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ВВЕДЕНИЕ
Введу сокращения:
аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
|
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi
ветка по-частям.
коммит Create переделка под биомассу. txt
вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
|
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ *
Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во
всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
|