Ошибка c2679 бинарный не найден оператор

Сохраняю с CSV файла в вектор. После этого нужно вывести 5 случайных людей:

vector<vector<string>> Man;

for (int i = 0; i < 5; i++) {
    auto  k = rand() % Man.size();

    for (auto l = Man[k].begin(); l < Man[k].end(); l++) {
        cout << Man[k][l] << " ";                             // ←——— тут ошибка
    }

    cout << endl;
}

Ошибка:

C2679    бинарный "[": не найден оператор, принимающий правый операнд типа "std::_Vector_iterator<std::_Vector_val<std::_Simple_types<_Ty>>>" (или приемлемое преобразование отсутствует)   Project9    c:usersost1m1ronsourcereposproject9project9source.cpp    107

eanmos's user avatar

eanmos

6,6416 золотых знаков29 серебряных знаков52 бронзовых знака

задан 1 авг 2018 в 15:29

ost1m1ron -'s user avatar

1

Ошибка в том, что вы пытаетесь получить значение отправляя в operator[] не индекс(size_t), а итератор!!

Когда вы пишите auto l = Man[k].begin(), это и есть итератор на конкретный элемент, т.е. чтобы получить данные достаточно просто разыменовать итератор.

vector<vector<string>> Man;
for (int i = 0; i < 5; i++)
{
    auto  k = rand() % Man.size();
    for (auto l = Man[k].begin(); l < Man[k].end(); ++l)
    {
        cout << *l << " "; // SUPERMAN
    }
    cout << endl;
}

Пару советов:

  1. Используйте префиксный инкремент (++i, а не i++). Это особенно касается невстроенных типов.
  2. Вы пишите в условии цикла l < Man[k].end(). Вы на каждой итерации вызываете Man::operator[] и end(). Лучше будет получить перед внутренним циклом значение end() и дальше сравнивать. И сравнивать не оператором< а оператором!=.

ответ дан 1 авг 2018 в 15:43

acade's user avatar

acadeacade

1,7361 золотой знак5 серебряных знаков10 бронзовых знаков

3

 for (auto l = Man[k].begin(); l < Man[k].end(); l++) {
     cout << Man[k][l] << " "; 
 }
l  это итератор и нельзя его использовать как индекс.
Поэтому нужно поменять на:

for (auto l = Man[k].begin(); l != Man[k].end(); l++) {
    cout << *l << " "; 
}

ответ дан 1 авг 2018 в 15:49

AR Hovsepyan's user avatar

AR HovsepyanAR Hovsepyan

15.8k3 золотых знака13 серебряных знаков30 бронзовых знаков

2

description title ms.date f1_keywords helpviewer_keywords ms.assetid

Learn more about: Compiler Error C2679

Compiler Error C2679

11/04/2016

C2679

C2679

1a5f9d00-9190-4aa6-bc72-949f68ec136f

Compiler Error C2679

binary ‘operator’ : no operator found which takes a right-hand operand of type ‘type’ (or there is no acceptable conversion)

To use the operator, you must overload it for the specified type or define a conversion to a type for which the operator is defined.

The following sample generates C2679:

// C2679.cpp
class C {
public:
   C();   // no constructor with an int argument
} c;

class D {
public:
   D(int) {}
   D(){}
} d;

int main() {
   c = 10;   // C2679
   d = 10;   // OK
}

karlhildekruger

46 / 31 / 19

Регистрация: 09.05.2022

Сообщений: 259

1

05.06.2022, 21:27. Показов 1626. Ответов 13

Метки нет (Все метки)


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

C++
1
2
3
4
        void SerializeInstitute(ofstream& fileStream, Institute imi)
        {
            fileStream << "Course{n" << endl << "Students: " << imi.getStudents() << endl << "Lecturers: " << imi.getLecturers() << endl << "getCourses: " << imi.getCourses() << "getMarks: " << imi.getMarks()  << endl << "}";
        }

Ошибка:

Код

Серьезность	Код	Описание	Проект	Файл	Строка	Состояние подавления
Ошибка	C2679	бинарный "<<": не найден оператор, принимающий правый операнд типа "std::vector<stud::Student,std::allocator<stud::Student>>" (или приемлемое преобразование отсутствует)	204

геттер из класса Institute, который я пытаюсь сериализовать в текстовый файл

C++
1
2
3
4
vector<Student> Institute::getStudents()
{
        return students;
};



0



Programming

Эксперт

94731 / 64177 / 26122

Регистрация: 12.04.2006

Сообщений: 116,782

