Форум программистов, компьютерный форум CyberForum.ru

std::string, потоки - C++

Восстановить пароль Регистрация
 
 
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
23.01.2014, 19:21     std::string, потоки #1
Доброго времени суток! Использую такую конструкцию:
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
while(...) {
        while(getline(dic, buf2)) {
                if (buf2 < buf1) continue;
            else if (buf2 == buf1) break;
            else {
                    def << buffer << endl;
            break;
    }
}

После выполнения else if происходит возврат во внешний while, и хотелось бы, чтобы по достижении внутреннего while считывалась бы не новая строка, а использовалась старая.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ev[G]eN
Эксперт С++
 Аватар для Ev[G]eN
5093 / 1531 / 381
Регистрация: 23.01.2011
Сообщений: 3,148
23.01.2014, 19:22     std::string, потоки #2
задание хотелось бы видеть
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4920 / 2663 / 243
Регистрация: 29.11.2010
Сообщений: 7,409
23.01.2014, 19:23     std::string, потоки #3
C++
1
2
3
4
5
6
7
8
9
10
while(...) {
    bool flag = true;
        while(getline(dic, buf2) && flag) {
                if (buf2 < buf1) continue;
            else if (buf2 == buf1) flag = false;
            else {
                    def << buffer << endl;
            break;
    }
}
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
23.01.2014, 19:36  [ТС]     std::string, потоки #4
Ev[G]eN, Это, в общем-то, сравнение слов из словаря со словами из отсортированного файла, то бишь, запись несуществующих слов в файл, орфографическая проверка.

Добавлено через 10 минут
Т.е. мне нужно указатель преместить на строку выше.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
23.01.2014, 19:59     std::string, потоки #5
Цитата Сообщение от qwerty778 Посмотреть сообщение
Т.е. мне нужно указатель преместить на строку выше.
Как-то так:
C++
1
2
3
4
dic.seekg(-2, ios::cur);
while (dic.peek() != '\n')
    dic.seekg(-1, ios::cur);
dic.seekg(1, ios::cur);
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
23.01.2014, 20:52  [ТС]     std::string, потоки #6
alsav22, спасибо большое. Хотя по-началу были проблемы, ведь, открыл не в бинарном режиме.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
23.01.2014, 21:49     std::string, потоки #7
Цитата Сообщение от qwerty778 Посмотреть сообщение
Хотя по-началу были проблемы, ведь, открыл не в бинарном режиме.
В текстовом криво работает?

Добавлено через 46 минут
Для первой строки ещё нужно условие добавить:
C++
1
2
3
4
5
6
7
8
9
10
streamoff pos;
dic.seekg(-2, ios::cur);
while (dic.peek() != '\n')
{
    dic.seekg(-1, ios::cur);
    if ((pos = fin.tellg()) == 0)
                    break;
}
if (pos != 0)
    dic.seekg(1, ios::cur);
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
23.01.2014, 22:14  [ТС]     std::string, потоки #8
alsav22, да, в текстовом криво. Ок, добавлю
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
23.01.2014, 22:23     std::string, потоки #9
В текстовом вот так будет работать (в windows):
C++
1
2
3
4
5
6
7
8
9
10
streamoff pos;
dic.seekg(-3, ios::cur);
while (dic.peek() != '\n')
{
    dic.seekg(-1, ios::cur);
    if ((pos = fin.tellg()) == 0)
                    break;
}
if (pos != 0)
    dic.seekg(2, ios::cur);
Добавлено через 2 минуты
В текстовом, если peek() встречает '\n', то курсор передвигается на позицию 'r\' (который, в windlows, перед '\n').
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
25.01.2014, 13:28  [ТС]     std::string, потоки #10
alsav22, От оно чё, каретка. Спасибо)
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
01.02.2014, 18:52  [ТС]     std::string, потоки #11
alsav22, добрый вечер, сейчас напоролся на проблемку: первая строка в потоке dic - "а", и срабатывает условие равенства buf1==buf2. Программа зацикливается на while.
pos, при этом, равно -1.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.02.2014, 19:21     std::string, потоки #12
Код не вижу.
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
01.02.2014, 19:32  [ТС]     std::string, потоки #13
alsav22, код Ваш, в этом топике выше
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.02.2014, 20:17     std::string, потоки #14
Там чтения нет. С чтением, со сравнением и пр. покажите.
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
01.02.2014, 20:46  [ТС]     std::string, потоки #15
alsav22, это разные топики) Тут же у меня другая проблема.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.02.2014, 21:00     std::string, потоки #16
Цитата Сообщение от qwerty778 Посмотреть сообщение
это разные топики) Тут же у меня другая проблема.
Раз другая проблема, то зачем к моему коду отправляете, который под другую проблему был выложен?
Цитата Сообщение от qwerty778 Посмотреть сообщение
код Ваш, в этом топике выше
Код покажите. Я как должен видеть проблему, если кода не вижу? В моём коде, нет никаких
Цитата Сообщение от qwerty778 Посмотреть сообщение
buf1==buf2
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
02.02.2014, 14:17  [ТС]     std::string, потоки #17
alsav22, сорри, вот фрагмент моего кода с вашим:
Кликните здесь для просмотра всего текста
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
while (getline(dic, buf2)) { //wrong words to file
            if (buf2 < buf1)
                continue;
            ////////////////////////////////////////////////////////////
            else if (buf2 == buf1) { //remove cursor to line up
                streamoff pos;
                dic.seekg(-3, ios::cur);
                while (dic.peek() != '\n')
                {
                    dic.seekg(-1, ios::cur);
                    if ((pos = dic.tellg()) == 0) {
                        break;
                    }
                }
 
                if (pos != 0)
                    dic.seekg(2, ios::cur);
                break;
            }
            ///////////////////////////
            else {
                def << buffer << endl;
                break;
            }
        }
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
02.02.2014, 22:11     std::string, потоки #18
Мой код делает это:
Цитата Сообщение от qwerty778 Посмотреть сообщение
Т.е. мне нужно указатель преместить на строку выше.
Теперь подумайте, что будет происходить в вашем коде (17 пост). Считали строку, вернулись к началу её же, опять считали и т.д. Должно быть ещё одно чтение, чтобы читались следующие строки. Как у вас это должно быть сделано, без понятия, но вот пример кода на эту тему, и результат работы:
в файле:
aaa aaa
bbb bbb
ccc ccc
ddd ddd
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <fstream>
#include <string>
 
using namespace std;
 
void f(istream& dic) // перемещает курсор на строку выше
{
    streamoff pos;
    dic.seekg(-3, ios::cur);
    while (dic.peek() != '\n')
    {
        dic.seekg(-1, ios::cur);
        if ((pos = dic.tellg()) == 0)
                        break;
    }
    if (pos != 0)
        dic.seekg(2, ios::cur);
}
 
int main()
{
    ifstream dic("1.txt");
    if (dic)
    {
        string buf1 = "\0";
        string buf2;
        while(getline(dic, buf2)) 
        {
            cout << buf2 << endl;
        
            while(getline(dic, buf2)) 
            {
                cout << buf2 << endl;
                if (buf2 < buf1) 
                {
                    f(dic);
                    continue;
                }
                else if (buf2 == buf1)
                {
                    f(dic);
                    break;
                }
                else 
                {
                    f(dic);
                    break;
                }
            }
        }
        dic.close();
 
    }
    else
        cout << "Error!" << endl;
 
    system("pause");
    return 0;
}
Миниатюры
std::string, потоки  
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
02.02.2014, 23:50     std::string, потоки #19
Вот вариант, чтобы повторно читалась и первая строка (даже если в ней одна буква):
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <fstream>
#include <string>
 
using namespace std;
 
void f(istream& dic) // перемещает курсор на строку выше
{
    streamoff pos;
    dic.seekg(-3, ios::cur);
    dic.clear();
    if ((pos = dic.tellg()) == -1)
    {
        dic.clear();
        dic.seekg(0);
        pos = dic.tellg();
        return;
    }
    while (dic.peek() != '\n')
    {
        dic.seekg(-1, ios::cur);
        pos = dic.tellg();
        if (pos == -1)
        {
            dic.clear();
            dic.seekg(0);
            pos = dic.tellg();
            break;
        }
    }
    if (pos != 0)
        dic.seekg(2, ios::cur);
}
 
int main()
{
    ifstream dic("1.txt");
    if (dic)
    {
        string buf1 = "\0";
        string buf2;
        bool flag = false;
        while(getline(dic, buf2)) 
        {
            cout << buf2 << endl;
            if (buf2 < buf1) 
            {
                f(dic);
                   
            }
            else if (buf2 == buf1)
            {
                f(dic);
            }
            else 
            {
                f(dic);
            }
            if (getline(dic, buf2))
                cout << buf2 << endl;
        }
        dic.close();
    }
    else
        cout << "Error!" << endl;
 
    system("pause");
    return 0;
}

В общем, код нужно подгонять под конкретную задачу.
Миниатюры
std::string, потоки  
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.02.2014, 02:34     std::string, потоки
Еще ссылки по теме:

C++ Error C2664: std::vector<_Ty>::push: невозможно преобразовать параметр 1 из 'double' в 'const std::string &'
C++ Std::string and std::wstring convert
Потоки и прямая запись в заданый std::string C++

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

Или воспользуйтесь поиском по форуму:
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
03.02.2014, 02:34  [ТС]     std::string, потоки #20
alsav22, хорошо, тогда как понять, что нет строки выше, и указатель переместить нельзя?
Yandex
Объявления
03.02.2014, 02:34     std::string, потоки
Ответ Создать тему
Опции темы

Текущее время: 12:04. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru