System.Threading.ThreadAbortException: поток был прерван – какой поток?C#

Место общения программистов C#
Ответить
Anonymous
 System.Threading.ThreadAbortException: поток был прерван – какой поток?

Сообщение Anonymous »

У меня есть веб-сайт, который постоянно считывает данные с другого сайта и отображает эту информацию на карте.
У меня есть сокет, запущенный как

client.BeginReceive(state.buffer, 0, StateObject.BufferSize, 0,
new AsyncCallback(ReceiveCallback), state);


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

readBytesWaitHandle.Set();


Очень редко я получаю следующую ошибку

System.Threading.ThreadAbortException: Thread was being aborted.
at System.Threading.WaitHandle.WaitOneNative(SafeHandle waitableSafeHandle, UInt32 millisecondsTimeout, Boolean hasThreadAffinity, Boolean exitContext)
at System.Threading.WaitHandle.InternalWaitOne(SafeHandle waitableSafeHandle, Int64 millisecondsTimeout, Boolean hasThreadAffinity, Boolean exitContext)
at System.Threading.WaitHandle.WaitOne(TimeSpan timeout, Boolean exitContext)
at WebAPRS.PacketListener.readBytesBuffer() in c:\Users\Alan\Documents\Visual Studio 2013\Projects\WebAPRS\WebAPRS\PacketListener.cs:line 274


Вопрос в том, какой поток прерывается? Тот, который запускает ReceiveCallback, или тот, который ожидает
ReceiveCallback, чтобы установить дескриптор ожидания.

Спасибо

Алан

Изменить Вот код для ReceiveCallback

// run by the client thread (which is implicitly created)
private void ReceiveCallback(IAsyncResult ar)
{
try
{
if (restarting) return;

// Retrieve the state object and the client socket
// from the asynchronous state object.
timeSpanSinceLastBytes = DateTime.Now - timeSinceLastBytes;
timeSinceLastBytes = DateTime.Now;
var state = (StateObject)ar.AsyncState;

if (!state.workSocket.Connected)
{
reStartClient("Error: state.workSocket.Connected =false - Restarting");
return;
}

var client = state.workSocket;

// Read data from the remote device.
var bytesRead = client.EndReceive(ar);

if (bytesRead == 0)
{
reStartClient("ERROR: bytes==0 - Restarting");
return;
}

// quickly store the buffer
storeBytes buff = new storeBytes(state.buffer, bytesRead);
byteQueue.Enqueue(buff);
string data = Encoding.ASCII.GetString(state.buffer, 0, bytesRead);
client.BeginReceive(state.buffer, 0, StateObject.BufferSize, 0,
new AsyncCallback(ReceiveCallback), state);
// setoff the readBytes Thread
readBytesWaitHandle.Set();
}
catch(Exception e)
{
reStartClient("ReceiveCallback failed : " + e.ToString());
}
}


Вы увидите, что я постарался уловить каждую возможность, о которой только мог подумать. Часто происходит сбой при чтении нулевых байтов, и он перезапускается нормально. (Сначала я проверяю, не продолжается ли процесс перезапуска)

Блок catch не улавливает эту ошибку.
Мой сайт просто умирал (возможно, раз в 12 часов), поэтому у меня работает другой поток, который проверяет
работоспособность потока, считывающего выходные данные ReceiveCallback каждые 30 секунд, и распечатывает сообщение об ошибке выше.
Код для этого:

private void checkRunning(object state)
{
if(! ((packetListener.readBytes.ThreadState == ThreadState.Running)||(packetListener.readBytes.ThreadState == ThreadState.WaitSleepJoin)))
{
packetListener.appendToDebugFile("readBytes thread not running "+packetListener.readBytes.ThreadState.ToString());
}
if(! ((packetListener.readStrings.ThreadState == ThreadState.Running) || (packetListener.readStrings.ThreadState == ThreadState.WaitSleepJoin)))
{
packetListener.appendToDebugFile("readStrings thread not running " + packetListener.readStrings.ThreadState.ToString());
}
if (packetListener.timeSpanSinceLastBytes > TimeSpan.FromSeconds(30))
{
packetListener.appendToDebugFile("bytes not seen for " + packetListener.timeSpanSinceLastBytes.ToString());
}
packetListener.appendToDebugFile("Threads running OK");
}


Подробнее здесь: https://stackoverflow.com/questions/254 ... ich-thread
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»