问题:
我在一个子窗体中创建了三个线程,分别读取一个PLC的50个标签,一共150个,当我把子窗体打开时开始读取,当把子窗体关闭后停止读取,再次打开时又重新开始读取。
第一次打开时速度(ms)是这样的:
第二次就变成了这样:
时间差不多翻了一倍,开关子窗体的次数越多越慢。
循环读取数据的代码如下:
一共三个,这里只放一个,另外两个是差不多的
private async void ReadPlcData1()
{
while (true)
{
try
{
stopwatch1 = Stopwatch.StartNew();
plcData1[0] = await readOmronData.ReadOneOmronData(FrmMain.omronCipNet1, "s_SysStrip1.Status.Homed", "BOOL");
plcData1[1] = await readOmronData.ReadOneOmronData(FrmMain.omronCipNet1, "s_SysStrip1.Status.Homing", "BOOL");
plcData1[2] = await readOmronData.ReadOneOmronData(FrmMain.omronCip