소켓에 바로 메세지를 보내는게 아니라 버퍼를 만들어서 넣어주고 주고받는 이유가 있나요?
수신과 송신 버퍼를 둘 다 가지고 있고 거기에 일단 메시지를 넣어서 보내거나 버퍼를 통해서 받고 있는데 버퍼를 사용하는 이유가 소켓이 바로 메세지를 받지 못하고 대기하는 경우나 병목이 있을 경우를 대비해서 그런건가요?
답변 1
2
꼭 병목 때문에 그런 것은 아니고 사실 다른 선택지가 없습니다.
우선 수신의 경우, 소켓 API 자체가 [수신을 희망하는 유저레벨 버퍼]를 건내주면
거기다가 커널 수신버퍼에 있는 내용을 복사해서
우리한테 반환해주는 방식으로 되어 있습니다.
물론 당장 이를 다 소모하지 않고 유지시켜주는 이유는
TCP 특성상 패킷이 완전체로 한 번에 도착하지 않을 수도 있기 때문입니다.
송신의 경우도 마찬가지로 송신을 희망하는 [유저레벨 데이터 버퍼]를 건내주면,
거기에 있는 내용을 커널쪽 송신 버퍼로 복사한 다음,
상대방에게 보내주는 방식으로 동작하기 때문에
이 경우에도 버퍼가 없을 수는 없습니다.
C#에서의 RAII
0
66
3
TLS 질문드립니다.
0
79
2
SpinLock과 컨텍스트스위칭에 대해 질문 남겨요.
0
74
2
Unity Span
0
97
2
XML, Dll 차이점
0
134
2
Session 질문입니다
0
96
1
Write Read 커서 키워드
0
88
1
더미 클라이언트 수에 따른 OnDisconnect 발생
0
85
2
네트워크 Send 전담 스레드 배치
0
112
2
UnhandledException 으로 서버 터지는 경우
0
102
2
컨텐츠 단, 엔진 단
0
118
1
질문 있습니다
0
93
2
C# 게임서버 3D MMORPG
0
159
2
유니티6 버전
0
106
2
receive하는 부분과 send하는 부분의 차이
0
154
2
커서의 위치의 중요성
0
110
2
C++ 전혀 모르는데 C# 서버
0
176
2
강의에 질문이 있습니다
0
92
2
멀티스레드 이해도 질문
0
107
1
500 vs 500
0
147
3
OnAcceptHandler 액션 함수
0
70
1
이 정도 서버의 객관적인 수준이 궁금합니다.
0
204
2
36. Serialization #3 에서 string (name) 코드 수정 질문
0
86
2
외부 컴퓨터와의 통신 방법이 궁금합니다
0
112
1





