주식 실시간 체결 정보를 내려받아서 처리하고 있는데요
종목이 예를 들어 100개라고 하면 각 종목에서 데이터가 들어오는데 어떤 종목은 초당 수십개가 들어오는 것도 있고 1초에 한개도 안들어오는 종목이 있죠
각 종목이 얼마나 빠른 속도로 데이터가 들어오는지.. 지금은 아래와 같은 방법을 쓰고 있습니다
// shcode // 종목코드 변수
Stopwatch sw = new Stopwatch();
int cheCount;
long sw1;
Dictionary<string, List<DateTime>> ChegyulCountDic = new Dictionary<string, List<DateTime>>(); // Dictionary 하나 선언해주고
ChegyulCountDic.Add(shcode, new List<DateTime>()); // 종목을 등록합니다
그리고 데이터가 내려오면
sw.Start();
ChegyulCountDic[shcode].Add(DateTime.Now); // 종목별 리스트에 시간을 넣어줍니다
if ((DateTime.Now - DataClass.ChegyulCountDic[shcode][0]).TotalSeconds > 10) // 10초 동안에 얼마나 들어왔는지 체크하기위해 10 초가 지난 것은 삭제
{
DataClass.ChegyulCountDic[shcode].RemoveAt(0);
}
if ((DateTime.Now - DataClass.ChegyulCountDic[shcode][0]).TotalSeconds > 10) // 두번 검사합니다.
{
DataClass.ChegyulCountDic[shcode].RemoveAt(0);
}
그리고 남아있는 리스트 Count 로 건수를 구하고 있습니다
cheCount = ChegyulCountDic[shcode].Count;
sw.Stop();
sw1 = sw.ElapsedTicks;
이렇게 해서 Stopwatch 로 측정해보니 많이 걸릴 경우 한건 처리하는데 sw1 = 8ms까지도 나오네요
데이터가 많이 내려올경우 정확한건 없지만 초당 1000건도 내려올수가 있는데 하나에 8ms 가 걸리면 다 처리할 수가 없네요
초보라서 이런방식 밖에 생각이 나지 않습니다
Dictionary<string, int> dic = new Dictionary<string, int>();
dic[shcode]++; // 이렇게 건수를 증가 10초가 지나면 0으로 초기화하고 할려니 초기화 직후 건수를 읽으면 실제 속도와 차이가 안되더군요
이런 경우 어떤 해야 되는지 조언부탁드립니다
[최초 등록일: ]
[최종 수정일: 11/16/2021]