일부 시나리오에서는 Boost::function을 표준을 예상하는 메서드에 전달해야 할 수도 있습니다. 함수 포인터(동일한 서명을 보여줌). 이로 인해 컴파일 오류가 발생할 수 있습니다.
typedef void TriggerProc_type(Variable*, void*); void InitVariable(TriggerProc_type *proc); boost::function<void (Variable*, void*)>& triggerProc ... InitVariable(triggerProc); // Error: cannot convert parameter 1
Boost::function을 제거하고 바인딩된 functor를 참조하면 즉시 유사한 오류가 발생합니다. :
error C2664: 'blah(void (__cdecl *)(type *,void *))' : cannot convert parameter 1 from 'boost::_bi::bind_t<R,F,L>>' to 'void (__cdecl *)(type *,void *)'
일반적으로 인정되는 솔루션 솔루션은 사소한 경우에만 성공적으로 작동하므로 제한적입니다. 보다 효과적인 접근 방식은 콜백 서명을 준수하고 호출할 해당 Boost::function을 확인하고 실행하는 shim 함수를 사용하는 것입니다.
typedef void (*CallbackType)(int x, void* user_data); void RegisterCallback(CallbackType cb, void* user_data); void MyCallback(int x, void* userData) { boost::function<void(int)> pfn = static_cast<boost::function<void(int)> &>(userData); pfn(x); } boost::function<void(int)> fn = boost::bind(myFunction(5)); RegisterCallback(MyCallback, &fn);
이 방법은 Boost::function과 Boost::function 간의 호환성을 보장합니다. Boost::bind를 사용하면 C 콜백과의 원활한 통합이 가능합니다. 그러나 콜백 서명에 사용자 데이터 포인터가 없으면 이 접근 방식이 불가능해집니다. 그럼에도 불구하고 이러한 콜백 구조는 본질적으로 실제 적용 및 수정이 제한됩니다.
위 내용은 함수 포인터가 필요한 메서드에 Boost::function을 전달하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!