Member 14589606 Ответов: 2

Можно считывать только одно температурное считывание с процессора датчика, для других датчиков оно не работает


За один раз с датчика можно снять только одно значение. Я использовал концепцию асинхронных сокетов, то есть он считывает только температуру процессора одного датчика за один раз. Когда вы добавляете больше, это показывает, что есть ошибка. Любые идеи будут оценены по достоинству.

После выполнения заданий все потоки успешно запустились, а затем возникла проблема при инициализации для 2-го датчика, отображающая "Error TemperatureMesurement-Job initialization 4_cam2_temperature:обычно каждый адрес сокета (протокол, сетевой адрес или соединение) может быть использован только один раз"(ссылка на initializejob вверху), а затем проблема в requestdata() для датчика 2, указывающая "Error TemperatureMesurement-Job requestData 4_cam2_temperature:ссылка на объект не была установлена на экземпляр объекта". Используемый класс исключений-это класс System.exception.

И только с помощью temperatureGauge.udp, а не temperatureGauge.GMH3700. Он запрашивает температуру только у определенного датчика, а не у других, как показано в коде ASCII –

Чтобы сделать его простым, проблема в основном здесь:
Тот показывает сообщение об ошибке:
"Ошибка TemperatureMesurement-инициализация задания 4_cam2_temperature:обычно каждый адрес сокета (протокол, сетевой адрес или соединение) может быть использован только один раз"

