С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/75: Рейтинг темы: голосов - 75, средняя оценка - 4.65
96 / 82 / 22
Регистрация: 19.10.2013
Сообщений: 485

Непобедимый `multiple definition`

02.11.2015, 06:58. Показов 13848. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.

Решил отрефакторить довольно большой проект, уже 10 раз пожалел что взялся за это дело не могу победить чертов multiple definition, которого в явном виде нет.

Весь проект (библиотека) условно разбит на три части:
  1. Публичная часть - заголовки для подключения в других проектах;
  2. Приватная часть - для сборки релиза библиотеки;
  3. Группа приватных классов, подключаемых в приватной части.

С публичной частью проблем не возникло, вычленить её из проекта не составило труда, а вот с приватной - черт ногу сломит. Дело в том, что основной класс приватной части имеет очень-очень много методов, но все эти методы можно опять-таки условно разделить на решаемые ими задачи:

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
#ifndef MYCLASS_H
#define MYCLASS_H
 
class PrivateClass {
  void one_fn1();
  void one_fn2();
 
  void two_fn3();
  void two_fn4();
  /* ... */
}
 
#endif
Поэтому я решил создать не один CPP-файл, а несколько, для того чтобы было удобнее работать с кодом: privateclass.cpp, privateclass_one.cpp, privateclass_two.cpp
Естественно, каждый этот CPP-файл подключает основной заголовочный файл privateclass.h
В общем на данном этапе проект выглядит примерно так:


и все прекрасно компилируется, до тех пор, пока в проекте не появляется еще один приватный класс:


как только в проекте появляется AnotherPrivateClass.h, все переворачивается с ног на голову =/ при компиляции возникает куча варнингов и до 17-ти тысяч(!) ошибок multiple definition! При чем ошибка двойного объявления классов/функций появляется в каждом CPP-файле: и в privateclass.cpp, и в privateclass_one.cpp, и в privateclass_two.cpp. При этом абсолютно во всех заголовочных файлах присутствуют <<include guard's>>


Что я делаю не так?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.11.2015, 06:58
Ответы с готовыми решениями:

multiple definition
Мне в проэкте в двух файлах нужно подключить один и тот же заголовочный файл с другого проэкта(header.h). Этот заголовочный файл подключает...

multiple definition of
Друзья помогите разобраться с проблемой! Функции написаны в одном файле и их надо вызвать в другом, например: #include &quot;OP.cpp&quot;...

Multiple definition
В заголовочном файле создаю переменные который используют функции из этой же единицы трансляции, но происходит multiple definition, если...

6
Модератор
Эксперт С++
 Аватар для zss
13770 / 10963 / 6491
Регистрация: 18.12.2011
Сообщений: 29,240
02.11.2015, 07:06
А все another_privateclass Тоже так оформлены
C++
1
2
3
4
5
6
7
8
9
#ifndef ANOTHER_MY_PRIVATE_CLASS_H
#define ANOTHER_MY_PRIVATE_CLASS_H
 
class AnotherMyPrivateClass {
 
  /* ... */
};
 
#endif
0
96 / 82 / 22
Регистрация: 19.10.2013
Сообщений: 485
02.11.2015, 07:12  [ТС]
Конечно же! Более того, так оформлены все подключаемые заголовочные файлы фреймворка Qt, на которые тоже жалуется компилятор.

Если я уберу все эти privateclass.cpp, privateclass_one.cpp, privateclass_two.cpp, privateclass_three.cpp ... и весь код засуну в один файл, который превратится в огромнейшую простыню, все снова будет компилироваться без проблем. Но я хотел уйти от этого, потому что это жутко неудобно
0
542 / 163 / 79
Регистрация: 23.09.2013
Сообщений: 316
02.11.2015, 07:14
WxMaper,
1) проверьте не включены ли .cpp .cc .c файлы в загловочные файлы или в другие source файлы.
2) Проверьте, везде ли в .h файлах стоят header guard - аля
C++
1
2
3
4
#ifndef MYCLASS_H
#define MYCLASS_H
 
