Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
kattten
1 / 1 / 0
Регистрация: 26.01.2010
Сообщений: 32
1

Ошибка компиляции undefined reference to `Polygon::Polygon(Point const*, int)'

22.03.2016, 12:43. Просмотров 868. Ответов 6
Метки нет (Все метки)

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include "Polygon.h" 
 
#include <iostream> 
#include <iomanip> 
 
using std::cout; 
using std::endl; 
 
int main() 
{ 
    Point points[4] = {Point(0, 0), Point(0, 5), Point(5, 5), Point(5, 0)}; 
    Polygon Pr(points, 4); 
 
    cout << "polygon: " << Pr << endl; 
    cout << "perimeter = " << Pr << endl; 
    cout << "first point: (" << Pr[0].x << " " << Pr[0].y << ")" << endl; 
}
undefined reference to `Polygon::Polygon(Point const*, int)'
Прошу помощи
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.03.2016, 12:43
Ответы с готовыми решениями:

Ошибка при компиляции undefined reference to `List<int>::List()'|
Доброго времени суток=) столкнулась с такой проблемой нужно написать шаблон...

Ошибка undefined reference to `QueueTp<Worker>::isfull() const'
Здравствуйте. Вот выводятся такие ошибочки. Помогите, плз, разобраться....

Ошибка компиляции единого файла: undefined reference to `vtable for .'
Проблема при компиляции файла: prog.cpp:(.text.startup+0x42): undefined...

PostgreSQL и CLion, ошибка при компиляции undefined reference
Господа знатоки, который день мучаюсь с одной проблемой Изучаю PostgreSQL....

[Linker error] undefined reference to `sterling(int, int, int)'
#include &lt;iostream&gt; using namespace std; int sterling(int,int,int); int...

6
zss
Модератор
Эксперт С++
7470 / 6843 / 4320
Регистрация: 18.12.2011
Сообщений: 18,103
Завершенные тесты: 1
22.03.2016, 12:46 2
В классе Polygon (файл poligon.h) нет конструктора
C++
1
Polygon(Point*, int);
1
Ilot
Эксперт С++
1832 / 1190 / 342
Регистрация: 16.05.2013
Сообщений: 3,139
Записей в блоге: 5
Завершенные тесты: 1
22.03.2016, 12:46 3
kattten, отсутствует реализация конструктора Polygon::Polygon(Point const*, int)
1
kattten
1 / 1 / 0
Регистрация: 26.01.2010
Сообщений: 32
22.03.2016, 13:38  [ТС] 4
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#ifndef __POLYGON_H 
#define __POLYGON_H 
 
#include <ostream> 
 
typedef int Coordinate; //тип значения координаты 
 
//класс точка, она же вершина многоугольника 
class Point 
{ 
public: 
    Coordinate x; 
    Coordinate y; 
 
    //конструкторы для точки - с ними легче жить 
 
    Point() {} //конструктор по умолчанию 
    Point(Coordinate c1, Coordinate c2) //конструктор точки по двум значениям координат 
        : x(c1), y(c2) 
        {} 
}; 
 
 
//класс многоугольник 
class Polygon 
{ 
public: 
    Polygon()                   //конструктор по умолчанию, создаёт пустой мн-к с 0 вершин 
        : n_(0), points_(0) 
        {} 
 
    Polygon(Polygon const& p);              //конструктор копирования 
    Polygon(Point const* points, int n);    //конструктор из массива точек 
   ~Polygon();                              //деструктор 
 
    Point & operator[](int i)        //операция произвольного доступа к вершинам по индексу 
          { return points_[i]; } 
 
    //вывод в поток лучше делать френдом, а не методом класса 
    friend std::ostream& operator <<(std::ostream & os, Polygon const & poly); 
 
    operator float(); //приведение типа к float - возвращает периметр 
 
private: 
    int n_; 
    Point *points_; 
 
    float edge_length(int i); //вспомогательная функция - длина i-го ребра 
};
 
