Предположим, у вас есть большой проект, написанный на c ++, который содержит тысячу файлов .cpp и тысячу файлов .h. И давайте предположим, что проект также зависит от десяти статических библиотек. Скажем, мы работаем над Windows, и мы строим наш проект в Visual Studio 20xx. Когда вы нажимаете Ctrl + F7 Visual Studio, чтобы начать компиляцию всего решения (предположим, что у нас есть только один проект в решении)
В чем смысл компиляции?
Второй этап компиляции выполняется Linker.Linker должен объединить весь объектный файл и построить окончательно вывод (который может быть исполняемым или библиотекой)
Шаги по связыванию проекта
error LNK2001: unresolved external symbol "void __cdecl foo(void)" (?foo@@YAXXZ)
Наблюдение
Как решить эту ошибку
Ошибка времени компилятора:
Ошибка времени компоновщика
#pragma once
, чтобы компилятор не включал один заголовок если он уже был включен в текущий .cpp, который скомпилирован . Почти во всех случаях эта ошибка вызвана одной из двух причин. К счастью, для этого есть простая проверка.
Прежде всего убедитесь, что вы находитесь на линии, где происходит ошибка, этого обычно можно достичь, используя dbstop if error
, прежде чем запускать свою функцию или скрипт. Теперь мы можем проверить первую проблему:
. Найти каждую переменную и посмотреть, как они индексируются. Индексируемая переменная обычно находится в одной из следующих форм:
variableName(index,index)
variableName{index,index}
variableName{indices}(indices)
Теперь просто посмотрите на материал между скобками и выберите каждый индекс. Затем нажмите f9
, чтобы оценить результат и проверить, является ли оно реальным положительным целым или логическим. Визуальный осмотр обычно достаточен (помните, что допустимые значения находятся в true, false или 1,2,3, ... BUT NOT 0), но для большой матрицы вы можете использовать такие вещи, как isequal(index, round(index))
или более точно isequal(x, max(1,round(abs(x))))
для проверки действительных натуральных чисел. Чтобы проверить класс, вы можете использовать class(index)
, который должен возвращать «логический», если все значения являются «истинными» или «ложными».
Обязательно проверьте каждый индекс, даже те, которые выглядят необычно, как в примере ниже. Если все индексы проверяются, вы, вероятно, сталкиваетесь со второй проблемой:
. Функции MATLAB часто имеют очень интуитивные имена. Это удобно, но иногда приводит к случайным перегрузкам (встроенным) функциям, т. Е. Созданию переменной с тем же именем, что и функция, например, вы можете пойти max = 9
, а для остальной части вашего скрипта / функции Matlab рассмотрит max
как вместо переменной max
вместо переменной max
вы получите эту ошибку, если вы попробуете что-то вроде max([1 8 0 3 7])
, потому что вместо возврата максимального значения этого вектора Matlab теперь предполагает, что вы пытаетесь индексировать переменную max
и 0
является недопустимым индексом.
Чтобы проверить, какие переменные у вас есть, вы можете посмотреть рабочее пространство. Однако, если вы ищете системный подход, здесь один:
Для каждой буквы или слова, за которым следуют скобки ()
, и не подтверждено, что на шаге 1 указаны правильные индексы. Проверьте, фактически переменная. Это можно легко сделать, используя which
.
Простое появление недопустимого индекса
a = 1;
b = 2;
c = 3;
a(b/c)
Здесь мы будем оценивать b/c
и найдите, что это не очень округленное число.
Сложное появление недопустимого индекса
a = 1;
b = 2;
c = 3;
d = 1:10;
a(b+mean(d(cell2mat({b}):c)))
Я рекомендую работать наизнанку. Поэтому сначала оцените индексирование самой внутренней переменной: d
. Оказывается, cell2mat({b}):c
хорошо оценивает целые числа. Затем оцените b+mean(d(cell2mat({b}):c))
и найдем, что у нас нет целочисленного или логического индекса в a
.
Здесь мы будем оценивать b/c
и находим, что это не очень округленное число.
Перегрузка функции
which mean
% some directory\filename.m
Вы должны увидеть что-то подобное, чтобы фактически подтвердить, что что-то является функцией.
a = 1:4;
b=0:0.1:1;
mean(a) = 2.5;
mean(b);
Здесь мы видим, что mean
случайно назначен. Теперь мы получаем:
which mean
% mean is a variable.
В Matlab (и большинстве других языков программирования) знак умножения всегда должен быть записан. Хотя в вашем математическом классе вы, вероятно, узнали, что вместо a*(a+a)
вы можете написать write a(a+a)
, это не то же самое в matlab. Первый - это вызов индексирования или функции, а второй - умножение.
>> a=0
a =
0
>> a*(a+a)
ans =
0
>> a(a+a)
Subscript indices must either be real
positive integers or logicals.
Ответы на этот вопрос до сих пор были сосредоточены на источниках этой ошибки, что здорово. Но важно понять мощную, но очень интуитивную функцию индексирования матриц в Matlab. Следовательно, , как работают индексирование и , что является допустимым индексом , во избежание этой ошибки, в первую очередь, используя допустимые индексы.
В своей основе данный массив A
длины n
, есть два способа его индексирования.
1 : n
(допускаются дубликаты). 0 не допускается, так как массивы Matlab основаны на 1, если вы не используете метод ниже. Для многомерных массивов несколько индексов внутренне преобразуются в линейный индекс , хотя эффективным и прозрачным образом. Итак, допустимый индексный массив в другой массив с n числом элементов ca be:
Помня об этом, неверная ошибка индексации возникает, когда вы смешиваете два типа индексирования: один или несколько нулей встречаются в линейном индексирующем массиве, или вы смешиваете 0 и 1 с чем-то другим, кроме 0 и 1 с :).
Существует много материалов онлайн, чтобы узнать это, включая этот : http://www.mathworks.com/company/newsletters/articles/matrix-indexing-in-matlab.html