public override void initializeJob()
{
try
{
if (TempDevice == temperatureGauge.udp)
{
camIP = parameters[0];
socketCmdText = new UdpClient(cmdTextPort);
socketCmdText.BeginReceive(new AsyncCallback(OnUdpDataCmdText), socketCmdText);
socketCmd = new UdpClient(cmdPort);
socketCmd.BeginReceive(new AsyncCallback(OnUdpDataCmd), socketCmd);
}
if (TempDevice == temperatureGauge.GMH3700)
{
PortGMH3700.PortName = ComPortbyUser;
PortGMH3700.BaudRate = 4800; /* Baudrate '4800' oder '38400' */
PortGMH3700.Parity = Parity.None;
PortGMH3700.DataBits = 8;
PortGMH3700.StopBits = StopBits.One;
PortGMH3700.DtrEnable = true;
PortGMH3700.RtsEnable = false;
PortGMH3700.Open();
}
}
catch (Exception e)
{
Console.WriteLine("Error TemperatureMesurement-Job initialization " + jobName + " : " + e.Message);
}




Тот показывает сообщение об ошибке:
""Ошибка TemperatureMesurement-Job requestData 4_cam2_temperature:ссылка на объект не была установлена на экземпляр объекта"

private void requestData()
{
try
{
IPAddress _camip = IPAddress.Parse(camIP);
IPEndPoint _ep = new IPEndPoint(_camip, cmdTextPort);
byte[] _sendbuf = Encoding.ASCII.GetBytes("Cmd_ISL_GetCurrentSensorTemperature");
socketCmdText.Send(_sendbuf, _sendbuf.Length, _ep);
    byte[] _sendbuf2 = Encoding.ASCII.GetBytes("Get_Temp");
    socketCmdText.Send(_sendbuf2, _sendbuf2.Length, _ep);
    /*
    byte[] _sendbuf3 = Encoding.ASCII.GetBytes("APP_Version");
    socketCmdText.Send(_sendbuf3, _sendbuf3.Length, _ep);

    IPEndPoint _ep2 = new IPEndPoint(_camip, cmdPort);
    Byte[] _sendbuf4 = { 0x02, 0x00, 0x00, 0x10, 0x01, 0x00, 0x00, 0x00, 0xED };
    socketCmd.Send(_sendbuf4, _sendbuf4.Length, _ep2);
    */
}
catch (Exception e)
{
    Console.WriteLine("Error TemperatureMesurement-Job requestData " + jobName + " : " + e.Message);
}


Что я уже пробовал:

Любые идеи будут оценены по достоинству. Спасибо

2 Ответов

Рейтинг:
2

OriginalGriff

Цитата:
Ссылка на объект не была установлена на экземпляр объекта

Это одна из самых распространенных проблем, которые нам задают, и это также та, на которую мы меньше всего готовы ответить, но вы больше всего готовы ответить сами.

Позвольте мне просто объяснить, что означает ошибка: вы пытались использовать переменную, свойство или возвращаемое значение метода, но оно содержит null - что означает, что в переменной нет экземпляра класса.
Это немного похоже на карман: у вас есть карман в рубашке, который вы используете, чтобы держать ручку. Если вы сунете руку в карман и обнаружите, что там нет ручки, вы не сможете подписать свое имя на листе бумаги - и вы получите очень смешные взгляды, если попытаетесь! Пустой карман дает вам нулевое значение (здесь нет ручки!), поэтому вы не можете сделать ничего, что обычно делали бы, когда вы извлекли свою ручку. Почему он пуст? Вот в чем вопрос - может быть, вы забыли взять ручку, когда уходили из дома сегодня утром, или, возможно, вы оставили ручку в кармане вчерашней рубашки, когда снимали ее вчера вечером.

Мы не можем сказать, потому что нас там не было, и, что еще важнее, мы даже не можем видеть вашу рубашку, не говоря уже о том, что находится в кармане!

Вернемся к компьютерам, и вы каким - то образом сделали то же самое-и мы не можем увидеть ваш код, а тем более запустить его и узнать, что содержит null, когда это не должно быть.
Но вы можете - и Visual Studio поможет вам здесь. Запустите свою программу в отладчике, и когда она выйдет из строя, VS покажет вам строку, в которой она обнаружила проблему. Затем вы можете начать просматривать различные его части, чтобы увидеть, какое значение равно null, и начать просматривать свой код, чтобы узнать, почему. Поэтому поставьте точку останова в начале метода, содержащего строку ошибки, и снова запустите программу с самого начала. На этот раз VS остановится перед ошибкой и позволит вам изучить, что происходит, пройдя через код, глядя на ваши значения.

Но мы не можем этого сделать - у нас нет вашего кода, мы не знаем, как его использовать, если бы он у нас был, у нас нет ваших данных. Так что попробуйте - и посмотрите, сколько информации вы можете узнать!


Member 14589606

Когда я вызываю intializeJob (), он показывает сообщение об ошибке; обычно каждый адрес сокета (протокол, сетевой адрес или соединение) может быть использован только один раз"

public void ExecuteJob()
{
int measureEventTime = 0;
intervalComparison = measurementEvent.repetitionIntervalTime * 0.75;
if (measurementEvent.eventRepetitionCount > 1)
{
measureEventTime = (int)(measurementEvent.eventIntervalTime * measurementEvent.eventRepetitionCount);
intervalComparison = measurementEvent.eventIntervalTime * 0.75;
}

initializeJob();
пробовать
{
если (IsRepeatable())
{
// выполнение задания с интервалами, определяемыми метд
// GetRepetionIntervalTime()

Нить.Сон(measurementEvent.startDelay);
пока (jobActive)
{
for (int i = 0; i < measurementEvent.eventRepetitionCount; i++)
{
//Thread thread = new Thread(new ThreadStart(DoJob));
//нить.Начать();
Система.Нарезание резьбы.Задачи.Система задач русском языке не относится =.Нарезание резьбы.Tasks.Task.Run(() => { DoJob(); });
Нить.Сон(measurementEvent.eventIntervalTime);
}
Нить.Сон(measurementEvent.repetitionIntervalTime - measureEventTime);
}
}
// поскольку повторения нет, просто выполните задание
еще
{
DoJob();
}
}
поймать (ThreadInterruptedException е)
{
Приставка.WriteLine(Строка.Формат("задание \"{0}\" было успешно прервано.", jobName));
}
наконец
{
deinitializeJob();
}
}

Рейтинг:
1

Patrice T

Цитата:
Можно считывать только одно температурное считывание с процессора датчика, для других датчиков оно не работает

Использование try/catch в вашем коде не позволяет программе сообщить вам, где возникла проблема, и это важная информация.
Try/catch используется для скрытия ошибки, которую вы ожидаете а потом дать соответствующий ответ.
Пример: у вас есть функция, чем в основном делать деление, и вы ожидаете, что делитель иногда будет равен нулю. Если вы ничего не сделаете, программа выйдет из строя, попытка/уловка позволит вам построить правильный ответ (скажем, ноль), и программа завершится без проблем.
Одна вещь, которую нужно сделать, - это также проверить, является ли ошибка тем, что вы ожидаете, потому что в противном случае вы должны вывести сообщение об ошибке.

Совет: удалите try/catch и запустите программу в режиме отладчика, ypu будет показано, где находится ошибка, и вы сможете проверить переменные ans, тогда вы будете знать, какой именно запрос не удался, это первый шаг к решению.

Научитесь правильно делать отступы в вашем коде, это покажет его структуру, и это поможет чтению и пониманию. Это также помогает выявлять структурные ошибки.
public override void initializeJob()
{
    try
    {
        if (TempDevice == temperatureGauge.udp)
        {
            camIP = parameters[0];
            socketCmdText = new UdpClient(cmdTextPort);
            socketCmdText.BeginReceive(new AsyncCallback(OnUdpDataCmdText), socketCmdText);
            socketCmd = new UdpClient(cmdPort);
            socketCmd.BeginReceive(new AsyncCallback(OnUdpDataCmd), socketCmd);
        }
        if (TempDevice == temperatureGauge.GMH3700)
        {
            PortGMH3700.PortName = ComPortbyUser;
            PortGMH3700.BaudRate = 4800; /* Baudrate '4800' oder '38400' */
            PortGMH3700.Parity = Parity.None;
            PortGMH3700.DataBits = 8;
            PortGMH3700.StopBits = StopBits.One;
            PortGMH3700.DtrEnable = true;
            PortGMH3700.RtsEnable = false;
            PortGMH3700.Open();
        }
    }
    catch (Exception e)
    {
        Console.WriteLine("Error TemperatureMesurement-Job initialization " + jobName + " : " + e.Message);
    }
}

Стиль отступа - Википедия[^]

Профессиональные редакторы программистов имеют эту функцию и другие, такие как сопоставление скобок и подсветка синтаксиса.
Блокнот++ Главная Страница[^]
личные[^]