#endif //__POLYGON_H
Добавлено через 15 минут
Собственно выше сам polygon.h
0
nd2
2838 / 2405 / 1057
Регистрация: 29.01.2016
Сообщений: 8,046
22.03.2016, 13:50 5
Цитата Сообщение от kattten Посмотреть сообщение
Собственно выше сам polygon.h
Реализация вот этого конструктора Polygon(Point const* points, int n); где?
1
kattten
1 / 1 / 0
Регистрация: 26.01.2010
Сообщений: 32
22.03.2016, 14:05  [ТС] 6
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include "Polygon.h" 
 
#include <math.h> 
#include <ostream> 
 
 
//конструктор копирования 
Polygon::Polygon(Polygon const& p) 
{ 
    //передадим всю работу конструктору из массива точек, 
    //ведь именно это нам и нужно сделать 
    Polygon::Polygon(p.points_, p.n_); 
} 
 
 
//конструктор из массива точек 
Polygon::Polygon(Point const* points, int n) 
{ 
    n_ = n; 
    points_ = new Point[n]; 
    for(int i = 0; i < n; i++) 
    { 
        points_[i] = points[i]; 
    } 
} 
 
 
//деструктор 
Polygon::~Polygon() 
{ 
    if(points_ == 0) 
        return; 
 
    delete[] points_; 
    points_ = 0; 
    n_ = 0; 
} 
 
 
//вывод в поток 
std::ostream& operator <<(std::ostream & os, Polygon const & poly) 
{ 
    os << "["; 
    for(int i = 0; i < poly.n_; i++) 
    { 
        Point const& p = poly.points_[i]; 
        os << "(" << p.x << "  " << p.y << ") "; 
    } 
    os << "]"; 
    return os; 
} 
 
 
//приведение типа к float - возвращает периметр 
Polygon::operator float() 
{ 
    float P = 0; //здесь будем накапливать периметр 
    for(int i = 0; i < n_; i++) 
    { 
        P += edge_length(i); 
    } 
    return P; 
} 
 
//вспомогательная функция - длина i-го ребра 
//т.е. ребра от i-й вершины до следующей 
float Polygon::edge_length(int i) 
{ 
    if(i < 0) 
    { 
        //рёбер с номерами меньше 0 нет и быть не может 
        //тут можно бы сообщить куда следует об ошибке 
        return 0; 
    } 
 
    if(i >= n_) 
    { 
        //рёбер с номерами больше номера последней вершины тоже нет 
        //тут можно бы сообщить куда следует об ошибке 
        return 0; 
    } 
 
    int j = i + 1; //следующая вершина 
    if(j == n_)    //если i-я вершина была последней 
    { 
        j = 0;     //то j-я это попросту первая 
    } 
 
    Point const& a = points_[i]; 
    Point const& b = points_[j]; 
 
    float dx = b.x - a.x;               //проекция ребра на ось X 
    float dy = b.y - a.y;               //проекция ребра на ось Y 
    float Length = sqrt(dx*dx + dy*dy); //корень из суммы квадратов - гипотенуза прямоугольного треугольника 
 
    return Length;
0
zss
Модератор
Эксперт С++
7470 / 6843 / 4320
Регистрация: 18.12.2011
Сообщений: 18,103
Завершенные тесты: 1
22.03.2016, 14:22 7
Лучший ответ Сообщение было отмечено kattten как решение

Решение

А у Вас действительно файл из предыдущего поста подключен к проекту?

Добавлено через 5 минут
Кстати, чтобы Ваш код откомпилировался мне пришлось исправить
C++
1
typedef float Coordinate; //тип значения координаты
1
22.03.2016, 14:22
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.03.2016, 14:22

Ошибка [Linker error] undefined reference to `Vector::Vector(int)'
Добрый день. Делал по методички, и почему-то валятся ошибки... файл...

Undefined reference to Change_Array(int, int)
Приветствую всех желающих помочь Третьи сутки осваиваю функции C++, вторые...

int const * const foo(const int* param) const - разъясните значение квалификаторов
int const * const foo(const int* param) const ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru