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

методы seekg и seekp - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Не запускается Devcpp http://www.cyberforum.ru/cpp-beginners/thread553161.html
Перестал запускаться Devcpp. попробовал переустановить, но ничего не поменялось. Пишет подождите момент, и пропадает. Добавлено через 7 минут И Microsoft Visual C++ 2010 выдает ошибку "адресат вызова сделал исключение".
C++ Программа для удалённого администрирования Сразу извиняюсь, если создал тему не в том разделе, ведь скорее всего так оно и есть. Прошу не удалять, а просто перенести в нужный раздел. В общем, есть тема курсовой работы "Программа для удалённого администрирования". Собственно. программа должна выполнять следующие функции: - Работа как клиент-серверное приложение через стандартный протокол TCP/IP - Поддержка авторизации через логин и... http://www.cyberforum.ru/cpp-beginners/thread553156.html
Структура Train. Считывание из файла C++
Всем привет. У меня такая задача. Описать структуру с именем TRAIN, содержащую следующие поля:-название пункта назначения;-номер поезда;-время отправления.Написать программу, выполняющую следующие действия:-ввод с клавиатуры данных в массив, состоящий из 8 элементов типа TRAIN; записи должны быть упорядочены в алфавитном порядке по названиям пунктов назначения;-вывод на экран информации о...
Файлы C++
в чем ошибка помогите плиз //--------------------------------------------------------------------------- #include <stdio.h> #include <conio.h> //--------------------------------------------------------------------------- int main() {
C++ найти элемент матрицы с наименьшей разностью компонент http://www.cyberforum.ru/cpp-beginners/thread553110.html
найти элемент матрицы с наименьшей разностью компонент
C++ Подсчитать сколько элементов массива в каждой новой строке матрицы имеет значение "-1" Всем привет такая проблема: из двумерного массива сделал матрицу типа: 1-1 0 0-1-1 1 1 1 нужно подсчитать сколько элементов массива в каждой новой строке матрицы имеет значение "-1",если элементов только 1 то работать дальше над следующей строкой,а если больше 1го или 0 элементов то прекратить поиск и выдать сообщение "матрица не верна". for (int i=0;i<n;i++) { for (int... подробнее

Показать сообщение отдельно
-=ЮрА=-
Заблокирован
Автор FAQ
20.04.2012, 10:42     методы seekg и seekp
Ree.exe,
Цитата Сообщение от Ree.exe Посмотреть сообщение
File(str, ios::in | ios::out | ios::binary);
-
во первых в файле числа должны быть записаны в двоичном режиме(даже если не будет флага ios::binary мы же
Цитата Сообщение от Ree.exe Посмотреть сообщение
File.read
читаем двоичное предсталение числа а не производим потоковый ввод >>)
Вот посмотри как выглядит вполне корректный файл со значениеми write/read
p@ffffff'@ @НММММЊQ@fffff¦J@ffffff$@333333@ Ђ>@ p@ffffff$@ p@љ™™™™R@fffffR@НММММЊQ@НМММММI@
во вторых : файл открыт в режиме чтение/запись - у него нет конца, т.к. дописав ещё одно значение вконец мы тем самым EOF передвинем. Критерием достижения конца файла может служить соответствие текущей позиции файла, его длинне
условие останова чтения/записи
C++
1
2
3
4
File.seekp(0,ios::end);
        len = File.tellp();
        File.seekp(0,ios::beg);
        while(File.tellp() < len && bRet)


Ниже код алгоритма рандомно генерирующего 15 вещественных чисел в диапазоне -50 50, которые затем записывается в файл. Посредством my_work мы производим перезапись отрицательных чисел на значение 256 и после перезаписи считываем файл чтобы проверить данные в нём
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
#include <iostream>
#include <fstream>
#include <ctime>
using namespace std;
 
//ÔóГ*êöèÿ Г§Г*ïîëГ*ГЁГІ ГґГ*éë szPath 
//n ГўГҐГ№ГҐГ±ГІГўГҐГ*Г*ûìè Г·ГЁГ±Г«Г*ìè Гў ГЁГ*òåðâГ*ëå
bool my_fill(const char *szPath, int n);
//ÔóГ*êöèÿ ïåðåçГ*ïèñûâГ*ГҐГІ îòðèöГ*òåëüГ*ûå Г§Г*Г*Г·ГҐГ*ГЁГї Г*Г* KV
bool my_work(const char *szPath, double KV);
//ÔóГ*êöèÿ ñ÷èòûâГ*ГҐГІ Г§Г*Г*Г·ГҐГ*ГЁГї ГЁГ§ ГґГ*éëГ* szPath ГЁ ГЇГҐГ·Г*ГІГ*ГҐГІ ГЁГµ Г*Г* ГЅГЄГ°Г*Г*
bool my_read(const char *szPath);
 
int main()
{
    char szPath[256] = {0};
    cout<<"Enter path : ";
    cin.getline(szPath,255);
    if(!my_fill(szPath, 15))
        cout<<"\nError rand fill\n";
    else
    if(!my_work(szPath, 256))
        cout<<"\nError read/write\n";
    else
    if(!my_read(szPath))
        cout<<"\nRead error\n";
    else
        cout<<"\nAlgorithm successfully work\n";
    system("pause");
    return 0;
}
 
bool my_fill(const char *szPath, int n)
{
    srand(time(0));
    double num;
    cout<<"Generated sequence\n";
    bool bRet = true;//ÔëГ*ГЈ Г±ГЁГЈГ*Г*ëèçèðóþùèé Г® òîì Г·ГІГ® Г§Г*ГЇГЁГ±Гј 
    //ïðîøëa ГіГ±ГЇГҐГёГ*Г® èëè æå ïðîèçîøëГ* îøèáêГ*
    fstream File(szPath, ios::out | ios::binary );
    if(!File.is_open())
        bRet = false;
    else
    while(-1 < (n = n - 1) && (bRet = File.good()))
    {
        File.write
        (
            (char *)&(num = (rand()%1000 - rand()%500)/10.0),
            sizeof(double)
        );
        cout<<num<<" ";
    }
    File.close();
    return bRet;
}
 
bool my_work(const char *szPath, double KV)
{
    bool bRet = true;//ÔëГ*ГЈ Г±ГЁГЈГ*Г*ëèçèðóþùèé Г® òîì Г·ГІГ® Г·ГІГҐГ*ГЁГҐ 
    //Г§Г*ГЇГЁГ±Гј ïðîøëè ГіГ±ГЇГҐГёГ*Г® èëè æå ïðîèçîøëГ* îøèáêГ*
    double num;
    long pos;
    long len;
    fstream File(szPath, ios::in | ios::out | ios::binary);
    if(!File.is_open())
        bRet = false;
    else
    {
        File.seekp(0,ios::end);
        len = File.tellp();
        File.seekp(0,ios::beg);
        while(File.tellp() < len && bRet)
        {
            File.read((char*)&num, sizeof(double));
            if(bRet = File.good())//Áóäåì ГЇГЁГ±Г*ГІГј Гў ГґГ*éë òîëüêî åñëè ГіГ±ГЇГҐГёГ*Г® Г±Г·ГЁГІГ*ëè
            if(num < 0)
            {
                if(sizeof(double) <= (pos = File.tellp()))
                {
                    File.seekp(pos - sizeof(double),ios::beg);
                    File.write((char*)&KV, sizeof(double));
                    bRet = File.good();
                }
            }
        }   
    }
    File.close();
    return bRet;
}
 
bool my_read(const char *szPath)
{
    bool bRet = true;//ÔëГ*ГЈ Г±ГЁГЈГ*Г*ëèçèðóþùèé Г® òîì Г·ГІГ® Г·ГІГҐГ*ГЁГҐ 
    //ïðîøëî ГіГ±ГЇГҐГёГ*Г® èëè æå ïðîèçîøëГ* îøèáêГ*
    double num;
    cout<<"\nReaded sequence\n";
    fstream File(szPath, ios::in | ios::binary);
    if(!File.is_open())
        bRet = false;
    else
    while(!File.eof() && bRet)
    {
        File.read
        (
            (char *)&num,
            sizeof(double)
        );
        if(!File.eof())
        if(bRet = File.good())
            cout<<num<<" ";
    }
    File.close();
    return bRet;
}
Миниатюры
методы seekg и seekp  
 
Текущее время: 19:25. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru