Как запустить 2 потока в программе - PullRequest
0 голосов
/ 28 августа 2018

Вот мой код. Я хочу добиться многопоточности. Я хочу сказать, что я хочу, чтобы первый поток выполнялся первым. Через некоторое время, завершил ли поток 1 задачу или не вернулся из нее и выполнил поток 2. Через некоторое время перейдите к Как это сделать. Я попытался присоединить метод здесь, но безрезультатно.

private void ThreadCreate()
{
    try
    {                        
        Print  thr1 = new Print("First Thread : Service Started ");
        Print  thr2 = new Print("Seconf Thread : Service Started");

        Thread thread1 = new Thread(new ThreadStart(thr1.TextLog));
        Thread thread2 = new Thread(new ThreadStart(thr2.TextLog));

        thread1.Name = "Thread1";
        thread2.Name = "Thread2";

        thread1.Start();              
        thread2.Start();

        thread1.Join(1000);
        thread2.Join(1000);
    }
    catch (Exception ex)
    {
    }
}

///// Part2 
class Print
{
    public string apppath = System.AppDomain.CurrentDomain.BaseDirectory.ToString();    
    string _message;

    public Print(string message)
    {
        this_message = message;
    }

    public void TextLog()
    {
        try
        {
            StreamWriter sw;
            FileInfo f;
            Thread thr = Thread.CurrentThread;
            int j = 0;


            string s = apppath + " Print " + DateTime.Today.ToString("dd-MM-yyyy") + ".txt";

            f = new FileInfo(s);
            if (f.Exists)
            {
                sw = f.AppendText();
            }
            else
            {
                sw = f.CreateText();
                sw.WriteLine();
            }
            sw.WriteLine("-----------------------------------------------------------------");
            sw.WriteLine(_msg + "    " + DateTime.Now.ToString("yyyy.MM.dd HH:mm:ss:ffff"));

            if (_msg == "Service Stopped ...............")
            {

            }
            else
            {
                for (int i = 0; i < 10; i++)
                {
                    Thread thr2 = Thread.CurrentThread;
                    if (thr2.Name == "Thread1")
                    {
                        sw.WriteLine(thr2.Name + " : " + i + "    " + DateTime.Now.ToString("yyyy.MM.dd HH:mm:ss:ffff"));
                    }
                    else
                    {
                        sw.WriteLine(thr2.Name + " ::: " + i + "    " + DateTime.Now.ToString("yyyy.MM.dd HH:mm:ss:ffff"));
                    }

                    j = j + 1;
                    sw.WriteLine("Thread will sleep now -----------------------------------------------------------------");
                    Thread.Sleep(1000);
                    sw.WriteLine("Thread came out from sleeping -----------------------------------------------------------------");
                }
            }
            sw.Close();
        }
        catch (Exception e)
        {
            _message = e.Message;               
        }
    }
}

Я получаю вывод, как это. Выход:

----------------------------------------------------------------
First Thread : Service Started     2018.08.28 12:32:10:1123
Thread1 : 0    2018.08.28 12:32:10:1123
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 1    2018.08.28 12:32:11:1279
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 2    2018.08.28 12:32:12:1436
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 3    2018.08.28 12:32:13:1593
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 4    2018.08.28 12:32:14:1750
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 5    2018.08.28 12:32:15:1907
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 6    2018.08.28 12:32:16:2063
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 7    2018.08.28 12:32:17:2220
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 8    2018.08.28 12:32:18:2377
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 9    2018.08.28 12:32:19:2534
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
-----------------------------------------------------------------
First Thread : Service Started     2018.08.28 12:33:00:1499
Thread1 : 0    2018.08.28 12:33:00:1499
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 1    2018.08.28 12:33:01:1656
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 2    2018.08.28 12:33:02:1813
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 3    2018.08.28 12:33:03:1969
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping --------------------------------------

Здесь первый поток выполняется первым, а первый поток запускается. Я не вывожу так.

Ожидаемый результат:

