Я разработал приложение для SMS (отправка / получение SMS с использованием GSM-модема) с использованием этой библиотеки - http://www.scampers.org/steve/sms/libraries.htm
У меня есть таймер, который проверяет полученные сообщения каждые 3 секунды. Проблема в том, что каждые несколько минут я получаю такую ошибку:
***
at GsmComm.GsmCommunication.GsmPhone.GsmComm.GsmCommunication.IProtocol.ReceiveAnything(String pattern)
at GsmComm.GsmCommunication.GsmPhone.GsmComm.GsmCommunication.IProtocol.ReceiveMultiple()
at GsmComm.GsmCommunication.GsmPhone.GsmComm.GsmCommunication.IProtocol.ExecAndReceiveMultiple(String command)
at GsmComm.GsmCommunication.GsmPhone.ListMessages(PhoneMessageStatus status)
at GsmComm.GsmCommunication.GsmCommMain.ReadMessages(PhoneMessageStatus status, String storage)
at SMS.BL.TimerCalls_rec.recProcessTimerEvent(Object sender, EventArgs e) in D:\Csharp\SMS GSM\SMS\BL\TimerCalls_rec.cs:line 57++++++++No data received from phone after waiting for 30000 ms.
Это часть этого кода:
try
{
// Read all SMS messages from the storage
if (CommSetting.comm.IsConnected())
{
DecodedShortMessage[] messages = CommSetting.comm.ReadMessages(PhoneMessageStatus.All, PhoneStorageType.Phone);
foreach (DecodedShortMessage message in messages)
{
ReadMessage(message.Data);
//delete message
indexP = message.Index;
CommSetting.comm.DeleteMessage(indexP, PhoneStorageType.Phone);
}
}
}
catch (Exception err)
{
RIWL.log(err.StackTrace + "++++++++" + err.Message, "Error: ");
}
Это строка, в которой возникает ошибка:
DecodedShortMessage[] messages = CommSetting.comm.ReadMessages(PhoneMessageStatus.All, PhoneStorageType.Phone);
Есть идеи, почему время от времени модем не отвечает? Отправка / получение сообщений происходит отдельно. При отправке СМС - чтение останавливается и наоборот.
Могу ли я сделать что-нибудь еще, чтобы проверить, не занят ли последовательный порт?
РЕДАКТИРОВАТЬ: Если это поможет, в момент возникновения ошибки dllhost.exe - COM Surrogate вскоре появится в процессах.