한가지 에러와 한가지 질문이 있습니다
967
작성자 없음
작성한 질문수 0
한가지 에러는 WRITE_LOCK 부분인데요
void MemoryPool::Push(MemoryHeader* ptr)
{
WRITE_LOCK;
//Pool에 메모리 반납
queue.push(ptr);
allocCount.fetch_sub(1);
}
부분에서 WRITE_LOCK에서 에러가 나고 있는 상황입니다.
Push와 Pop 둘 다 동일합니다.
심각도 코드 설명 프로젝트 파일 줄 비표시 오류(Suppression) 상태
오류(활성) E0300 바인딩된 함수에 대한 포인터는 함수를 호출하는 데에만 사용할 수 있습니다.
이런 에러가 나고 있는 상황이고
한가지 질문은 Memory부분에서
if (allocSize > MAX_ALLOC_SIZE)
{
header = reinterpret_cast<MemoryHeader*>(malloc(allocSize));
}
부분에서 왜 static_cast를 쓰지 않고 reinterpret_cast를 사용하는 건가요? static_cast를 사용했을 때 발생할 수 있는 문제점이 있나요?
답변 1
0
음 에러라는게 빌드 에러를 말씀하시는건가요? 강의 코드를 그대로 받아서 실행해도 동일한가요?
4대 캐스팅 관련된 내용은 서버 시간에 다룰 부분이 아닙니다.
따로 구글링을 통해 차이에 대해 알아보시기 바랍니다.
0
왜 reinterpret_cast를 쓰는지 여쭤본건 캐스팅의 차이점을 묻는다기 보단
reinterpret_cast를 쓰는 특별한 이유가 있는지, 다른 캐스팅을 쓰면 프로그램의 진행에 문제가 있는지를 여쭤보고 싶어서였습니다.
혹시 그 이유가 캐스팅의 차이점과 관련이 있는건가요?
0
캐스팅 4총사는 용도에 따라 사용할 수 있는 상황이 조금 다르기도 하고
또 사용 여부에 따라 프로그래머의 의도를 나타낼 수도 있다는 장점이 있는데요.
가령 dynamic_cast를 사용하지 않고서도 static_cast로 포인터 변환을 하더라도,
타입만 확실하다면 문제 없이 지나갈 수 있습니다. (먼저 타입 체크를 하고 static_cast를 하는 등)
포인터 변환에서의 reinterpret_cast와 static_cast는
전자의 경우 아무런 연관성 없는 포인터의 변환을,
후자는 상속 구조에서의 강제 포인터 변환에 사용하는데 (dynamic처럼 체크는 X)
물론 지금의 경우 malloc이 void*을 뱉어주니 결과적으로 둘 중 뭘 사용하더라도 상관없습니다.
다만 reinterpret_cast가 조금 더 '상관없는 포인터 타입으로의 변환'의 의미를 내포하고 있을 뿐이죠.
이런 세부적인 부분은 그냥 원하는 방식으로 만드시면 됩니다.
Memory Pool에서 오버플로우 질문입니다.
0
62
2
포토폴리오 및 진로 관련하여 고민입니다.
0
112
1
포토폴리오 관련 고민입니다.
0
61
1
실무에서도 alloc, 스마트포인터 등을 구현해서 쓰는지 궁금합니다.
0
82
2
성능 테스트 결과
0
103
2
게임 서버 Stateful, Stateless 진로 고민
0
121
1
WaitOnAddress와 Sleep의 차이 질문
0
83
1
궁금한거 있습니다.
0
82
2
JobTimer 구동 스레드
0
107
2
TryPop() 동작 관련 질문
0
81
1
로드맵 C#서버 C++서버 방향성 질문
0
148
2
스레드 id를 출력할떄 메인스레드 id도 출력되나요?
0
73
1
생명주기를 위한 의도적 복사
0
86
2
락프리의 실무에서 사용 질문
0
139
2
32bit threadID와 16비트 상위 WriteFlag에 대해
0
101
2
mutex와 sleep 차이점
0
117
1
실무에서는 어떠한 코드 스타일을 사용하는지 궁금합니다
0
152
2
Stomp Allocator의 Release함수에 대한 질문입니다.
0
96
1
공부법 관련해서
0
183
2
MakeShared 함수 관련
0
114
1
지금까지 서버코어에서 만든 내용에 대해 궁금한 점이 있어서 질문 드립니다.
0
144
2
운영체제관련 질문입니다
0
131
1
send하려는 데이터 크기가 크면 memcpy에서 문제가 발생할 것 같습니다.
0
117
2
메모리 풀 질문있습니다.
0
123
1