-----------------------------------------------------------------
First Thread : Service Started     2018.08.28 12:32:10:1123
Thread1 : 0    2018.08.28 12:32:10:1123
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 1    2018.08.28 12:32:11:1279
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 2    2018.08.28 12:32:12:1436
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread2 : 0    2018.08.28 12:32:13:1593
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread2 : 1    2018.08.28 12:32:14:1750
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 3    2018.08.28 12:32:15:1907
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread1 : 4    2018.08.28 12:32:16:2063
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------
Thread2 : 2    2018.08.28 12:32:17:2220
Thread will sleep now -----------------------------------------------------------------
Thread came out from sleeping -----------------------------------------------------------------

1 Ответ

0 голосов
/ 28 августа 2018

Как видно из выходного журнала, между событиями «Служба запущена» около 50 секунд. Я думаю, что они происходят из двух разных прогонов вашего приложения.

Другое дело, почему вы не получаете вывод из Thread2. Это потому, что ваш Thread1 получил эксклюзивный доступ к файлу журнала. Поток 2 пытается получить доступ к файлу, получает исключение (IOException), поскольку файл используется, но нет способа зарегистрировать это исключение, поэтому поток тихо умирает.

Если вы хотите записать информацию в свой журнал из нескольких потоков, вам нужно синхронизировать доступ к файлу. Я бы предложил создать специальный класс для этого. Нечто подобное (самое простое, только для демонстрационных целей):

public static class Log1
{
    private static string filePath;
    private static object syncRoot = new object();

    public static void WriteLine(string m)
    {
        lock (syncRoot)
        {
            if (string.IsNullOrEmpty(filePath))
            {
                filePath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), "test20");
                Directory.CreateDirectory(filePath);
                filePath = Path.Combine(filePath, "Print_" + DateTime.Today.ToString("dd-MM-yyyy") + ".txt");
            }
            File.AppendAllText(filePath, m + Environment.NewLine);
        }
    }
}

Тогда ваш метод потока превращается в:

    public void TextLog()
    {
        try
        {
            Thread thr = Thread.CurrentThread;
            int j = 0;

            Log1.WriteLine("-----------------------------------------------------------------");
            Log1.WriteLine(_message + "    " + DateTime.Now.ToString("yyyy.MM.dd HH:mm:ss:ffff"));

            if (_message == "Service Stopped ...............")
            {

            }
            else
            {
                for (int i = 0; i < 10; i++)
                {
                    Thread thr2 = Thread.CurrentThread;
                    if (thr2.Name == "Thread1")
                    {
                        Log1.WriteLine(thr2.Name + " : " + i + "    " + DateTime.Now.ToString("yyyy.MM.dd HH:mm:ss:ffff"));
                    }
                    else
                    {
                        Log1.WriteLine(thr2.Name + " ::: " + i + "    " + DateTime.Now.ToString("yyyy.MM.dd HH:mm:ss:ffff"));
                    }

                    j = j + 1;
                    Log1.WriteLine("Thread will sleep now -----------------------------------------------------------------");
                    Thread.Sleep(1000);
                    Log1.WriteLine("Thread came out from sleeping -----------------------------------------------------------------");
                }
            }
        }
        catch (Exception e)
        {
            _message = e.Message;
            Log1.WriteLine(e.ToString());
        }
    }

, который эффективно производит что-то вроде:

-----------------------------------------------------------------
-----------------------------------------------------------------
Seconf Thread : Service Started    2018.08.28 10:27:19:8441
Thread2 ::: 0    2018.08.28 10:27:19:8491
Thread will sleep now         
-----------------------------------------------------------------
First Thread : Service Started     2018.08.28 10:27:19:8402
Thread1 : 0    2018.08.28 10:27:19:8691
Thread will sleep now    
-----------------------------------------------------------------
Thread came out from sleeping     
-----------------------------------------------------------------
Thread2 ::: 1    2018.08.28 10:27:20:8665
Thread will sleep now 
...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...