05.06.2022, 21:27

Ответы с готовыми решениями:

Ошибка C2679: бинарный ‘=’: не найден оператор, принимающий правый операнд типа ‘double’
// ConsoleApplication2.cpp : Defines the entry point for the console application.
//

#include…

Error C2679: бинарный «=»: не найден оператор, принимающий правый операнд типа
Сразу скажу что в с++ полный ноль. Но есть потребность решить такую вот задачу:
Нужно собрать…

Возвращение кортежа — error C2679: бинарный «=»: не найден оператор, принимающий правый операнд типа
Привет
есть функция, которая возвращает кортеж

tuple&lt;X**, Math, int, int,…

Error C2679: бинарный «<<«: не найден оператор, принимающий правый операнд типа «std::string» (или приемлемое
эмулятор работы банкомата
Например

#include &quot;stdafx.h&quot;

#include &lt;iostream&gt;
#include…

Error C2679: бинарный «=»: не найден оператор, принимающий правый операнд
Ошибка 1 error C2679: бинарный &quot;=&quot;: не найден оператор, принимающий правый операнд типа…

13

17427 / 9259 / 2264

Регистрация: 30.01.2014

Сообщений: 16,215

05.06.2022, 21:48

2

karlhildekruger, вам нужно определить оператор << для типа vector<Student>.



0



karlhildekruger

46 / 31 / 19

Регистрация: 09.05.2022

Сообщений: 259

05.06.2022, 22:23

 [ТС]

3

Это правильно?

C++
1
2
3
4
5
6
7
8
template<class T>
ostream& operator<<(std::ostream& os, const vector<T>& vect)
{
    for (size_t i = 0; i < vect.size(); ++i)
        os << vect[i] << "t";
    os << "n";
    return os;
}

Выдает ошибку

Код

Серьезность	Код	Описание	Проект	Файл	Строка	Состояние подавления
Ошибка	C2679	бинарный "<<": не найден оператор, принимающий правый операнд типа "const _Ty" (или приемлемое преобразование отсутствует)



0



17427 / 9259 / 2264

Регистрация: 30.01.2014

Сообщений: 16,215

05.06.2022, 23:25

4

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

Это правильно?

Правильно. И для Student тоже должен быть такой оператор.

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

Выдает ошибку

В какой строке?



0



46 / 31 / 19

Регистрация: 09.05.2022

Сообщений: 259

05.06.2022, 23:35

 [ТС]

5

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

os << vect[i] << «t»;

Ошибка в этой строке



0



17427 / 9259 / 2264

Регистрация: 30.01.2014

Сообщений: 16,215

05.06.2022, 23:59

6

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

Ошибка в этой строке

Цитата
Сообщение от DrOffset
Посмотреть сообщение

для Student тоже должен быть такой оператор



0



karlhildekruger

46 / 31 / 19

Регистрация: 09.05.2022

Сообщений: 259

06.06.2022, 00:12

 [ТС]

7

Не работает. Выводит те же ошибки

C++
1
2
3
4
5
6
7
ostream& operator<<(std::ostream& os, const Student& s)
{
        os << s.getStudentNo();
        os << s.getGroupName();
    os << "n";
    return os;
}



0



17427 / 9259 / 2264

Регистрация: 30.01.2014

Сообщений: 16,215

06.06.2022, 00:13

8

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

Не работает.

Значит вы что-то не так сделали.
Покажите весь код.



0



karlhildekruger

46 / 31 / 19

Регистрация: 09.05.2022

Сообщений: 259

06.06.2022, 00:16

 [ТС]

9

Student.h

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
#pragma once
#ifndef STUDENT_H
#define STUDENT_H
#include <iostream>
#include <string>
#include <vector>
#include "Person.h"
using namespace std;
using namespace per;
namespace stud
{
class Student :public Person
{private:
    string StudentNo = "123";
    string GroupName = "FIIT-21";
 
public:
    void setStudentNo(string newStudentNo);
    void setGroupName(string newGroupName);
    string getStudentNo();
    string getGroupName();
    
};
}
 
#endif

institute.h

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
#pragma once
#ifndef _INSTITUTE_H_
#define _INSTITUTE_H_
#include <string>
#include <vector>
#include "Student.h"
#include "Lecturer.h"
#include "Course.h"
#include "Mark.h"
using namespace mar;
using namespace cours;
using namespace stud;
using namespace std;
using namespace lect;
namespace insti
{
    class Institute
    {
    private:
        vector<stud::Student>students;
        vector<lect::Lecturer>lecturers;
        vector<cours::Course>courses;
        vector<mar::Mark>marks;
 
    public:
        void AddStudent(stud::Student newStudent);
        vector<Student>GetStudentsGroup(std::string groupName);
        Student GetStudent(std::string studentNo);
        bool DeleteStudent(std::string studentNo);
        void AddEmployee(Lecturer employee);
        Lecturer GetEmployee(int personnelNo);
        bool DeleteEmployee(int personnelNo);
        void AddCourse(Course course);
        Course GetCourse(int id);
        bool DeleteCourse(int id);
        void AddMark(Mark tmpMarks);
        vector<Mark> GetCourseMarks(int courseId);
        vector<Mark> GetStudentMarks(std::string studentNo);
        vector<Mark> GetGroupMarks(std::string groupName);
        vector<Student> getStudents();
        vector<Lecturer> getLecturers();
        vector<Course> getCourses();
        vector<Mark> getMarks();
 
    };
}
 
#endif

serializer.h

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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
#pragma once
#define _CRT_SECURE_NO_WARNINGS
#include<fstream>
#include"Person.h"
#include "Institute.h"
#include"Lecturer.h"
#include "Student.h"
#include <string>
#include <vector>
#include"Mark.h"
#include"Course.h"
#include "Institute.h"
using namespace insti;
using namespace per;
using namespace lect;
using namespace stud;
using namespace mar;
using namespace cours;
using namespace std;
 
 
template<class T>
ostream& operator<<(std::ostream& os, const vector<T>& vect)
{
    for (size_t i = 0; i < vect.size(); ++i)
        os << vect[i];
    os << "n";
    return os;
}
 
ostream& operator<<(std::ostream& os, const Student& s)
{
        os << s.getStudentNo();
        os << s.getGroupName();
    os << "n";
    return os;
}
 
 
 
namespace seria
{
 
    class Serializer
    {
    public:
        void SerializePerson(std::ofstream& fileStream, Person person)
        {
            fileStream << "Person{n" << person.get_FIO() << endl << person.get_Email() << endl;
        };
 
 
        Person DeserializePerson(std::ifstream& fileStream)
        {
            
            string s;
            getline(fileStream, s);
            Person person;
            if (s.compare("Person") == 0)
            {
                fileStream >> s; //"{"
                string n;
                fileStream >> n;  
                person.set_FIO(n);
                fileStream >> n;
                person.set_Email(n);
                return person;
            }
        };
 
 
 
 
 
 
 
 
 
        void SerializeLecturer(std::ofstream& fileStream, Lecturer lecturer)
        {
            fileStream << "Lecturer{n" <<"fio: "<< lecturer.get_FIO() << endl<<"email: " << lecturer.get_Email() << endl<<"position: " << lecturer.getPosition() << endl<<"personnelNo: " << lecturer.getPersonnelNo() << "n}";
        };
        Lecturer DeserializeLecturer(std::ifstream& fileStream)
        {
            string s;
            getline(fileStream, s);
            Lecturer lecturer;
            if (s.compare("Lecturer") == 0)
            {
                fileStream >> s; //"{"
                string n;
                fileStream >> n;    //превращение строки в объект (обратная операция сериализации, когда мы заносили объект в текстовый файл)
                lecturer.set_FIO(n);
                fileStream >> n;
                lecturer.set_Email(n);
                fileStream >> n;
                lecturer.setPosition(n);
                int nn;fileStream >> nn;
                lecturer.setPersonnelNo(nn);
                return lecturer;
            }
        };
    
 
 
 
 
 
 
 
 
 
 
 
        void SerializeStudent(std::ofstream& fileStream, Student student)
        {
            SerializePerson(fileStream, student);
            fileStream <<"Group: " << student.getGroupName() << endl <<"Student Number: " << student.getStudentNo() << endl << "}";
        };
 
        Student DeserializeStudent(std::ifstream& fileStream)
        {
 
            /*
            string s;
            getline(fileStream, s);
            Person person;
            if (s.compare("Person") == 0)
            {
                fileStream >> s; //"{"
                string n;
                fileStream >> n;  
                person.set_FIO(n);
                fileStream >> n;
                person.set_Email(n);
                return person;
            }*/
 
 
 
 
            string s;
            getline(fileStream, s);
            Student student;
            if (s.compare("Person") == 0)
            {
                fileStream >> s; //"{"
                string n;
                fileStream >> n;    //фио и мейл уже записаны из Person
                student.setStudentNo(n);
                fileStream >> n;
                student.setGroupName(n);
                return student;
            }
        };
 
 
 
 
 
        void SerializeMark(std::ofstream& fileStream, Mark mark)
        {
            fileStream << "Mark{n" << "year: " << mark.getYear() << endl << "StudentNo: " << mark.getStudentNo() << endl << "Coursed: " << mark.getCourseId() << endl << "Mark: " << mark.getMark() << endl << "}";
        };
        Mark DeserializeMark(std::ifstream& fileStream)
        {
            string s;
            getline(fileStream, s);
            Mark mark;
            if (s.compare("Mark") == 0)
            {
                fileStream >> s; //"{"
                int n;
                fileStream >> n;    //превращение строки в объект (обратная операция сериализации, когда мы заносили объект в текстовый файл)
                mark.setYear(n);
                string s;
                fileStream >> s;
                mark.setStudentNo(s);
                fileStream >> n;
                mark.setCourseId(n);
                fileStream >> n;
                mark.setMark(n);
                return mark;
            }
        };
 
 
 
 
 
 
 
 
 
 
 
 
        void SerializeCourse(std::ofstream& fileStream, Course course)
        {
            Lecturer lecturer;
            fileStream << "Course{n" << "Subject: " << course.getSubject() << endl << "Semester: " << course.getSemester() << endl << "PersonnelNo: " << lecturer.getPersonnelNo() << endl << "}";
        };
        Course DeserializeCourse(std::ifstream& fileStream)
        {
            string s;
            getline(fileStream, s);
            Course course;
            Lecturer lect;
            if (s.compare("Course") == 0)
            {
                fileStream >> s; //"{"
                int n;
                string s;
                fileStream >> s;    //превращение строки в объект (обратная операция сериализации, когда мы заносили объект в текстовый файл)
                course.setSubject(s);
                fileStream >> n;
                course.setSemester(n);
                fileStream >> n;
                lect.setPersonnelNo(n);
                return course;
            }
        };
 
 
        void SerializeInstitute(ofstream& fileStream, Institute imi)
        {
            fileStream  <<imi.getStudents() << endl << "Lecturers: " << imi.getLecturers() << endl << "getCourses: " << imi.getCourses() << "getMarks: " << imi.getMarks() << endl << "}";
 
        }
 
 
 
        Institute DeserializeInstitute(ifstream fileStream)
        {
                string s;
    getline(fileStream, s);
    Institute institute;
    if (s.compare("Institute") == 0)
    {
        
        fileStream >> s; //"{"
         Course c;
         int s;
        fileStream >> s;
        c.setSemester(s);
        institute.AddCourse(c);
 
        Lecturer l;
        string ts;
        fileStream >> ts;
        l.set_FIO(ts);
        institute.AddEmployee(l);
 
        Mark m;
        int fs;
        fileStream >> fs;
        m.setMark(fs);
        institute.AddMark(m);
 
        Student a;
        string ss;
        fileStream >> ss;
        a.set_FIO(ss);
        institute.AddStudent(a);
 
        
        return institute;
    }
};
 
        
 
 
 
 
        //Person DeserializePerson(std::ifstream& fileStream)
        //{
 
        //  string s;
        //  getline(fileStream, s);
        //  Person person;
        //  if (s.compare("Person") == 0)
        //  {
        //      fileStream >> s; //"{"
        //      string n;
        //      fileStream >> n;
        //      person.set_FIO(n);
        //      fileStream >> n;
        //      person.set_Email(n);
        //      return person;
        //  }
        //};
 
 
 
 
    };
}



0



2341 / 1868 / 606

Регистрация: 29.06.2020

Сообщений: 7,056

06.06.2022, 00:32

10

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

os << s.getStudentNo();
        os << s.getGroupName();

Эти методы у класса Student, не константные, а вы пытаетесь их вызвать от константного объекта.
Вот и ошибка.
Если они не изменяют состояния класса, сделайте их константными. (методы класса Student : getStudentNo и getGroupName

Добавлено через 2 минуты

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

string StudentNo = «123»;
    string GroupName = «FIIT-21»;

Улыбнуло )



0



DrOffset

17427 / 9259 / 2264

Регистрация: 30.01.2014

Сообщений: 16,215

06.06.2022, 00:40

11

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

Выводит те же ошибки

Ну, как минимум не те же.
Судя по коду у вас абсолютно все ваши классы должны быть снабжены соответствующими операторами <<, вы это сделали?
Например, у вас в строке

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

C++
1
fileStream <<imi.getStudents() << endl << "Lecturers: " << imi.getLecturers() << endl << "getCourses: " << imi.getCourses() << "getMarks: " << imi.getMarks() << endl << "}";

getLecturers, getMarks, getCourses приводят к вызову operator<< для Course, Lecturer и Mark. Скорее всего они все у вас отсутствуют.

Также у вас в реализации оператора << для Student используется константная ссылка (что правильно), но функции используемые внутри него string getStudentNo(); и string getGroupName(); объявлены без const. Для остальных классов это тоже видимо будет справедливо. Следите за const-корректностью.



0



46 / 31 / 19

Регистрация: 09.05.2022

Сообщений: 259

06.06.2022, 01:43

 [ТС]

12

сделал для всех операторов определение, все сделал константными, появились другие ошибки

Код

Серьезность	Код	Описание	Проект	Файл	Строка	Состояние подавления
Ошибка	LNK2005	"class std::basic_ostream<char,struct std::char_traits<char> > & __cdecl operator<<(class std::basic_ostream<char,struct std::char_traits<char> > &,class stud::Student const &)" (??6@YAAEAV?$basic_ostream@DU?$char_traits@D@std@@@std@@AEAV01@AEBVStudent@stud@@@Z) уже определен в Main.obj	C:УЧЕБАСРСSerializer.obj	1

Код

Серьезность	Код	Описание	Проект	Файл	Строка	Состояние подавления
Ошибка	LNK1169	обнаружен многократно определенный символ - один или более	1



0



Вездепух

Эксперт CЭксперт С++

10932 / 5922 / 1621

Регистрация: 18.10.2014

Сообщений: 14,885

06.06.2022, 02:04

13

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

появились другие ошибки

Ну так в ошибке же написано, в чем проблема.

Скорее всего вы засунули определение оператора << для Student в заголовочный файл. Да, вижу, что так и есть — в serializer.h.

В заголовочный файл можно помещать только определения особых категорий

1. Определения шаблонов
2. Inline определения
3. Определения с внутренним связыванием

Ваш оператор << не принадлежит ни к одной из этих категорий.



0



alecss131

Модератор

Эксперт Java

2442 / 1003 / 346

Регистрация: 11.08.2017

Сообщений: 3,093

06.06.2022, 11:18

14

Цитата
Сообщение от karlhildekruger
Посмотреть сообщение

C++
1
2
3
4
5
6
7
8
template<class T>
ostream& operator<<(std::ostream& os, const vector<T>& vect)
{
 for (size_t i = 0; i < vect.size(); ++i)
 os << vect[i] << "t";
 os << "n";
 return os;
}

Зачем так сложно? можно короче

C++
1
2
3
4
5
6
template<class T>
std::ostream& operator<<(std::ostream& os, const std::vector<T>& vect) {
 std::copy(vect.begin(), vect.end(), std::ostream_iterator<T>(std::cout, "t"));
 os << std::endl;
 return os;
}



0



IT_Exp

Эксперт

87844 / 49110 / 22898

Регистрация: 17.06.2006

Сообщений: 92,604

06.06.2022, 11:18

14

I’ve got the following when building a graph.

#include <vector>
using namespace std;

template<class T>
class Node
{
private:
  T data;
  Node<T> *link;
  vector<T>  neighbors;
public:
  Node(){neighbors = new vector<T>();};
};

int main()
{
  Node<int> n;
  return 0;
}

… which returns the error C2679: binary ‘=’: no operator found…

I’m using VS2010. What’s wrong?
Thanks!

asked Nov 17, 2010 at 16:17

soulia's user avatar

The new operator returns a pointer type, but your member variable neighbors is not a pointer. So you’re assigning a pointer (the result of new) to a non-pointer type. Your neighbors variable needs to be a pointer: vector<T>* neighbors.

But I think you’re probably misunderstanding the use of new here. You probably shouldn’t even use a vector pointer at all. Just remove the line neighbors = new vector<T>(). The vector object will be automatically initialized and ready for use.

In C++, the new keyword allocates and initializes objects on the heap, which then must be freed later using delete. It’s preferable to avoid the new keyword by simply initializing the object as an automatic variable, like:

vector<T> neighbors;

This way, you don’t have to worry about memory management, and the vector object will automatically be destroyed when it goes out of scope.

answered Nov 17, 2010 at 16:19

Charles Salvia's user avatar

Charles SalviaCharles Salvia

52.1k13 gold badges128 silver badges140 bronze badges

1

vector<T>  neighbors;
neighbors = new vector<T>();

neighbours is not a pointer.

The whole point of using vectors is not managing the memory explicitly.
In fact in your node constructor, neighbours is default-initialized, so just don’t initialize. Your constructor may look like this:

Node(){}

So you can just omit it :)

