工资类的编写(其中工资数据的输入从文件中输入)
2016-03-10 17:04
387 查看
salary类的编写
要求编写的成员函数:void read_data( ); 手动输入工资太麻烦。现给出包含了不足500个职工工资的文件salary.txt(下
载)从文件中读数据
void write_data(); 将排序后的结果存放到一个文件中,即ofstream
void add_salarys(int x); 给每个人涨x元的工资
void sort_salarys(); 给工资排序
void show_salarys( ); 显示工资
一.cout和cerr的区别
1、cout:写到标准输出的ostream对象.cout经过缓冲后输出,默认情况下是显示器。这是一个被缓冲的输出,是标准输出,并且可以重新定向
2、cerr:输出到标准错误的ostream对象,常用于程序错误信息。cerr不经过缓冲而直接输出,一般用于迅速输出出错信息,是标准错误,默认情况下被关联到标准输出流,但它不被缓冲,也就说错误消息可以直接发送到显示器,而无需等到缓冲区或者新的换行符时,才被显示。一般情况下不被重定向
二.为什么有cerr和clog
比如,你的程序遇到调用栈用完了的威胁(无限,没有出口的递归)。
你说,你到什么地方借内存,存放你的错误信息?
所以有了cerr。其目的,就是在你最需要它的紧急情况下,还能得到输出功能的支持。
三.涉及到的文件的读和写见下篇(文件的读和写)
要求编写的成员函数:void read_data( ); 手动输入工资太麻烦。现给出包含了不足500个职工工资的文件salary.txt(下
载)从文件中读数据
void write_data(); 将排序后的结果存放到一个文件中,即ofstream
void add_salarys(int x); 给每个人涨x元的工资
void sort_salarys(); 给工资排序
void show_salarys( ); 显示工资
#include <iostream> #include <fstream> using namespace std; const int N=500; class Salary { public: void read_data( ); void write_data(); void add_salarys(int x); void sort_salarys(); void show_salarys( ); private: double salarys ; //工资, 用指针更好 int number; //人数 }; void Salary::read_data( ) { int i; ifstream infile("salary.txt",ios::in); //以输入的方式打开文件 if(!infile) //测试是否成功打开 { cerr<<"open error!"<<endl; exit(1); } i=0; while(infile>>salarys[i]) i++; number=i; infile.close(); } void Salary::write_data( ) { int i; ofstream outfile("salary_ordered.txt",ios::out); //以输出的方式打开文件 if(!outfile) //测试是否成功打开 { cerr<<"open error!"<<endl; exit(1); } for(i=0; i<number; ++i) { outfile<<salarys[i]<<endl; } outfile.close(); } void Salary::add_salarys(int x) { int i; for (i=0; i<number; i++) salarys[i]+=x; } void Salary::sort_salarys() { int i,j; double t; for (i=0; i<number-1; i++) for(j=0; j<number-i-1; j++) if (salarys[j]<salarys[j+1]) { t=salarys[j]; salarys[j]=salarys[j+1]; salarys[j+1]=t; } } void Salary::show_salarys( ) { int i; for (i=0; i<number; i++) cout<<salarys[i]<<endl; } int main( ) { Salary s; s.read_data( ); s.add_salarys(500); s.sort_salarys(); s.write_data(); s.show_salarys( ); return 0; }总结:
一.cout和cerr的区别
1、cout:写到标准输出的ostream对象.cout经过缓冲后输出,默认情况下是显示器。这是一个被缓冲的输出,是标准输出,并且可以重新定向
2、cerr:输出到标准错误的ostream对象,常用于程序错误信息。cerr不经过缓冲而直接输出,一般用于迅速输出出错信息,是标准错误,默认情况下被关联到标准输出流,但它不被缓冲,也就说错误消息可以直接发送到显示器,而无需等到缓冲区或者新的换行符时,才被显示。一般情况下不被重定向
二.为什么有cerr和clog
比如,你的程序遇到调用栈用完了的威胁(无限,没有出口的递归)。
你说,你到什么地方借内存,存放你的错误信息?
所以有了cerr。其目的,就是在你最需要它的紧急情况下,还能得到输出功能的支持。
三.涉及到的文件的读和写见下篇(文件的读和写)
相关文章推荐
- 默认参数的函数
- 高效网页截图编辑插件(Web page screenshot editor)
- [optimization]Dogleg Method狗腿算法
- Python讀寫Excel文件的實例
- 获取scrollview当前滚动到某页的代码,已经滚动中计算的代码
- 华为手机不能打印Log日志问题
- 嵌入式linux:音频编解码PCM转至AAC
- 观察者模式
- 日期控件的使用
- JAVA学习篇--javaweb之Filter具体解释
- ionic android双击退出应用和物理返回按钮隐藏键盘的实现
- 一个利用Dataflow实现的Actor
- mysql ERROR 1045 (28000): 错误解决办法
- Apache的安装
- 文章标题Matlab GUI学习笔记(一)function “funcname” 工作区和基本工作区
- Android SDK 配置镜像服务器
- 3. autowire、scope和aware接口
- Android Gradle实战中遇到的问题与经验
- Thread interrupt
- Android ALARM_SERVICE服务