|
24 / 24 / 4
Регистрация: 13.03.2011
Сообщений: 326
|
|
Класс лог-файла, как лучше осуществить запись в файл26.06.2012, 16:04. Показов 15037. Ответов 10
Метки нет (Все метки)
Здравствуйте!
Хочу создать класс лог-файла с конструктором, в котором передаваемое значение - путь к файлу. Связь с файлом хотел сделать через StreamWriter. Как это лучше всего сделать? Наследоваться от StreamWriter или можно как-то по-другому? И как правильно наследоваться? У StreamWriter первый конструктор с параметром fileName, и при наследовании у меня выходит ошибка "No overload for method StreamWriter takes 0 arguments". Конструктор разве не наследуется от класса-предка?
0
|
|
| 26.06.2012, 16:04 | |
|
Ответы с готовыми решениями:
10
Программное создание и запись *.xml-файла, как осуществить и где почитать Как осуществить запись(дозапись) в файл в отдельном потоке и закрыть его после записи? Запись лог файла |
|
Администратор
|
|||||||
| 26.06.2012, 16:42 | |||||||
|
Если всё-таки захотите наследовать от StreamWriter, то вот так:
1
|
|||||||
|
24 / 24 / 4
Регистрация: 13.03.2011
Сообщений: 326
|
|
| 26.06.2012, 17:02 [ТС] | |
|
За пример наследования - спасибо!
Насчет другого способа - сразу скажу, что я в ООП мало что понимаю, но я тоже хотел создать отдельный класс, но возникли проблемы с конструктором. Если я создам в конструкторе локальный экземпляр StreamWriter, то он не будет виден в методах класса. Если я захочу создать глобальный экземпляр - то мне надо при его объявлении уже знать путь к файлу для конструктора StreamWriter, а я хочу, чтобы путь задавался в конструкторе моего класса. Получается замкнутый круг... Или нет?
0
|
|
|
713 / 680 / 126
Регистрация: 30.03.2012
Сообщений: 1,124
|
||||||
| 26.06.2012, 17:12 | ||||||
1
|
||||||
|
24 / 24 / 4
Регистрация: 13.03.2011
Сообщений: 326
|
||||||
| 26.06.2012, 17:51 [ТС] | ||||||
|
Не смекнул, что надо new в конструктор спрятать
![]() Спасибо ![]() Добавлено через 31 минуту Вообщем получился вот такой класс
0
|
||||||
|
713 / 680 / 126
Регистрация: 30.03.2012
Сообщений: 1,124
|
|
| 26.06.2012, 17:59 | |
|
очевидно вы пытаетесь создать 2й файл с тем же именем не убив 1й streamwriter который в него что то пишет
либо закрывайте этот streamwriter сразу же по нажатию этой же кнопки (в начале кнопки создали, в конце - убили) либо разнесите действия создания файла и записи строк в него на разные кнопки
1
|
|
|
24 / 24 / 4
Регистрация: 13.03.2011
Сообщений: 326
|
|||||||
| 26.06.2012, 18:07 [ТС] | |||||||
0
|
|||||||
|
713 / 680 / 126
Регистрация: 30.03.2012
Сообщений: 1,124
|
|
| 26.06.2012, 18:48 | |
|
сборка мусора в c# происходит время от времени, а не сразу по завершении использования объекта
если вы нажмете кнопку через час вероятнее всего она уже произойдет, но рассчитывать на это не надо, лучше закрывайте ручками )
1
|
|
|
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
|
|
| 26.06.2012, 20:30 | |
|
У меня есть аналогичный класс.
Логи получаются большие, поэтому когда файл достигает заданного настройками размера, я его закрываю и создаю следующий. Соответственно в имени файла есть часть, представляющая из себя порядковый номер фрагмента лога. В связи с этим создание потока я вынес из конструктора в отдельный метод, который вызываю 1) в конструкторе 2) в методе добавления записи в лог, если проверка покажет, что мы достигли заданного размера, либо превысили его. Старый закрываю, новый создаю в том же свойстве. Кроме того, имеет смысл вывести класс логгера из интерфейса IDisposable, реализовав в методе Dispose закрытие потока. Это стилистически грамотный подход, позволяющий общепринятым способом закрыть поток при высвобождении ресурсов. При закрытии приложения пишем Logger_31.Dispose(); Так же использование логгера в юзинге тоже может пригодиться.
1
|
|
|
24 / 24 / 4
Регистрация: 13.03.2011
Сообщений: 326
|
|
| 26.06.2012, 22:08 [ТС] | |
|
С первой частью все понятно - уже почти создал подобное.
Ко второй у меня есть парочка вопросов :1) Есть ли функциональный смысл реализовывать метод Dispose() через IDisposable, если я использую StreamWriter, и спокойно могу вызывать его метод Close() ? 2) Я вот тут написал деструктор, вызывающий метод Close() - а есть ли в этом смысл? - где-то читал, что это замедляет работу GC. 3) Using используете только при создании/открытии потока?
0
|
|
|
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
|
|
| 27.06.2012, 05:41 | |
|
1) Close of StreamWriter вызывается в Dispose of Logger. Чтобы не делать StreamWriter публиком. Чтобы не делать StreamWriter.Close() снаружи.
2) GC будет столько же работать. Просто может прийти раньше или позднее. Память отдаётся GC сразу после Flush либо после Write если AutoFlush. К тому же если речь идёт о завершении работы приложения GC уже не будет дефрагментировать его память (тут основные тормоза бывают), а просто вернёт системе всю память как есть. 3) Имелись в виду каскадные юзинги например в тестах. Иногда это удобно. Обычно я их не применяю.
1
|
|
| 27.06.2012, 05:41 | |
|
Помогаю со студенческими работами здесь
11
Проверка на существование строки, запись в лог-файл Бинарное дерево поиска. Как осуществить запись в файл и чтение из файла
Как осуществить запись пути который указывается через FolderBrowserDialog в .ini файл Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам
Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
|
Сукцессия микоризы: основная теория в виде двух уравнений.
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
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
|