answered Nov 17, 2010 at 16:19

Armen Tsirunyan's user avatar

Armen TsirunyanArmen Tsirunyan

130k59 gold badges324 silver badges434 bronze badges

The problem occurs in Visual Studio 2005 but works in Vc++6.0

rx_fastset.h

struct SortedAppender

{


typedef Std:: output_iterator_tag iterator_category;

typedef BASE value_type;

typedef ptrdiff_t difference_type;

typedef BASE* pointer;

typedef BASE& reference;

sortedAppender(FastSet& fastSet): m_fastSet(fastSet) {}

sortedAppender& operator=(value_type v) { m_fastSet.sortedAppend(v); return *this;}

sortedAppender& operator*() { return *this; }

sortedAppender& operator++() { return *this; }

sortedAppender& operator++(int) { return *this; }

FastSet& m_fastSet;

};

rx_vist.cpp

inline

void SetUnion(const NodeIdSet& leftSet, const NodeIdSet& rightSet, NodeIdSet& unionSet)

{

assert(unionSet.empty());

std:: set_union(leftSet.begin(), leftSet.end(),

rightSet.begin(), rightSet.end(),

NodeIdSet:: sortedAppender(unionSet));

}

I am getting the following errors..

rx_vist.cpp

c:program filesmicrosoft visual studio 8vcincludealgorithm(3815) : error C2679: binary ‘=’ : no operator found which takes a right-hand operand of type ‘RX:: FastSet<BASE>:: sortedAppender’ (or there is no acceptable conversion)

