LNK2038, ошибка несоответствия итератора, необходимо игнорировать - PullRequest
5 голосов
/ 27 сентября 2011

Я получаю ошибку компоновщика LNK2038 при попытке преобразовать проект VS2008 в VS2010. Эта ошибка возникает, когда компилируются два разных проекта, в которых один использует макрос препроцессора _DEBUG, а другой - нет. По сути, у меня есть сторонняя библиотека, которая имеет только выпуск .libs, поэтому, когда я пытаюсь использовать эту библиотеку при сборке проекта в режиме отладки, я получаю это несоответствие.

Я понимаю, почему Microsoft выдает эту ошибку (безопасность итератора STL), однако наш проект не использует Microsoft STL, мы используем STLPort, поэтому эта ошибка ничего не значит для нашего проекта. Мне просто нужен способ, чтобы помешать этой проверке.

Внутри STL есть файл с именем yvals.h, который включает определение #pragma detect_mismatch для различных настроек _ITERATOR_DEBUG_LEVEL. Этот набор определений обернут в #ifndef _ALLOW_ITERATOR_DEBUG_LEVEL_MISMATCH, #endif. Однако даже если я определю _ALLOW_ITERATOR_DEBUG_LEVEL_MISMATCH в качестве макроса препроцессора для всего моего проекта, я все равно получаю ту же ошибку компоновщика. Я могу даже изменить yvals.h, чтобы определить этот макрос, и он ничего не делает (я предполагаю, потому что сам STL нужно будет перекомпилировать).

Таким образом, мой вопрос в основном, какие шаги я могу предпринять, чтобы _ALLOW_ITERATOR_DEBUG_LEVEL_MISMATCH фактически работал так, как задумано, чтобы мой проект нигде не делал эту проверку при компиляции в VS2010?

РЕДАКТИРОВАТЬ: Я знаю, что это поздний ответ, но я только что нашел это сообщение и понял, что я не опубликовал решение. Как уже упоминалось, в библиотеках было несоответствие. Оказывается, VS2010 меняет каталоги по умолчанию для определенных проектов (я нашел поток на MSDN в один момент, полный жалоб на это), и это изменение каталога заставило VS2010 искать в неправильном каталоге библиотеку отладки, и это было вместо этого найти библиотеку релизов.

1 Ответ

2 голосов
/ 27 сентября 2011

Вы должны использовать ту же версию стандартной библиотеки, скомпилированную с теми же опциями, если вы ожидаете успешной ссылки.Если вы используете STLPort, то вы можете связываться только с библиотеками, которые используют STLPort, но не с библиотеками, которые используют стандартную реализацию VC ++.Если вы смешаете, либо не сможете установить связь, либо получите странные ошибки времени выполнения.

Проблема в том, что такие вещи, как std::vector<>::iterator, могут быть определены совершенно по-другому;в зависимости от того, где и как они используются, вы обнаружите, что используете экземпляр, созданный в другой библиотеке, с другим макетом.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...