From 1fd49a571338b6c946bb05dcdf59ec1468df5c50 Mon Sep 17 00:00:00 2001
From: SWK <sungwk82@diteam.co.kr>
Date: 목, 22 12월 2022 12:31:43 +0900
Subject: [PATCH] ongoing50 #4403 CF AOI Reveiw TACT 지연 개선 1. 일정 시간 유지 신호 처리 시 동기화로 인한 불합리 개선 - 일정 시간 유지 필요 시 스래드풀 작업큐를 이용하여 루프처리 방식으로 변경 - 유지 신호 처리 중 출력 신호 발생 시 작업큐에 등록하여 유지 신호와 결합하여 출력 처리 2. FDC 보고 항목 중 SW 버전 체크 루프 불합리 개선 - 프로그램 시작 시 연동 프로그램 버전 체크 간 실행되지 않는 프로그램이 있는 경우 무한 루프 발생 - 무한 루프로 인한 CPU 점유 상승->루프 중간 Sleep추가 및 코드 간소화 3. 로그 메시지에 시간 ms단위 추가(황만수SM 작업 내역 병합)

---
 ReviewHistory/include/akSTL/akQueue.h |  100 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 100 insertions(+), 0 deletions(-)

diff --git a/ReviewHistory/include/akSTL/akQueue.h b/ReviewHistory/include/akSTL/akQueue.h
new file mode 100644
index 0000000..92c0046
--- /dev/null
+++ b/ReviewHistory/include/akSTL/akQueue.h
@@ -0,0 +1,100 @@
+#pragma once
+
+
+#include "akSTLLinker.h"
+#include <memory.h>
+
+	class AKSTL_DLLSPEC CakQueue
+	{
+	public:
+		CakQueue(void);
+		~CakQueue(void);
+
+	public:
+		bool empty()
+		{	
+			return m_nDataSize == 0 ? true : false;
+		}
+
+		size_t size()
+		{
+			return m_nDataSize;
+		}
+
+		char* front()
+		{
+			return &m_pQueue[m_stPoint];
+		}
+
+		char* back()
+		{
+			return &m_pQueue[m_stPoint+m_nDataSize-1];
+		}
+
+		void push(char _Val)
+		{
+			if(m_stPoint+m_nDataSize >= m_nMemSize)
+			{
+				size_t newsize = m_nMemSize*2;
+				char* pNewQueue = new char [newsize];
+				memcpy(pNewQueue, &m_pQueue[m_stPoint], sizeof(char)*(m_nMemSize-m_stPoint));
+				m_nMemSize = newsize;
+				m_stPoint = 0;
+				char* pTemp = m_pQueue;
+				m_pQueue = pNewQueue;
+				delete [] pTemp;
+
+			}
+
+			
+			m_pQueue[m_stPoint+m_nDataSize] = _Val;
+			m_nDataSize++;
+		}
+
+		void push(char* pVal, int nSize)
+		{
+			if(m_stPoint+m_nDataSize + nSize >= m_nMemSize)
+			{
+				size_t newsize = m_nMemSize+nSize*2;
+				char* pNewQueue = new char [newsize];
+				memcpy(pNewQueue, &m_pQueue[m_stPoint], sizeof(char)*(m_nMemSize-m_stPoint));
+				m_nMemSize = newsize;
+				m_stPoint = 0;
+				char* pTemp = m_pQueue;
+				m_pQueue = pNewQueue;
+				delete [] pTemp;
+
+			}
+
+			//m_enPoint++;
+			memcpy(&m_pQueue[m_stPoint+m_nDataSize], pVal, sizeof(char)*nSize);
+			m_nDataSize+=nSize;
+		}
+
+		void pop()
+		{
+			m_stPoint++;
+			m_nDataSize--;
+
+			if(m_nDataSize == 0)
+			{
+				m_stPoint=m_nDataSize=0;
+			}
+		}
+		void pop(int nSize)
+		{
+			m_stPoint += nSize;
+			m_nDataSize -= nSize;
+			
+			if(m_nDataSize == 0)
+			{
+				m_stPoint=m_nDataSize=0;
+			}
+		}
+	private:
+		size_t m_stPoint; //메모리 시작위치
+		size_t m_nDataSize; //메모리 끝 위치
+		size_t m_nMemSize; //할당된 메모리 사이즈
+		char*  m_pQueue;
+		
+	};

--
Gitblit v1.9.3