fstream的使用(二)

long pos = file.tellg();   // 得到文件指针当前指向的文件位置(当指向文件末尾就是文件的长度)。

file.seekg(0,ios::beg);   // 让文件指针定位到文件开头

file.seekg(0,ios::end);   // 让文件指针定位到文件末尾

file.seekg(10,ios::cur);   // 让文件指针从当前位置向文件末方向移动10个字节

file.seekg(-10,ios::cur);   // 让文件指针从当前位置向文件开始方向移动10个字节

file.seekg(10,ios::beg);   // 让文件指针定位到离文件开头10个字节的位置

 

一、ASCII 输出

首先声明一个类对象:
ofstream fout;
打开一个文件,调用ofstream::open():
fout.open("output.txt");

也可以把文件名作为构造参数来打开一个文件:
ofstream fout("output.txt");

顺便说一句, 如果你要打开的文件不存在,它会为你创建一个, 所以不用担心文件创建的问题.

例子:
int num = 150;
char name[] = "John Doe";
fout << "Here is a number: " << num << "\n";
fout << "Now here is a string: " << name << "\n";

fout << flush; fout.close();

现在你用文本编辑器打开文件:
Here is a number: 150 Now here is a string: John Doe


二、ASCII 输入

输入和"cin" 流很像,
但你要考虑几件事情,

先看一个文本:

12 GameDev 15.45 L
This is really awesome!

为了打开这个文件,你必须创建一个in-stream对象:
ifstream fin("input.txt");

现在读入前四行.
int number;
float real;
char letter, word[8];
fin >> number;
fin >> word;
fin >> real;
fin >> letter;

也可以把这四行读取文件的代码写为更简单的一行。
fin >> number >> word >> real >> letter;

文件的每个空白之后, ">>" 操作符会停止读取内容, 直到遇到另一个>>操作符.
因为我们读取的每一行都被换行符分割开(是空白字符), ">>" 操作符只把这一行的内容读入变量。这就是这个代码也能正常工作的原因。但是,可别忘了文件的最后一行。

This is really awesome!

如果你想把整行读入一个char数组, 我们没办法用">>"操作符,因为每个单词之间的空格(空白字符)会中止文件的读取。

char sentence[101]; fin >> sentence;

我们想包含整个句子, "This is really awesome!" 但是因为空白, 现在它只包含了"This".
很明显, 肯定有读取整行的方法, 它就是getline()。这就是我们要做的。

fin.getline(sentence, 100);

第一个参数显然是用来接受的char数组. 第二个参数是在遇到换行符之前,数组允许接受的最大元素数量.


三、二进制 输入输出

注意我们不再使用插入和提取操作符(注:<< 和 >> 操作符).
你可以这么做,但它不会用二进制方式读写。你必须使用read() 和write() 方法读取和写入二进制文件. 创建一个二进制文件, 看下一行。

创建一个二进制文件,
ofstream fout("file.dat", ios::binary);
这会以二进制方式打开文件, 而不是默认的ASCII模式。

函数write() 有两个参数。 第一个是指向对象的char类型的指针, 第二个是对象的大小(译者注:字节数)。
int number = 30;
fout.write((char *)(&number), sizeof(number));

第一个参数写做"(char *)(&number)". 这是把一个整型变量转为char *指针。
第二个参数写作"sizeof(number)". sizeof() 返回对象大小的字节数. 就是这样!

二进制文件最好的地方是可以在一行把一个结构写入文件。
如果说,你的结构有12个不同的成员。 用ASCII文件,你不得不每次一条的写入所有成员。 但二进制文件替你做好了。

struct OBJECT
{ int number;
char letter;
} obj;
obj.number = 15;
obj.letter = ‘M’;
fout.write((char *)(&obj), sizeof(obj));

这样就写入了整个结构!

输入也很简单,因为read()函数的参数和 write()是完全一样的, 使用方法也相同。

ifstream fin("file.dat", ios::binary);
fin.read((char *)(&obj), sizeof(obj));

二进制文件比ASCII文件简单, 但有个缺点是无法用文本编辑器编辑。

-------------------
读文件

方法get() 每次返回一个字符。

方法ignore(int,char) 跳过一定数量的某个字符, 但你必须传给它两个参数。
第一个是需要跳过的字符数。
第二个是一个字符, 当遇到的时候就会停止。 例子,

fin.ignore(100, ‘\n’);

会跳过100个字符,或者不足100的时候,跳过所有之前的字符,包括 ‘\n’。

写文件

put(char), 它每次向输出流中写入一个字符。


打开文件

当我们用这样的语法打开二进制文件:

ofstream fout("file.dat", ios::binary);

"ios::binary"是你提供的打开选项的额外标志. 默认的, 文件以ASCII方式打开, 不存在则创建, 存在就覆盖. 这里有些额外的标志用来改变选项。

ios::app 添加到文件尾
ios::ate 把文件标志放在末尾而非起始。
ios::trunc 默认. 截断并覆写文件。
ios::nocreate 文件不存在也不创建。
ios::noreplace 文件存在则失败。

文件状态

eof(), 它返回是否标志已经到了文件末尾。

这个代码断统计小写‘e’ 在文件中出现的次数。

ifstream fin("file.txt");
char ch;
int counter;
while (!fin.eof())
{
    ch = fin.get();
    if (ch == ‘e’) counter++;
}
fin.close();
 

ofstream类的默认构造函数如下:

 

ofstream::ofstream(const char* filename, int mode = ios::out, int openport = filebuf::openport);

filename是要打开的文件名,
mode是打开的方式,
openport是打开文件的属性。

mode可以设置的方式如下:
ios::app         以追加的方式打开
ios::ate         文件打开后定位到文件尾
ios::binary     以二进制方式打开文件,默认是以文本方式打开
ios::in           文件以读(输入)方式打开
ios::out        文件以写(输出)方式打开
ios::trunc      如果文件存在,则把文件清空。
以上属性用“|”(按位或)连接起来。

openprot属性如下:
0     普通文件
1     只读文件
2     隐含文件
4     系统文件
以上属性可以用加或者按位或方式组织起来,比如1|2和3都代表既是只读又是隐含文件。

在windows操作系统中可以不要第三个参数,如果加入第三个参数,那第三个参数是打开文件的共享方式,也就是打开这个文件时,其他进程是否可以读写该文件。
共享方式参数可以是下面的值:
0x10 //_SH_DENYRW Denies read and write access to the file
0x20 //_SH_DENYWR Denies write access to the file
0x30 //_SH_DENYRD Denies read access to the file.
0x40 //_SH_DENYNO Permits read and write access
其他值都会报 "Invalid sharing flag "的错误。

ofstream hFile("c:\\1.txt", ios::out, _SH_DENYRW); // _SH_DENYRW is deny read and write
    if (!hFile) // if the file could open, hFile is a handle, else is zero
   {
        cout << "write fail!" << endl;       cout << "access is denies,maybe the file is readonlys,or use deny read opened of other process." << endl;
    }
    else
    {
        hFile << "by coderlee writes";
        cout << "write success!" << endl;
    }
    hFile.close(); // opened file need close.

转载于:https://my.oschina.net/u/3773235/blog/1619095

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值