Microsoft MVP성태의 닷넷 이야기
로깅관련 질문입니다. [링크 복사], [링크+제목 복사],
조회: 4374
글쓴 사람
장성욱 (lozen77 at naver.com)
홈페이지
첨부 파일
 

안녕하세요
현재 제가 다른장비로 부터 1초마다 계속 51바이트 값의 바이트배열을 수신합니다.
수신된 바이트 배열의 이름은 aa 이구요
void Finderror_Elapsed(object sender, ElapsedEventArgs e)쓰레드에 넣어
1초마다 aa의 51바이트 중 22번 바이트와 23번 바이트 총 2바이트를 들고와서 ToBitarray()함수를 거쳐 바이트를 비트배열로 변환하고,
비트 배열에서 true 값을 추출해서 enum의 문자열로 표시를 하게 합니다.
현재 밑의 코드인데,
여기서 질문은 1초마다 값을 들고와서 문자열로 표시를 해주는데, 이전값을 들고와서 여러번 표시안하고, true 값이 바뀔때만 표시를 하고싶습니다.
예를 들어 22번바이트의 1번째 비트만 true 이다 라고 했을때
"이 장비는 마스터의 a" 라고 표시가 1초마다 한번씩 나오게됩니다.
그리고 5초 후에 22번바이트의 1번째 비트가 true가 아닌 false 로 변경되었고, 22번째 바이트의 2번째 비트가 false에서 true로 되어
 "이 장비는 마스터의 b" 라고 표시가 1초마다 한번씩 나오게 되었을때
"이 장비는 마스터의 a"
"이 장비는 마스터의 a"
"이 장비는 마스터의 a"
"이 장비는 마스터의 a"
"이 장비는 마스터의 a"// 5초후 변경
"이 장비는 마스터의 b"
"이 장비는 마스터의 b"
"이 장비는 마스터의 b"
"이 장비는 마스터의 b"........
위와 같이 표시가 되는데
여기서 질문은 "이 장비는 마스터의 a"를 한번만 표시를 하고 싶고, 5초후 변경되어서 "이 장비는 마스터의 b"가 나오는 것도 한번만 표시를 하고싶습니다...
그래서 제가 string[] 타입의 logstring을 logstring_old 라고 1초 전 이전값으로 저장해서 서로 같으면 1번 표시 이후 안나오게,
서로 다르면 1번 표시하게끔 해보려는데 잘 안되네요...
너무 절박합니다....


 public partial class Form1 : Form
    {

      
        public enum pfc : int
        {
            a = 0,
            b = 1,
            c = 2,
            d = 3,
            e = 4,
            f = 5,
            g = 6,
            h = 7, // pfc 1바이트

            i = 8,
            j = 9,
            k = 10,
            l = 11,
            m = 12,
            n = 13,
            o = 14 // pfc 2바이트
        }
       


        public string[] logString = Array.Empty<string>(); // 로그 선언 및 초기화
        public string[] logString_old = Array.Empty<string>();
        public Form1()
        {
            
            
            InitializeComponent();


            void Finderror_Elapsed(object sender, ElapsedEventArgs e)
            {

                    logString = Array.Empty<string>();
                    logString_old = Array.Empty<string>();

                    logString = logString
                    .Concat(aa.Skip(22).Take(2).ToBitarray().FindError().Select(re => "이 장비는" + " master의 " +
                     Enum.GetName(typeof(pfc), re)))
                    .ToArray();

                logString_old = logString;

                    if (logString.SequenceEqual(logString_old))
                    {
                        
                    }
                    else
                    {
                        Debug.WriteLine(logstring);
                    }

            }
        }


    }
        
    public static class IEnumberableExt
    {
        public static int[] FindError(this BitArray ba, int exclude = -1)
        {
            int[] re = Array.Empty<int>();
            for (int i = 0; i < ba.Length; i++)
            {
                re = ba.Get(i) == true && i != exclude ?
                    re.Append(i).ToArray() :
                    re;
                
            }
            return re;
        }
        public static BitArray ToBitarray(this IEnumerable<byte> e)
        {
            return new BitArray(e.ToArray());
        }
    }











[최초 등록일: ]
[최종 수정일: 3/24/2022]


비밀번호

댓글 작성자
 



2022-03-24 10시10분
아래의 코드를,

-------------------------------------
logString_old = logString;

if (logString.SequenceEqual(logString_old))
{
}
else
{
    Debug.WriteLine(logstring);
}
-------------------------------------

단순히, 아래와 같이만 바꾸면 되는 거 아닌가요?

-------------------------------------
if (logString.SequenceEqual(logString_old))
{
}
else
{
    Debug.WriteLine(logstring);
}

logString_old = logString;
-------------------------------------
정성태
2022-04-04 06시51분
[장성욱] 감사합니다. 참고하여 덕분에 잘되었습니다. 항상 질문에 친절히 응답해주셔서 감사합니다.
[guest]

... 16  17  [18]  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5485이재원4/17/20216363교재 315페이지 내용 질문 [3]
5484Syong4/16/20219939윈폼 기반의 응용프로그램 dll 참조와 32,64bit 빌드 관련 문의 [4]
5483한예지 donator4/15/20215397익명 형식과 var 관계 질문 있습니다. [2]
5482질문4/13/20217195WPF를 위한 MVVM toolkit 선택과 관련한 문의드립니다. [4]
5480한예지 donator4/5/20217508GetHashCode 질문있습니다! [2]
5479한예지 donator4/4/20216583Equals를 닷넷에서 어떻게 구현했는지 보고 싶을 떄는 어떻게 해야 될까요? [2]
5478갑자기C#3/23/20219058C# Winform에서 TextBox없이 입력 받을 수 있나요? [7]
5477달팽이3/18/20216036c# 도형을 그린후 편집하는 방법이 궁금합니다. [2]파일 다운로드1
5475dimo...3/2/20217045POH가 .NET 5에 추가된 것으로 알고 있습니다. POH가 유용한 경우는 어떤 경우가 있을까요? [1]
5474Syong2/26/20216579사용자 지정 컨트롤 생성시 Invalidate, Update, Refresh의 차이점 [2]
5473한예지 donator2/25/20216468디자인 타임이 뭔지 궁금합니다!! [5]
5472dimo...2/24/20217259등록하지 않고 ocx를 사용하는 `키움`관련 포스팅을 따라가다 질문드립니다. [9]
5471남산2/21/20215892MarshalDirectiveException 에 대한 질문입니다. [1]
5470한예지 donator2/7/20215824yield 질문있습니다!! [2]
5469유호성2/6/20215361Parallel + Task.Run 동시 실행 환경에서 간헐적으로 Task.Run()에서 null이 리턴됩니다. [3]파일 다운로드1
5467hero...2/4/20215745실행 환경에 따른 Thread.Sleep 딜레이 차이 질문 [8]
5466pr1/29/20215633c# winform load시 작업표시줄에 뜨지 않는 현상을 겪으신적이 있으신가요? [4]파일 다운로드1
5465영귤1/28/20215995두 번째 await 부터는 스레드 개수만 늘어나는 것이 아닌가요 [1]
5464민우1/26/20216259C# 빌드시 코드 치환되는걸 확인하는 방법 문의 [2]
5463한예지 donator1/24/20217018Parameters.AddWithValue 와 Parameters.Add 의 차이점이 궁금합니다. [2]
5462C#초보1/22/20217400사용자 정의 메시지 전달이 가능한가요? [2]
5461한예지 donator1/22/20216795AsEnumerable() 메서드 질문 있습니다! [2]
5459한예지 donator1/21/20216141typeof와 GetType의 차이점 질문있습니다. [2]
5458진우1/20/20217041C# DataTable 에 SQL 쿼리문을 실행하는 방법 문의 (LINQ 사용하지 않고) [6]
5456성민1/17/202174299.0 출간 계획이 있으신가요? [2]
5455한예지 donator1/16/20216469교재 194페이지 콜백메서드 질문 있습니다! [5]
... 16  17  [18]  19  20  21  22  23  24  25  26  27  28  29  30  ...