with

[

BASE=RX::NodeId

]

c:arx_fastset.h(63): could be ‘RX::FastSet<BASE>:: sortedAppender &RX:: FastSet<BASE>:: sortedAppender:: operator =(unsigned int)’

with

[

BASE=RX::NodeId

]

while trying to match the argument list ‘(RX::FastSet<BASE>:: sortedAppender, RX::FastSet<BASE>:: sortedAppender)’

with

[

BASE=RX::NodeId

]

c:program filesmicrosoft visual studio 8vcincludealgorithm(3850) : see reference to function template instantiation ‘_OutIt std:: _Set_union<std:: _Vector_const_iterator<_Ty,_Alloc>,std::_Vector_const_iterator<_Ty,_Alloc>,_OutIt>(_InIt1,_InIt1,_InIt2,_InIt2,_OutIt,std::_Range_checked_iterator_tag)’ being compiled

with

[

_OutIt=RX::FastSet<RX::NodeId>:: sortedAppender,

_Ty=RX::NodeId,

_Alloc=std::allocator<RX::NodeId>,

_InIt1=std::_Vector_const_iterator<RX::NodeId,std::allocator<RX::NodeId>>,

_InIt2=std::_Vector_const_iterator<RX::NodeId,std::allocator<RX::NodeId>>

]

