Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.66/71: Рейтинг темы: голосов - 71, средняя оценка - 4.66
 Аватар для Lupus
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
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.06.2012, 16:04
Ответы с готовыми решениями:

Программное создание и запись *.xml-файла, как осуществить и где почитать
Здравствуйте! Подскажите как программно записать *.xml файл? В самой программе много разных контролов будет, ну вот к примеру как создать...

Как осуществить запись(дозапись) в файл в отдельном потоке и закрыть его после записи?
Здравствуйте! Вопрос в названии темы! Подробнее планирую записывать(дозаписывать) в файл массив double doubleArray. Этот массив будет...

Запись лог файла
Доброго времени суток, есть программа которая сниферит сетевую карту. события приходят в виде }] }] }] |psh}] }] |psh}] ...

10
Администратор
Эксперт .NET
 Аватар для tezaurismosis
9673 / 4825 / 763
Регистрация: 17.04.2012
Сообщений: 9,664
Записей в блоге: 14
26.06.2012, 16:42
Цитата Сообщение от Lupus Посмотреть сообщение
Как это лучше всего сделать? Наследоваться от StreamWriter или можно как-то по-другому?
На мой взгляд, лучше сделать отдельный новый класс, а не наследовать его от StreamWriter, класс-потомок должен расширять своего родителя новыми возможностями, а в этом случае получается совсем другой по назначению класс; типа как развитием айфона бы стал телевизор, дисплей то же есть, но назначение другое. Но это ИМХО
Если всё-таки захотите наследовать от StreamWriter, то вот так:
C#
1
2
3
4
5
6
public class LogFile : StreamWriter
{
    public LogFile(string fileName) : base(fileName) {
        // ...
    }
}
1
 Аватар для Lupus
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
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
    public class LogFile
    {
        StreamWriter sw;
 
        public LogFile(string path)
        {
            sw = new StreamWriter(path);
        }
 
        public void WriteLine(string str)
        {
            sw.WriteLine(str);
            sw.Flush();
        }
    }
    class Program
    {
        static void Main(string[] args)
        {
            var lf = new LogFile(@"C:\1.txt");
            lf.WriteLine("123");
        }
    }
что не так?
1
 Аватар для Lupus
24 / 24 / 4
Регистрация: 13.03.2011
Сообщений: 326
26.06.2012, 17:51  [ТС]
Не смекнул, что надо new в конструктор спрятать
Спасибо

Добавлено через 31 минуту
Вообщем получился вот такой класс
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
class LogFile
    {
        private System.IO.StreamWriter sw;
 
        public LogFile(string path)
        {
            try
            {
                sw = new System.IO.StreamWriter(path + ".log", true, Encoding.UTF8);
            }
            catch (System.IO.IOException e)
            {
                System.Windows.Forms.MessageBox.Show(e.ToString());
            }
        }
        ~LogFile()
        {
            sw.Close();
        }
 
        public void writeLogLine(string line)
        {
            DateTime presently = DateTime.Now;
            line = presently.ToString() + " - " + line;
            sw.WriteLine(line);
            sw.Flush();
        }
    }
Поставил на нажатие кнопки создание файла. При первом нажатии все нормально, при повторном - вылетает исключение о том, что файл занят другим процессом. Что не так делаю?
0
713 / 680 / 126
Регистрация: 30.03.2012
Сообщений: 1,124
26.06.2012, 17:59
очевидно вы пытаетесь создать 2й файл с тем же именем не убив 1й streamwriter который в него что то пишет
либо закрывайте этот streamwriter сразу же по нажатию этой же кнопки (в начале кнопки создали, в конце - убили) либо разнесите действия создания файла и записи строк в него на разные кнопки
1
 Аватар для Lupus
24 / 24 / 4
Регистрация: 13.03.2011
Сообщений: 326
26.06.2012, 18:07  [ТС]
Цитата Сообщение от Tessen Посмотреть сообщение
очевидно вы пытаетесь создать 2й файл с тем же именем не убив 1й streamwriter который в него что то пишет
либо закрывайте этот streamwriter сразу же по нажатию этой же кнопки (в начале кнопки создали, в конце - убили) либо разнесите действия создания файла и записи строк в него на разные кнопки
А разве, после завершения события "нажатие кнопки" не должен вызваться деструктор экземпляра?
C#
1
2
3
4
5
private void button1_Click(object sender, EventArgs e)
        {
            LogFile Log = new LogFile("asdjijsdoj");
            Log.writeLogLine("Программа запущена!");
        }
0
713 / 680 / 126
Регистрация: 30.03.2012
Сообщений: 1,124
26.06.2012, 18:48
сборка мусора в c# происходит время от времени, а не сразу по завершении использования объекта
если вы нажмете кнопку через час вероятнее всего она уже произойдет, но рассчитывать на это не надо, лучше закрывайте ручками )
1
 Аватар для ksk
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
26.06.2012, 20:30
У меня есть аналогичный класс.

Логи получаются большие, поэтому когда файл достигает заданного настройками размера, я его закрываю и создаю следующий. Соответственно в имени файла есть часть, представляющая из себя порядковый номер фрагмента лога.

В связи с этим создание потока я вынес из конструктора в отдельный метод, который вызываю
1) в конструкторе
2) в методе добавления записи в лог, если проверка покажет, что мы достигли заданного размера, либо превысили его. Старый закрываю, новый создаю в том же свойстве.

Кроме того, имеет смысл вывести класс логгера из интерфейса IDisposable, реализовав в методе Dispose закрытие потока. Это стилистически грамотный подход, позволяющий общепринятым способом закрыть поток при высвобождении ресурсов. При закрытии приложения пишем Logger_31.Dispose(); Так же использование логгера в юзинге тоже может пригодиться.
1
 Аватар для Lupus
24 / 24 / 4
Регистрация: 13.03.2011
Сообщений: 326
26.06.2012, 22:08  [ТС]
С первой частью все понятно - уже почти создал подобное.
Ко второй у меня есть парочка вопросов :
1) Есть ли функциональный смысл реализовывать метод Dispose() через IDisposable, если я использую StreamWriter, и спокойно могу вызывать его метод Close() ?
2) Я вот тут написал деструктор, вызывающий метод Close() - а есть ли в этом смысл? - где-то читал, что это замедляет работу GC.
3) Using используете только при создании/открытии потока?
0
 Аватар для ksk
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.06.2012, 05:41
Помогаю со студенческими работами здесь

Проверка на существование строки, запись в лог-файл
Здравствуйте! Имеется файл excel и база данных, перебрасываю из файла в таблицу базы. Делаю запись в лог-файл строк, которые были...

Бинарное дерево поиска. Как осуществить запись в файл и чтение из файла
Добрый день! Если кому не жаль своего времени окажите помощь! Необходимо осуществить запись в файл,просмотр содержимого файла, и создание...

Как правильно осуществить запись с файла в stringstream и обратно?
Есть программа, которая должна осуществлять открытие не пустого текстового файла, далее содержимое файла должно шифроваться, после...

Как осуществить запись в файл bin и как прочитать всё, что в нём есть
Добрый день.Подскажите как осуществить запись в файл bin и как прочитать всё,что в нём есть.Заранее благодарен.

Как осуществить запись пути который указывается через FolderBrowserDialog в .ini файл
Товарищи, прошу Вашей помощи в моем вопросе. Возникла необходимость хранить настройки утилиты в .ini файле. Проведя некоторое время в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
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
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru