VS 2010: ошибка LNK2019: неразрешенный внешний символ «extern» C «void * __cdecl

0

Я новичок в C++, я попытался скопировать этот код и запустить в visual studio 2010. Но он дает нерешенную ошибку extern 'c' и еще один неразрешенный токен "extern" C ", как указано ниже кода.

Это код, вызывающий ошибки:

#ifdef _MANAGED     // Works only with managed C++
#pragma once
#pragma managed(push, on)
#include <stdlib.h>     //free

typedef void (__cdecl *_PVFV)(void);
extern "C" void * __cdecl _decode_pointer(void *);
extern "C" void * __cdecl _encoded_null();

// crtdll.c
extern "C" _PVFV *__onexitbegin;
extern "C"  _PVFV *__onexitend;



void CrtDestroyStatics(void)
{
    _PVFV * onexitbegin = (_PVFV *)_decode_pointer(__onexitbegin);
    if (onexitbegin)
    {
        _PVFV * onexitend = (_PVFV *)_decode_pointer(__onexitend);
        _PVFV function_to_call = NULL;

        /* save the start and end for later comparison */
        _PVFV * onexitbegin_saved = onexitbegin;
        _PVFV * onexitend_saved = onexitend;

        while (1)
        {
            _PVFV * onexitbegin_new = NULL;
            _PVFV * onexitend_new = NULL;

            /* find the last valid function pointer to call. */
            while (--onexitend >= onexitbegin && (*onexitend == NULL || *onexitend == _encoded_null()))
            {
                /* keep going backwards. */
            }

            if (onexitend < onexitbegin)
            {
                /* there are no more valid entries in the list, we are done. */
                break;
            }

            /* cache the function to call. */
            function_to_call = (_PVFV)_decode_pointer(*onexitend);

            /* mark the function pointer as visited. */
            *onexitend = (_PVFV)_encoded_null();

            /* call the function, which can eventually change __onexitbegin and __onexitend */
            (*function_to_call)();

            onexitbegin_new = (_PVFV *)_decode_pointer(__onexitbegin);
            onexitend_new = (_PVFV *)_decode_pointer(__onexitend);

            if ( ( onexitbegin_saved != onexitbegin_new ) || ( onexitend_saved != onexitend_new ) )
            {
                /* reset only if either start or end has changed */
                 __onexitbegin = onexitbegin_saved = onexitbegin_new;
                 __onexitend = onexitend_saved = onexitend_new;
            }

            break;
        }
        /*
        * free the block holding onexit table to
        * avoid memory leaks.  Also zero the ptr
        * variables so that they are clearly cleaned up.
        */

        free ( onexitbegin ) ;

        __onexitbegin = __onexitend = (_PVFV *)_encoded_null();
    }

} //CrtDestroyStatics

#pragma managed(pop)
#endif

И вот ошибки компоновщика:

Error   4   error LNK2019: unresolved external symbol "extern "C" void * __cdecl _decode_pointer(void *)" (?_decode_pointer@@$$J0YAPEAXPEAX@Z) referenced in function "void __cdecl CrtDestroyStatics(void)" (?CrtDestroyStatics@@$$FYAXXZ)
Error   3   error LNK2028: unresolved token (0A000F2F) "extern "C" void * __cdecl _decode_pointer(void *)" (?_decode_pointer@@$$J0YAPEAXPEAX@Z) referenced in function "void __cdecl CrtDestroyStatics(void)" (?CrtDestroyStatics@@$$FYAXXZ)

Хотя у меня есть эти значения библиотек, унаследованные для дополнительных зависимостей в Linker-> Ввод

kernel32.lib
user32.lib
gdi32.lib
winspool.lib
comdlg32.lib
advapi32.lib 

Скажите, пожалуйста, что я сделал неправильно?

  • 0
    Это внутренний код из реализации Microsoft C-runtime. Он уже существует, вы не должны пытаться добавить его снова. Вы получаете ошибки компоновщика, потому что вы компилируете с / MD, настройкой по умолчанию. Который хранит этот код в DLL, msvcr100.dll, он не экспортирует внутренние функции, такие как _decode_pointer (). Использование этого кода - довольно плохая идея.
  • 0
    @HansPassant: Я знаю, что это не очень хорошая практика, Ганс, но я нахожусь в сложной ситуации, которая заставила меня попытаться очистить некоторые статические переменные в момент, когда я решу, спасибо за совет :)
Теги:
linker-errors
visual-studio-2010

1 ответ

0
Лучший ответ

Если _decode_poiner недоступен в вашем ядре32, кажется, что ваша конфигурация настроена неправильно. Если у вас установлена более старая версия VS и обновлена, убедитесь, что компоновщик не указывает на старую среду.

Вы можете проверить здесь дополнительную информацию о том, как решить эту проблему.

  • 0
    Благодаря Devolus кажется, что MS изменила прототип функции и имя, используемое для очистки указателей ... extern "C" void * __cdecl _decode_pointer (void *); изменяется на WINBASEAPI __out_opt PVOID WINAPI DecodePointer (void *); для MSVCRT10.dll

Ещё вопросы

Сообщество Overcoder
Наверх
Меню