Boost::function을 일반 함수 포인터로 수준 내리기
문제:
Boost::function을 요구하는 메소드에 대해 동일한 시그니처를 가진 일반 함수 포인터로 사용하면 오류가 발생할 수 있습니다. as C2664.
해결 방법:
일부 답변에서는 target()을 사용하여 Boost::function에서 포인터를 검색하는 것을 제안하지만 이는 다음과 같은 사소한 경우에만 작동합니다. 처음에 바인딩된 객체는 C 콜백에 바인딩할 수 있었습니다.
중요한 경우, Boost::function의 기본 메커니즘 하나가 아닌 여러 개의 포인터가 필요합니다. 따라서 보다 강력한 솔루션은 콜백 서명을 준수하는 shim 함수를 생성하고 사용자 데이터로 저장된 Boost::function에 호출을 위임하는 것입니다.
예:
// Shim function for callback typedef void (*CallbackType)(int x, void* user_data); void MyCallback(int x, void* userData) { boost::function<void(int)>& pfn = static_cast<boost::function<void(int)> &>(userData); pfn(x); } // Usage boost::function<void(int)> fn = boost::bind(myFunction(5)); RegisterCallback(MyCallback, &fn);
이 접근 방식을 사용하면 사용자 데이터가 포함된 C 콜백과 함께 Boost::function을 사용할 수 있습니다. 그러나 콜백 서명에 사용자 데이터 포인터가 부족한 경우 대부분의 상황에서 사용할 수 있으려면 완전히 다시 디자인해야 할 수도 있습니다.
위 내용은 일반 함수 포인터에 'boost::function'을 안전하게 전달하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!