Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
3 / 3 / 1
Регистрация: 04.04.2018
Сообщений: 351

Класс удаляется раньше чем нужно

10.03.2020, 12:05. Показов 1236. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
72 строка "Нельзя ссылаться на функцию так как она удалена"
Как это можно пофиксить? Создать указатель а потом удалить его?
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
#include<iostream>
#include<string>
#include<fstream>
using namespace std;
class TranslationUnit {
private:
    ifstream ifs;
    string path;
    bool is_open;
public:
 
    TranslationUnit() : path(""),ifs(), is_open(false) {};
 
    TranslationUnit(string path) { 
        ifs.open(path); 
        if (!ifs.is_open()) // если файл не открыт
            cout << "Файл не может быть открыт!\n"; // сообщить об этом
        else
        {
            is_open = true;
        }
    };
 
    ~TranslationUnit() {
        is_open = false;
        ifs.close();
    }
 
    void set_ifs(string path) {
        ifs.open(path);
        if (!ifs.is_open()) // если файл не открыт
            cout << "Файл не может быть открыт!\n"; // сообщить об этом
        else
        {
            is_open = true;
        }
    }
    bool get_is_open() const { return is_open; }
    string get_path() const { return path; }
    friend class TU_Reader;
};
 
class TU_Reader {
private:
    char current_symbol;
    TranslationUnit *tU;
public:
    TU_Reader(TranslationUnit TU){
        if (TU.get_is_open()) {
            tU = &TU;
        }
        else {
            cout << "File closed.(TU_Reader)" << endl;
        }
    }
    TU_Reader& operator >>(TU_Reader& i) {
        if (!tU->ifs.eof()) {
            i.current_symbol = tU->ifs.get();
            return i;
        }
        else {
            cout << "End of file.(TU_Reader)" << endl;
        }
    }
    char get_current_symb() const {
        return current_symbol;
    }
};
 
int main() {
    TranslationUnit translationUnit("some.txt");
    TU_Reader tu_Reader(translationUnit);
    tu_Reader >> tu_Reader;
    cout << tu_Reader.get_current_symb();
    system("pause");
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.03.2020, 12:05
Ответы с готовыми решениями:

Программа кончается раньше чем надо
Почему после ответа пользователя на &quot;as your biseiness?&quot; компилятор пишет programm finished. Как это исправить? #include &lt;iostream&gt;...

Проинициализировать sdl раньше чем другие файлы
Есть проект из нескольких файлов. Этот проект использует библиотеку sdl. Есть главный файл, где проходит инициализация sdl и есть функция...

Конец файла обнаружен раньше, чем левая { скобка
Помогите исправить программу так,чтобы она работала. ( Программа для перевода числа в письменный вид) #include &lt;iostream&gt; ...

5
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
10.03.2020, 12:07
Цитата Сообщение от dimmarvel Посмотреть сообщение
72 строка "Нельзя ссылаться на функцию так как она удалена"
Как это можно пофиксить? Создать указатель а потом удалить его?
Это она на конструктор копирования для TranslationUnit ругается
Сделай TU_Reader(const TranslationUnit &TU)
1
Модератор
Эксперт С++
 Аватар для zss
13778 / 10971 / 6491
Регистрация: 18.12.2011
Сообщений: 29,257
10.03.2020, 13:57
Лучший ответ Сообщение было отмечено dimmarvel как решение

Решение

Исправил ошибки компиляции в соответствии с идеологией ООП.
Но за функциональность не ручаюсь, особенно непонятна функция operator>>:
Цитата Сообщение от zss Посмотреть сообщение
cin >> tu_Reader;
что и куда тут читается.
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
#include<iostream>
#include<string>
#include<fstream>
using namespace std;
class TU_Reader;
 
class TranslationUnit {
private:
    ifstream ifs;
    string path;
    bool is_open;
public:
 
    TranslationUnit() : path(""), ifs(), is_open(false) {};
 
    TranslationUnit(string path):path(path) {
        ifs.open(path);
        if (!ifs.is_open()) // если файл не открыт
            cout << "Файл не может быть открыт!\n"; // сообщить об этом
        else
        {
            is_open = true;
        }
    }
    //---------------- правило трех - копиконструктор
    TranslationUnit(const TranslationUnit& tu) :path(tu.path) {
        ifs.open(path);
        if (!ifs.is_open()) // если файл не открыт
            cout << "Файл не может быть открыт!\n"; // сообщить об этом
        else
        {
            is_open = true;
        }
    }
    //---------------- правило трех - деструктор
    ~TranslationUnit() {
        is_open = false;
        ifs.close();
    }
    //---------------- правило трех - operator=
    //  TranslationUnit& operator=(const TranslationUnit& TU); // не используем
    void set_ifs(string _path) {
        path = _path;
        ifs.open(path);
        if (!ifs.is_open()) // если файл не открыт
            cout << "Файл не может быть открыт!\n"; // сообщить об этом
        else
        {
            is_open = true;
        }
    }
    bool get_is_open() const { return is_open; }
    string get_path() const { return path; }
    friend class TU_Reader;
    friend istream& operator>>(istream& is, TU_Reader& i);
};
 
class TU_Reader {
private:
    char current_symbol;
    TranslationUnit *tU;
public:
    TU_Reader(const TranslationUnit& TU) {
        if (TU.get_is_open()) {
            tU = new TranslationUnit(*tU);
        }
        else {
            cout << "File closed.(TU_Reader)" << endl;
            tU = nullptr;
        }
        current_symbol = 0;
    }
 
    //---------------- правило трех - копиконструктор
    TU_Reader(const TU_Reader& TR) {
        if ( TR.tU->get_is_open() ) {
            tU = new TranslationUnit(*TR.tU);
        }
        else {
            cout << "File closed.(TU_Reader)" << endl;
            tU = nullptr;
        }
        current_symbol = 0;
    }
    //---------------- правило трех - деструктор
    ~TU_Reader() { delete tU; }
    //---------------- правило трех - operator=
    //  TU_Reader& operator=(const TranslationUnit& TU); // не используем
 
//------------------  тут я не врубаюсь, что и откуда идет
    friend istream& operator>>(istream& is,TU_Reader& i) {
        if (! i.tU->ifs.eof()) {
            i.current_symbol = (char)(i.tU->ifs.get());
        }
        else {
            cout << "End of file.(TU_Reader)" << endl;
        }
        return is;
    }
    char get_current_symb() const {
        return current_symbol;
    }
};
 
int main() {
    TranslationUnit translationUnit("some.txt");
    TU_Reader tu_Reader(translationUnit);
    cin >> tu_Reader;
    cout << tu_Reader.get_current_symb();
    system("pause");
}
1
3 / 3 / 1
Регистрация: 04.04.2018
Сообщений: 351
11.03.2020, 19:09  [ТС]
Цитата Сообщение от zss Посмотреть сообщение
//------------------  тут я не врубаюсь, что и откуда идет
Я хотел реализовать оператор который берет следующий символ в файле и помещает его в поле "current_symbol" класса TU_Reader
0
Модератор
Эксперт С++
 Аватар для zss
13778 / 10971 / 6491
Регистрация: 18.12.2011
Сообщений: 29,257
11.03.2020, 19:43
Цитата Сообщение от dimmarvel Посмотреть сообщение
и помещает его в поле "current_symbol" класса TU_Reader
Цитата Сообщение от zss Посмотреть сообщение
cin >> tu_Reader;
А какое отношение ко всему этому имеет cin?
Перегрузите лучше операцию TU_Reader& TU_Reader::operator++() будет более натурально.
1
3 / 3 / 1
Регистрация: 04.04.2018
Сообщений: 351
11.03.2020, 19:45  [ТС]
zss,
Цитата Сообщение от dimmarvel Посмотреть сообщение
tu_Reader >> tu_Reader;
в моем исходнике небыло cin
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.03.2020, 19:45
Помогаю со студенческими работами здесь

Файл изменен раньше, чем установлена OC
Объясните как такое возможно? Винда установлена в 10 месяца, а файлы изменены в 9? Или я чего-то не понимаю, насколько я помню фрапс я...

У клиента АПы раньше чем у всех!
Ну как такое может быть?! Клиент видит АПы раньше чем все остальные! К примеру сегодня (15.02.2010) уже звонит, говорит скатились на на 2...

Ads by blockandsurf не чем не удаляется
Куча рекламных баннеров во всех браузерах антивирусы не помогают! (ads by blockandsurf)

Выход из цикла происходит раньше, чем предполагалось
#include&lt;iostream&gt; using namespace std; void main() { char ar={&quot;1234567890qwertyuiop&quot;},m='3',n='u'; cout&lt;&lt;ar&lt;&lt;'\n'; for...

Деструктор выполняется раньше, чем выбрасывается исключение
Здравствуйте! При разработке сайта использовал паттерн MVC. Когда происходит выбрасывание исключения в теле класса Page сначала...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача №1: при указании работ (справочник РаботыПоРемонтуСпецтехники),. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru