C++文件读取的4种情况汇总

目录
  • 简介:
  • C++文件读取的一般步骤:
  • 文件读取方法:
    • 第一种方法:采用“<<”运算符
    • 第二种方法:利用<string>中的getline函数,按行读取,这样每一行内的所有空格也可以顺利读取
    • 第三种方法: 利用readFile对象内部的getline方法,这个名字虽然和第二种中的一样,但是传入的参数不同,并不是同一个函数。
    • 第四种方法:利用radeFile内部的get()函数一个个的将字符读出来,遇到EOF时返回False退出while循环,这个过程会读取"endl",也就是换行字符,在读到换行字符时会进行换行操作。
  • 总结:

简介:

C++我们可以更具不同的目的来选取文件的读取方式,这里我会介绍C++中的四种文件读取方式。

C++文件读取的一般步骤:

1、包含头文件 #include<fstream>

2、实例化对象:istream file

3、打开文件:file.open("文件路径","打开方式"),打开文件后判断文件是否打开成功,file.is_open()返回一个bool类型,成功:true  失败:false

4、进行文件读取操作

5、关闭文件

文件读取方法:

第一种方法:采用“<<”运算符

#include<iostream>
#include<fstream>
#include<string>
using namespace std;

int main()
{
	ifstream readFile;
	readFile.open("file.txt", ios::in);

	if (readFile.is_open())
	{
		cout << "文件打开成功!" << endl;
		char buff[1000] = { 0 };
		while (readFile >>buff)
		{
			cout << buff << endl;
		}
	}
	else
	{
		cout << "文件打开失败!" << endl;
	}

	readFile.close();
	return 0;
}

解释:这种方式和采用cin>>进行写入类型,readFile>>buff进行写入时永远是从buff[0]开始,不会进行追加式的写入,readFile在遇到EOF(End Of File)时会返回False,以此来跳出while循环。

局限性:由于“<<”运算符自身的性质,会将一切空格当作终止条件,这样的话就无法输出空格信息,采用这种方法会将一行信息进行分段读出,对于类对象的信息读取是很有用的。

结果演示:

文件内容:

苏轼 长恨此身非我有

李白 人生得意需尽欢

曹松 一将功成万骨枯

输出结果:

苏轼

长恨此身非我有

李白

人生得意需尽欢

曹松

一将功成万骨枯

第二种方法:利用<string>中的getline函数,按行读取,这样每一行内的所有空格也可以顺利读取

代码部分:

#include<iostream>
#include<fstream>
#include<string>
using namespace std;

int main()
{
	ifstream readFile;
	readFile.open("file.txt", ios::in);

	if (readFile.is_open())
	{
		cout << "文件打开成功!" << endl;
		cout << "类容如下!" << endl;
		string str;
		while (getline(readFile,str))
		{
			cout << str << endl;
		}
	}
	else
	{
		cout << "文件打开失败!" << endl;
	}
    readFile.close();

	return 0;
}

解释:getline()函数会在文件读完时返回False跳出while循环,适用于想一次性的读取一行文件,保持读出内容和文件内容一致。

输出结果:

苏轼 长恨此身非我有

李白 人生得意需尽欢

曹松 一将功成万骨枯

第三种方法: 利用readFile对象内部的getline方法,这个名字虽然和第二种中的一样,但是传入的参数不同,并不是同一个函数。

代码部分:

#include<iostream>
#include<fstream>
#include<string>
using namespace std;

int main()
{
	ifstream readFile;
	readFile.open("file.txt", ios::in);

	if (readFile.is_open())
	{
		cout << "文件打开成功!" << endl;
		char buff[1000] = { 0 };
		while (readFile.getline(buff,sizeof(buff)))
	    {
		    cout << buff << endl;
        }

	}
	else
	{
		cout << "文件打开失败!" << endl;
	}
	readFile.close();
	return 0;
}
 

输出结果:

苏轼 长恨此身非我有

李白 人生得意需尽欢

曹松 一将功成万骨枯

第四种方法:利用radeFile内部的get()函数一个个的将字符读出来,遇到EOF时返回False退出while循环,这个过程会读取"endl",也就是换行字符,在读到换行字符时会进行换行操作。

代码部分:

#include<iostream>
#include<fstream>
#include<string>
using namespace std;

int main()
{
	ifstream readFile;
	readFile.open("file.txt", ios::in);

	if (readFile.is_open())
	{
		cout << "文件打开成功!" << endl;
		char buff = 0;
		while ((buff=readFile.get())!=EOF)
		{
			cout << buff;
		}
	}
	else
	{
		cout << "文件打开失败!" << endl;
	}
	readFile.close();
	return 0;
}
 

输出部分:

苏轼 长恨此身非我有

李白 人生得意需尽欢

曹松 一将功成万骨枯

总结:

第一种方法虽然有无法读取空格的缺陷,但是在我们对类对象进行初始化时是很有帮助的;第二、三两种就是不同的函数重载,在I/O输入这一部分有详细的介绍,分别对应的是string库和iostream库;第四种也是I/O流中的用法。

到此这篇关于C++文件读取的4种情况的文章就介绍到这了,更多相关C++文件读取内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C/C++ 读取16进制文件的方法

    1.为什么有这种需求 因为有些情况需要避免出现乱码.不管什么编码都是二进制的,这样表示为16进制就可以啦. 2.如何读取16进制文件 最近编程用这一问题,网上查了一下,感觉还是自己写吧. 16进制数据一般是:text=0x340xb5...,就是0x开头,之后是两个数字十六进制数. 如果直接使用sscanf(text,"0x",&num),会把连续的数字读进去直到遇到'x'. 如使用sscanf读取text第一个读到的十六进制数是0x340,误判啦.最后,因为是4个一组,就先把

  • c语言读取csv文件和c++读取csv文件示例分享

    C读取csv文件 复制代码 代码如下: #include <stdio.h>#include <string.h> char *trim(char *str){    char *p = str;     while (*p == ' ' || *p == '\t' || *p == '\r' || *p == '\n')        p ++;    str = p;     p = str + strlen(str) - 1;     while (*p == ' ' ||

  • c++读取数据文件到数组的实例

    在刷题过程中,遇到的读取文件问题,只是记录自己的问题,新手~ 如果在一个txt文件当中有以下数据 1 2 3 4 5 6 7 8 9 10 1.如果我们只是简单将这些数据保存在一个数组中: #include <iostream> #include <fstream> using namespace std; int main() { int i,datalen=0; double num[100]; ifstream file("data.txt"); whil

  • c++实现逐行读取配置文件写入内存的示例

    不解析配置内容,只读取文件内容,剪去注释和首尾空格后写入缓存: vector<string> 中.供其他方法使用.代码是在做一个MFC小工具时写的. ReadProtocol.h 复制代码 代码如下: /*** 从文件中 读取 protocol 的内容 写入缓存* 供外部方法使用* Alex Liu, 2014*/ #pragma once #include <vector>#include <map>#include <list>#include <

  • C++文件的数据写入和文件的数据读取的方法实现

    目录 一:没有数据,准备数据,写入文件 二:读文件操作 一:没有数据,准备数据,写入文件 1.main.cpp #include<iostream> using namespace std; #include<fstream> #include<string> #include<list> #include"CData.h" #include"CStaff.h" int main() { CData::userInit

  • C++文件读取的4种情况汇总

    目录 简介: C++文件读取的一般步骤: 文件读取方法: 第一种方法:采用“<<”运算符 第二种方法:利用<string>中的getline函数,按行读取,这样每一行内的所有空格也可以顺利读取 第三种方法: 利用readFile对象内部的getline方法,这个名字虽然和第二种中的一样,但是传入的参数不同,并不是同一个函数. 第四种方法:利用radeFile内部的get()函数一个个的将字符读出来,遇到EOF时返回False退出while循环,这个过程会读取"endl&q

  • 详解Vue 数据更新了但页面没有更新的 7 种情况汇总及延伸总结

    如果你发现你自己需要在 Vue 中做一次强制更新,99.9% 的情况,是你在某个地方做错了事. 1. Vue 无法检测实例被创建时不存在于 data 中的 property 原因:由于 Vue 会在初始化实例时对 property 执行 getter/setter 转化,所以 property 必须在 data 对象上存在才能让 Vue 将它转换为响应式的. 场景: var vm = new Vue({ data:{}, // 页面不会变化 template: '<div>{{message}

  • MySQL索引失效的几种情况汇总

    一.索引不存储null值 更准确的说,单列索引不存储null值,复合索引不存储全为null的值.索引不能存储Null,所以对这列采用is null条件时,因为索引上根本 没Null值,不能利用到索引,只能全表扫描. 为什么索引列不能存Null值? 将索引列值进行建树,其中必然涉及到诸多的比较操作.Null值的特殊性就在于参与的运算大多取值为null. 这样的话,null值实际上是不能参与进建索引的过程.也就是说,null值不会像其他取值一样出现在索引树的叶子节点上. 二.不适合键值较少的列(重复

  • Golang 实现超大文件读取的两种方法

    Golang超大文件读取的两个方案 流处理方式 分片处理 去年的面试中我被问到超大文件你怎么处理,这个问题确实当时没多想,回来之后仔细研究和讨论了下这个问题,对大文件读取做了一个分析 比如我们有一个log文件,运行了几年,有100G之大.按照我们之前的操作可能代码会这样写: func ReadFile(filePath string) []byte{ content, err := ioutil.ReadFile(filePath) if err != nil { log.Println("Re

  • golang容易导致内存泄漏的6种情况汇总

    目录 1. 定时器使用不当 1.1 time.After()的使用 1.2 time.NewTicker资源未及时释放 2. select阻塞 2.1 导致goroutine阻塞的情况 2.2 循环空转导致CPU暴涨 3. channel阻塞 4. goroutine导致的内存泄漏 4.1 申请过多的goroutine 4.2 goroutine阻塞 4.2.1 I/O问题 4.2.2 互斥锁未释放 4.2.3 死锁 4.2.4 waitgroup使用不当 5. slice 引起的内存泄漏 6.

  • perl文件读取的几种处理方式小结

    1.单行(大文件处理): 复制代码 代码如下: my $oneline = <$FL> 或while($line=<H>){ } 2.读取全部(小文件处理): 复制代码 代码如下: open (my $in, "path ") or die "open error: $! "; my @lines = <$in> ; 3.读3行(大文件及特殊处理需要): 复制代码 代码如下: open (my $in, "path &q

  • Python文件读取的3种方法及路径转义

    1.文件的读取和显示 方法1: 复制代码 代码如下: f=open(r'G:\2.txt')  print f.read()  f.close() 方法2:   复制代码 代码如下: try:      t=open(r'G:\2.txt')      print t.read()  finally:      if t:         t.close() 方法3: 复制代码 代码如下: with open(r'g:\2.txt') as g:      for line in g:     

  • Linux 查看内存使用情况的几种方法汇总

    目录 GUI 查看 如何访问系统监视器: 命令获取 虚拟文件 /proc/meminfo 命令 free 命令 vmstat 命令 top 命令 htop 在运行 Linux 系统的过程中为了让电脑或者服务器以最佳水平运行,常常需要监控内存统计信息. 那么今天我们就来看看有哪些方法可以访问所有相关信息并帮助管理员监控内存统计信息. 查看或者获取 Linux 中的内存使用情况既可以通过命令的方式,也可以通过桌面端的GUI程序查看. 以下的过程,所有命令和结果都是使用 Linux 发行版 Ubunt

  • PHP读取文件的常见几种方法

    最近整理了PHP读取文件的常见几种方法,具体如下: 1.fread string fread ( int $handle , int $length ) fread() 从 handle 指向的文件中读取最多 length 个字节.该函数在读取完最多 length 个字节数,或到达 EOF 的时候,或(对于网络流)当一个包可用时,或(在打开用户空间流之后)已读取了 8192 个字节时就会停止读取文件,视乎先碰到哪种情况. fread() 返回所读取的字符串,如果出错返回 FALSE. <?php

  • 浅谈Golang是如何读取文件内容的(7种)

    本文旨在快速介绍Go标准库中读取文件的许多选项. 在Go中(就此而言,大多数底层语言和某些动态语言(如Node))返回字节流. 不将所有内容自动转换为字符串的好处是,其中之一是避免昂贵的字符串分配,这会增加GC压力. 为了使本文更加简单,我将使用string(arrayOfBytes)将bytes数组转换为字符串. 但是,在发布生产代码时,不应将其作为一般建议. 1.读取整个文件到内存中 首先,标准库提供了多种功能和实用程序来读取文件数据.我们将从os软件包中提供的基本情况开始.这意味着两个先决

随机推荐