c:arx_vist.cpp(77) : see reference to function template instantiation ‘RX::FastSet<BASE>:: sortedAppender std:Tongue Tiedet_union<std::_Vector_const_iterator<_Ty,_Alloc>,std::_Vector_const_iterator<_Ty,_Alloc>,RX::FastSet<BASE>:: sortedAppender>(_InIt1,_InIt1,_InIt2,_InIt2,_OutIt)’ being compiled

with

[

BASE=RX::NodeId,

_Ty=RX::NodeId,

_Alloc=std::allocator<RX::NodeId>,

_InIt1=std::_Vector_const_iterator<RX::NodeId,std::allocator<RX::NodeId>>,

_InIt2=std::_Vector_const_iterator<RX::NodeId,std::allocator<RX::NodeId>>,

_OutIt=RX::FastSet<RX::NodeId>:: sortedAppender

]

c:program filesmicrosoft visual studio 8vcincludealgorithm(3815) : error C2582: ‘operator =’ function is unavailable in ‘RX::FastSet<BASE>:: sortedAppender’

with

[

BASE=RX::NodeId

]

Any help in this would be grateful.

Понравилась статья? Поделить с друзьями:
  • Ошибка c2589 недопустимая лексема справа от
  • Ошибка c257 00 форд фокус 3
  • Ошибка c2440 невозможно преобразовать int в int
  • Ошибка c2440 инициализация невозможно преобразовать
  • Ошибка c240201 kia какой электромотор