• 카테고리

    질문 & 답변
  • 세부 분야

    게임 프로그래밍

  • 해결 여부

    미해결

_pendingList 와 lock 질문

21.08.22 13:24 작성 조회수 254

0

  1.  void RegisterSend()
  2.         {
  3.             //
  4.             // a[][][][][][][][][][][][][][][][]
  5.             while (_sendQueue.Count > 0)
  6.             {
  7.                 byte[] buff = _sendQueue.Dequeue();
  8.                 _pendingList.Add(new ArraySegment<byte>(buff, 0, buff.Length));
  9.             }
  10.             _sendArgs.BufferList = _pendingList;
  11.             bool pending = _socket.SendAsync(_sendArgs);
  12.             if (pending == false)
  13.                 OnSendCompleted(null, _sendArgs);
  14.         }

1.

_sendQueue.Count > 0 말고

바로 

_sendArgs.BufferList .Count > 0 로 하는게 좋지 않나요

굳이 따로 만들어서 담는 이유가 있나요?

_sendArgs.BufferList = _pendingList;

----------------------------------------------------------

 public void Send(byte[] sendBuff)

        {

            lock (_lock)

            {

                 _sendQueue.Enqueue(sendBuff);

                 if (_pendingList.Count == 0)

                     RegisterSend();        

            }

        } 

2.

c#에서 같은 쓰레드인 경우는 락을 무시하고 들어갈수 있는게 맞나요?? 

3.

지금 코드는 멀티쓰레드 기준으로 만들었는데

실행은 싱글쓰레드로 작동하나요? Thread를 따로 만들지 않고 실행하는데.

답변 1

답변을 작성해보세요.

1

1.
_sendArgs에는 기존에 보냈던 데이터가 물려 있어서 별도로 관리합니다.
다만 세세한 부분에 대한 궁금증은 일단 원하시는대로 수정해보고
문제 없는지 직접 확인해보시는게 좋습니다.

2.
동일한 쓰레드 내에서만 뭔가 실행된다면 락을 잡을 필욘 없습니다.
(단 외부에서 다른 쓰레드가 개입하지 않는지 확인 필요)

3.
C#에서 네트워크 관련 비동기 함수들을 사용하면
자동으로 쓰레드 풀에서 쓰레드를 꺼내 완료 처리를 하기 때문에
자동으로 멀티쓰레드 환경입니다.