Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.68/22: Рейтинг темы: голосов - 22, средняя оценка - 4.68
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 6

Логирование

30.06.2010, 01:12. Показов 4443. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Срочно нужна ваша помощь.

Нужно чтобы ЭТО запускалось в отдельном потоке. Чтобы остальная часть программы, вызывающая этот класс, не ждала его выполнения, а просто передавала ему значения.

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
public class TxtLogger : ILogger
    {
        private FileStream f1;
        private StreamWriter output;
        protected string FileName = Environment.GetFolderPath(Environment.SpecialFolder.DesktopDirectory) + "\\Folder\\Output1.txt";
        protected string CurrentLogText;
        protected ThreadStart myThreadDelegate;
        protected Thread thr;
        public TxtLogger()
        {
            f1 = new FileStream(FileName, FileMode.Append);
            output = new StreamWriter(f1);
        }
        public void Log(string message, MessageType messageType)
        {
            lock (this)
            {
                CurrentLogText = "Message text: " + message + ", " + DateTime.Now.ToString() + ", Type: " + messageType;
                output.WriteLine(CurrentLogText);
                f1.Flush();
                output.Flush();
            }
        }
    }
Сверху описано:

C#
1
2
3
4
        protected ILogger lg1 = new TxtLogger();
        protected ILogger lg2 = new XmlLogger();
        protected ILogger lg3 = new DbLogger();
        protected MessageGenerator[] arr;
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  arr = new MessageGenerator[numberOfGen];
                    
                    for (int c = 0; c < arr.Length; c++)
                    {
                        arr[c] = new MessageGenerator(numberOfGen, mseconds);
                        if (checkBox1.Checked)
                        {
                            arr[c].MessageGeneratedEvent += new MessageGenerator.MyDelegate(lg1.Log);
                        }
                        if (checkBox2.Checked)
                            arr[c].MessageGeneratedEvent += new MessageGenerator.MyDelegate(lg2.Log);
                        if (checkBox3.Checked)
                            arr[c].MessageGeneratedEvent += new MessageGenerator.MyDelegate(lg3.Log);
                        arr[c].go();                      
                    }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.06.2010, 01:12
Ответы с готовыми решениями:

Логирование
Добрый день. есть ф-ция которая пишел лог файл на диск, когда запускается программа. Как сделать чтобы файл с логом перезаписывался когда...

Логирование и #if
Здравствуйте. Возникла ситуация: Код у меня работает как надо, а у клиента падает. Обращаюсь за советом к своему руководителю. Он отписал...

Логирование
Привет всем! Пишу клиент серверное приложение Хочу что бы все действия выводились в Richtextbox Как это правильно реализовать ...

3
 Аватар для IICuX
87 / 87 / 26
Регистрация: 04.01.2010
Сообщений: 270
30.06.2010, 01:19
вы итак используете потоки т.е. StreamWriter - Stream - поток, но если очень надо

C#
1
2
Thread t = new Thread(Method);
t.Start();
0
0 / 0 / 0
Регистрация: 30.06.2010
Сообщений: 6
30.06.2010, 10:59  [ТС]
Смотрите, здесь метод Log с параметрами. Можно, пожалуйста, пример.
0
4 / 4 / 2
Регистрация: 17.04.2010
Сообщений: 55
09.07.2010, 20:22
почему нельзя использовать BackgroundWorker? по нему в мсдн куча хелпа, он достаточно удобен.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.07.2010, 20:22
Помогаю со студенческими работами здесь

Логирование времени
Подскажите как правильно организовать логику, нужно логировать время ПК каждые пол часа и хранить данные за последние 4 дня, перезаписывая...

Логирование консоли в файл
Люди, нужна помощь в создании лог файла для консоли. Имею простой код консоли... static void Main(string args) { ...

Логирование и сохранение настроек
Подскажите хорошие библиотеки для логирования и сохранения настроек, без особых наворотов.

Логирование многопоточной службы
Добрый день! давеча думала я как бы мне соорудить логирование своей службы многопоточной. Вздумала она ошибки выдавать, да работать с...

Логирование http запросов
Доброго времени суток! Подскажите, пожалуйста, новичку в C#. У меня программа зависима от ответов сервера, проблема в том что иногда...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью в конфигурации КА2. Данные берутся из регистра сведений, по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru