Microsoft MVP성태의 닷넷 이야기
로깅관련 질문입니다. [링크 복사], [링크+제목 복사],
조회: 13278
글쓴 사람
장성욱 (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]

... 76  77  78  79  80  81  [82]  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
423이방은7/9/200615165리소스 임베디드 질문요.. [1]파일 다운로드1
422guest7/6/200614660COM+에서 풀링을 사용할 경우... [1]파일 다운로드1
424guest7/10/200615461    답변글 소스 코드 입니다. [1]
425guest7/11/200614630        답변글 다시 올립니다.파일 다운로드1
428정성태7/11/200614471            답변글 [답변]: 다시 올립니다.
421정보문7/6/200615189액티브X 설치 [1]
1354허재호11/12/201415785    답변글 [답변]: 액티브X 설치
418임대진7/4/200614376이럴적 있으세요?
419정성태7/4/200614475    답변글 [답변]: 이럴적 있으세요?
417이방은6/29/200614230[질문]2.0에서 웹리소스에 대해서 [2]
416박영일6/29/200614520CAS 설정여부 [1]
415김인학6/28/200615091스마트 클라이언트에서 웹서비스를 호출하고 있습니다. [1]
413김성호6/28/200614689IE프로그램문제... [2]
411이진형6/27/200615075어셈블리 네임 알아내기 [2]
414정성태6/28/200614044    답변글 [답변]: 어셈블리 네임 알아내기
410이재원6/26/200614216자바스크립트 스마트클라이언트 이벤트 호출 [3]
412이재원6/27/200614372    답변글 [답변]: 자바스크립트 스마트클라이언트 이벤트 호출
409정준명6/22/200615395윈폼 기반 스마트클라이언트 속도 문제에 대해서 의견을 구합니다. [2]
406이진형6/21/200615710처음에 스마트클라이언트 로딩하는 속도 [1]
4036/20/200614475Invoke 관련 문의 드립니다. [2]
4086/22/200613253    답변글 invoke 관련하여...
401김용국6/19/200614396SmartClient에서 동적 어셈블리 관련 문의 드립니다 [1]
402김용국6/20/200613407    답변글 [답변]: SmartClient에서 동적 어셈블리 관련 문의 드립니다 ... 다시 문의 드립니다! [1]
404김용국6/20/200613455        답변글 [답변]: [답변]: SmartClient에서 동적 어셈블리 관련 문의 드립니다 ... 다시 문의 드립니다! [1]
405김용국6/21/200614006            답변글 잘 되네요~~ ^^ 고맙습니다!
407김용국6/21/200613254                답변글 [답변]: 다시한번 문의드립니다!
... 76  77  78  79  80  81  [82]  83  84  85  86  87  88  89  90  ...