#endif
3) особенно внимательно проверьте отсутствие пересечения имен используемых в #define хедер гвардов.
4) особенно внимательно проверьте отсутствие ошибок в #define хедер гвардов аля:

C++
1
2
3
4
#ifndef MYCLASS_H
#define MYCLAS_H
 
#endif
или

C++
1
2
3
4
#ifdef MYCLASS_H
#define MYCLASS_H
 
#endif
5) особенно внимательно проверьте систему сборки проекта, не включен ли один и тот же файл .cpp в проект дважды, не включена ли стара и новая реализации файла.
6) Проверьте не пытаетесь ли вы использовать реализации классов qt определенные самостоятельно (скопированные в проект).
7) Постарайтесь выделить из проекта минимальное количество кода, которое воспроизводит ошибку. Можете попробовать сделать из этого кода отдельный проект - я думаю уже на этом этапе станет очевидным что именно Вам мешает.
8) если вышеперечисленное не поможет, предоставьте исходный код минимально воспроизводящего проблему проекта на обозрение публики.
0
96 / 82 / 22
Регистрация: 19.10.2013
Сообщений: 485
02.11.2015, 07:22  [ТС]
  1. Исключено! Никогда не инклужу cpp файлы;
  2. Гуарды имеется во всех файлах, все файлы были созданы QtCreator'ом, т.е. в ручную я код не оформлял (ну кроме тел функций)
  3. Имена не повторяются, все файлы и классы имеют уникальные названия
  4. Пункт 2 :-)
  5. Проверял, в файле .pro все чисто, создавался он тоже не вручную
  6. Только наследование
7, 8 - буду пробовать
0
694 / 304 / 99
Регистрация: 04.07.2014
Сообщений: 851
02.11.2015, 09:49
Пробовал удалить build-директорию? И собрать заново.
В Pro-файле нету ли дубликатов в "SOURCES+="?
0
96 / 82 / 22
Регистрация: 19.10.2013
Сообщений: 485
02.11.2015, 10:01  [ТС]
Цитата Сообщение от AlexVRud Посмотреть сообщение
Пробовал удалить build-директорию? И собрать заново.
Да пробовал, результат нулевой. Сейчас выдирал куски кода из проекта и, кажется, нашел в чем проблема была: проект перестает нормально компилировался после того как в нем появляются подключения заголовочных файлов PHP:

C++ (Qt)
1
2
#include "php.h"
#include <QObject>
- такой код не компилируется, появляются ошибки двойного переопределения методов QObject.

C++ (Qt)
1
2
#include <QObject>
#include "php.h"
- такой код прекрасно компилируется и работает. ОМГ! Либо я дурак, либо даже не знаю что и думать еще =)
Подключить заголовочные файлы пыха по такой схеме во всем проекте не получается, все равно встречаются места когда PHP объявляется раньше, чем Qt. До рефакторинга была именно такая схема - один единственный файл cpp, который инклудил свой заголовочный файл, который инклудил заголовочные файлы PHP в самую последнюю очередь.

C++ (Qt)
1
2
3
extern "C" { 
#include "php.h" 
} // не помогает
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.11.2015, 10:01
Помогаю со студенческими работами здесь

Ошибка multiple definition
В строке 4 компилятор выдает ошибку &quot;multiple definition of 'fin'&quot;. Проблема в том, что в этой строке вообще нет слова fin. Объясните,...

multiple definition of perebor(int)
//ôóíêöèÿ ïåðåáèðàåò ÷èñëà //è íà êàæäîå ÷èñëî äåéñòâóåò ôóíêöèåé proverka #include &lt;cstdlib&gt; #include &lt;iostream&gt; #include...

Multiple definition - несколько определений
Написал программу(не очень слаженную, но) используя множественное наследование. #include &lt;/home/demien/Рабочий...

Multiple definition для константы
Есть некий заголовочный файл с набором констант, который нужен во многих классах: #ifndef RCCCONSTS_H #define RCCCONSTS_H ...

Что такое multiple definition of
Здравствуйте форумчане, объясните новичку почему компилятор ругается, что я не правильно делаю? Я создал два класса Date и Book и решил...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru