Use lock statement instead of variable to lock logmessages
This commit is contained in:
parent
67c23b357f
commit
88ca75e883
@ -1,6 +1,6 @@
|
||||
namespace Logging;
|
||||
|
||||
public class LogMessage
|
||||
public readonly struct LogMessage
|
||||
{
|
||||
public DateTime logTime { get; }
|
||||
public string caller { get; }
|
||||
|
@ -6,7 +6,6 @@ public class MemoryLogger : LoggerBase
|
||||
{
|
||||
private readonly SortedList<DateTime, LogMessage> _logMessages = new();
|
||||
private int _lastLogMessageIndex = 0;
|
||||
private bool _lockLogMessages = false;
|
||||
|
||||
public MemoryLogger(Encoding? encoding = null) : base(encoding)
|
||||
{
|
||||
@ -15,12 +14,9 @@ public class MemoryLogger : LoggerBase
|
||||
|
||||
protected override void Write(LogMessage value)
|
||||
{
|
||||
if (!_lockLogMessages)
|
||||
lock (_logMessages)
|
||||
{
|
||||
_lockLogMessages = true;
|
||||
while(!_logMessages.TryAdd(DateTime.Now, value))
|
||||
Thread.Sleep(10);
|
||||
_lockLogMessages = false;
|
||||
_logMessages.Add(DateTime.Now, value);
|
||||
}
|
||||
}
|
||||
|
||||
@ -41,11 +37,9 @@ public class MemoryLogger : LoggerBase
|
||||
|
||||
for (int retIndex = 0; retIndex < ret.Length; retIndex++)
|
||||
{
|
||||
if (!_lockLogMessages)
|
||||
lock (_logMessages)
|
||||
{
|
||||
_lockLogMessages = true;
|
||||
ret[retIndex] = _logMessages.GetValueAtIndex(_logMessages.Count - retLength + retIndex).ToString();
|
||||
_lockLogMessages = false;
|
||||
}
|
||||
}
|
||||
|
||||
@ -63,11 +57,9 @@ public class MemoryLogger : LoggerBase
|
||||
{
|
||||
try
|
||||
{
|
||||
if (!_lockLogMessages)
|
||||
lock(_logMessages)
|
||||
{
|
||||
_lockLogMessages = true;
|
||||
ret.Add(_logMessages.GetValueAtIndex(_lastLogMessageIndex + retIndex).ToString());
|
||||
_lockLogMessages = false;
|
||||
}
|
||||
}
|
||||
catch (NullReferenceException e)//Called when LogMessage has not finished writing
|
||||
|
Loading…
Reference in New Issue
Block a user