использовать параметрическую функцию в потоке в C # - PullRequest
0 голосов
/ 15 августа 2010

привет, это мои многопоточные коды, они отлично работают

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Net;
using System.Threading;

namespace searchIpAdresses
{
    public partial class frmSearchIpRange : Form
    {
        public frmSearchIpRange()
        {
            InitializeComponent();
        }

        int intStartIp, intEndIp;

        private void frmSearchIpRange_Load(object sender, EventArgs e)
        {
            startIp.Text = "0.0.0.0";
            endIp.Text = "0.1.0.0";
            nudThreads.Value = 1;
        }

        private bool calcIpAddressRange()
        {
            intStartIp = IPAddress.NetworkToHostOrder(BitConverter.ToInt32(IPAddress.Parse(startIp.Text).GetAddressBytes(), 0));
            intEndIp = IPAddress.NetworkToHostOrder(BitConverter.ToInt32(IPAddress.Parse(endIp.Text).GetAddressBytes(), 0));
            if (intStartIp>intEndIp)
            {
                MessageBox.Show("End Ip must be bigger than Begin Ip!");
                return false;
            }
            else
            {
                return true;
            }
        }

        private void btnShow_Click(object sender, EventArgs e)
        {
            if (calcIpAddressRange())
            {
                int threadCount = Convert.ToInt32(nudThreads.Value);
                Thread[] threads = new Thread[threadCount];              

                for (int i = 0; i < threadCount; i++)
                {
                    threads[i] = new Thread(new ThreadStart(getPerformance));                  
                    threads[i].Name = string.Format(i.ToString());
                }

                foreach (Thread t in threads)
                {
                    t.Start();
                }

                //for (int i = 0; i < nudThreads.Value; i++)
                //{
                //    if (threads[i].IsAlive)
                //        threads[i].Abort();
                //}
            }

        }

        private void getPerformance()//int sampleStartIp, int sampleEndIp
        {
            if (calcIpAddressRange())
            {
                lbAddress.Items.Clear();
                progressBar1.Maximum = intEndIp - intStartIp;
                int i;
                for (i = intStartIp; i < intEndIp; i++)
                {
                    string ipAddress = new IPAddress(BitConverter.GetBytes(IPAddress.NetworkToHostOrder(i))).ToString();

                    progressBar1.Value++;
                    lbAddress.Items.Add(ipAddress);
                }
                MessageBox.Show(i.ToString() + " addresses added", "Information", MessageBoxButtons.OK, MessageBoxIcon.Information);
                progressBar1.Value = 0;
            }
        }
    }
}

, но я хочу разделить задания в функции getPerformance.поэтому я должен использовать его как

threads[i] = new Thread(new ThreadStart(getPerformance(sampleStart, sampleEnd)))

и т. д. В этом случае Visual Studio выдает ошибку «Ожидается имя метода».что такое решение?

редактировать: я пробовал это, но я не мог приспособить его для работы в формате массива @Henk Holterman

Thread[] threads = new Thread[threadCount];              

                for (int i = 0; i < threadCount; i++)
                {
                    //threads[i] = new Thread(new ThreadStart(getPerformance));                  
                    threads[i].Name = string.Format(i.ToString());

                    Thread t = new Thread(() => getPerformance(intStartIp, intEndIp));
                }

                foreach (Thread t in threads)
                {
                    t.Start();
                }

Ответы [ 2 ]

3 голосов
/ 15 августа 2010

Вы можете использовать ParameterizedThreadStart для передачи объекта в вызываемый метод

3 голосов
/ 15 августа 2010

1) Возможно, вам следует использовать Threadpool или Tasks (Fx4).

2) Когда вы можете использовать делегатов lamba'a (.NET 3 и более поздние версии)

  int a=1, b=2;
  Thread t = new Thread(() => Worker(a, b));

Для более старых версий вы можете использовать ParameterizedThreadStart и вспомогательный объект для хранения Start и End.


Edit для адаптации вашего цикла:

for (int i = 0; i < threadCount; i++)
{
   // some code to update intStartIp, intEndIp 

   //threads[i] = new Thread(new ThreadStart(getPerformance));                  
   threads[i] = new Thread(() => getPerformance(intStartIp, intEndIp));
   threads[i].Name = string.Format(i.ToString());   
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...