一、标准输入流
标准输入流对象cin,重点掌握的函数
cin.get() //一次只能读取一个字符
cin.get(一个参数) //读一个字符
cin.get(三个参数) //可以读字符串
cin.getline()
cin.ignore()
cin.peek()
cin.putback()
标准输入流常见api编程案例
//1 cin cout能根据类型 获取数据 / 输出数据
//2 输入字符串 你 好 遇见空格,停止接受输入
void main01()
{
char YourName[50];
int myInt;
long myLong;
double myDouble;
float myFloat;
unsigned int myUnsigned; cout << "请输入一个Int: ";
cin >> myInt;
cout << "请输入一个Long: ";
cin >> myLong;
cout << "请输入一个Double: ";
cin >> myDouble; cout << "请输入你的姓名: ";
cin >> YourName; cout << "\n\n你输入的数是:" << endl;
cout << "Int: \t" << myInt << endl;
cout << "Long: \t" << myLong << endl;
cout << "Double: \t" << myDouble << endl;
cout << "姓名: \t" << YourName << endl;
cout<< endl << endl;
system("pause");
return ;
} //1 输入英文 ok
//2 ctr+z 会产生一个 EOF(-1)
int main02()
{
char ch;
while( (ch= cin.get())!= EOF)
{
std::cout << "字符: " << ch << std::endl;
}
std::cout << "\n结束.\n";
system("pause");
return 0;
} //演示:读一个字符 链式编程
void main03()
{
char a, b, c;
cin.get(a);
cin.get(b);
cin.get(c);
cout << a << b << c<< endl; cout << "开始链式编程" << endl;
cout.flush(); cin.get(a).get(b).get(c);
cout << a << b << c<< endl;
system("pause");
return ;
} //演示cin.getline() 可以接受空格
void main04()
{
char buf1[256];
char buf2[256];
cout << "\n请输入你的字符串 不超过256" ;
cin.getline(buf1, 256, '\n');
cout << buf1 << endl; //
cout << "注意: cin.getline() 和 cin >> buf2 的区别, 能不能带空格 " << endl;
cin >> buf2 ; //流提取操作符 遇见空格 停止提取输入流
cout << buf2 << endl;
system("pause");
} //缓冲区实验
/*
1 输入 "aa bb cc dd" 字符串入缓冲区
2 通过 cin >> buf1; 提走了 aa
3 不需要输入 可以再通过cin.getline() 把剩余的缓冲区数据提走
*/
void main05()
{
char buf1[256];
char buf2[256]; cout << "请输入带有空格的字符串,测试缓冲区" << endl;
cin >> buf1;
cout << "buf1:" << buf1 << endl; cout << "请输入数据..." << endl; //缓冲区没有数据,就等待; 缓冲区如果有数据直接从缓冲区中拿走数据
cin.getline(buf2, 256);
cout << "buf2:" << buf2 << endl;
system("pause");
} // ignore 和 peek
void main06()
{
int intchar;
char buf1[256];
char buf2[256]; cout << "请输入带有空格的字符串,测试缓冲区 aa bb cc dd ee " << endl;
cin >> buf1;
cout << "buf1:" << buf1 << endl; cout << "请输入数据..." << endl;
cin.ignore(2);
//intchar = cin.peek();
//cout << "缓冲区若有数据,返回第一个数据的asc码:" << intchar << endl; //缓冲区没有数据,就等待; 缓冲区如果有数据直接从缓冲区中拿走数据
cin.getline(buf2, 256);
cout << "buf2:" << buf2 << endl; intchar = cin.peek(); //没有缓冲区 默认是阻塞模式
cout << "缓冲区若有数据,返回第一个数据的asc码:" << intchar << endl;
system("pause");
} //案例:输入的整数和字符串分开处理
int main07()
{
cout << "Please, enter a number or a word: ";
char c = std::cin.get(); if ( (c >= '0') && (c <= '9') ) //输入的整数和字符串 分开处理
{
int n; //整数不可能 中间有空格 使用cin >>n
cin.putback (c);
cin >> n;
cout << "You entered a number: " << n << '\n';
}
else
{
string str;
cin.putback (c);
getline (cin,str); // //字符串 中间可能有空格 使用 cin.getline();
cout << "You entered a word: " << str << '\n';
} system("pause");
return 0;
}
二、标准输出流
标准输出流对象cout
cout.flush()
cout.put()
cout.write()
cout.width()
cout.fill()
cout.setf(标记)
manipulator(操作符、控制符)
flush
endl
oct
dec
hex
setbase
setw
setfill
setprecision
...
标准输出流常见api编程案例
#include "iostream"
using namespace std;
#include <iomanip> void main81()
{
cout << "hello world" << endl;
cout.put('h').put('e').put('l').put('\n');
cout.write("hello world", 4); //输出的长度 char buf[] = "hello world";
printf("\n");
cout.write(buf, strlen(buf)); printf("\n");
cout.write(buf, strlen(buf) - 6); printf("\n");
cout.write(buf, strlen(buf) + 6); //给的大于buf长度 不会帮我们检查 提高速度 printf("\n"); system("pause");
return ;
} //使用cout.setf()控制符
void main82()
{
//使用类成员函数
cout << "<start>";
cout.width(30);
cout.fill('*');
cout.setf(ios::showbase); //#include <iomanip>
cout.setf(ios::internal); //设置
cout << hex << 123 << "<End>\n"; cout << endl;
cout << endl;
//manipulator(操作符、控制符) //使用控制阀
cout << "<Start>"
<< setw(30)
<< setfill('*')
<< setiosflags(ios::showbase) //基数
<< setiosflags(ios::internal)
<< hex
<< 123
<< "<End>\n"
<< endl; system("pause");
}
C++格式化输出,C++输出格式控制
在输出数据时,为简便起见,往往不指定输出的格式,由系统根据数据的类型采取默认的格式,但有时希望数据按指定的格式输出,如要求以十六进制或八进制形式 输出一个 整数,对输出的小数只保留两位小数等。有两种方法可以达到此目的。
1)使用控制符的方法;
2)使用流对象的有关成员函数。分别叙述如下。
使用控制符的方法
int main()
{
int a;
cout<<"input a:";
cin>>a;
cout<<"dec:"<<dec<<a<<endl; //以十进制形式输出整数
cout<<"hex:"<<hex<<a<<endl; //以十六进制形式输出整数a
cout<<"oct:"<<setbase(8)<<a<<endl; //以八进制形式输出整数a
char *pt="China"; //pt指向字符串"China"
cout<<setw(10)<<pt<<endl; //指定域宽为,输出字符串
cout<<setfill('*')<<setw(10)<<pt<<endl; //指定域宽,输出字符串,空白处以'*'填充
double pi=22.0/7.0; //计算pi值
//按指数形式输出,8位小数
cout<<setiosflags(ios::scientific)<<setprecision(8);
cout<<"pi="<<pi<<endl; //输出pi值
cout<<"pi="<<setprecision(4)<<pi<<endl; //改为位小数
cout<<"pi="<<setiosflags(ios::fixed)<<pi<<endl; //改为小数形式输出
system("pause");
return 0;
}
运行结果如下:
input a:34↙(输入a的值)
dec:34 (十进制形式)
hex:22 (十六进制形式)
oct:42 (八进制形式)
China (域宽为)
*****China (域宽为,空白处以'*'填充)
pi=3.14285714e+00 (指数形式输出,8位小数)
pi=3.1429e+00 (指数形式输出,4位小数)
pi=3.143 (小数形式输出,精度仍为)
在输入输出时有一些特殊的要求,如在输出实数时规定字段宽度,只保留两位小数,数据向左或向右对齐等。C++提供了在输入输出流中使用的控制符(有的书中称为操纵符)。
举例, 输出双精度数:
double a=123.456789012345; // 对a赋初值
1) cout<<a; 输出: 123.456
2) cout<<setprecision(9)<<a; 输出: 123.456789
3) cout<<setprecision(6); 恢复默认格式(精度为6)
4) cout<< setiosflags(ios∷fixed); 输出:
123.456789
5) cout<<setiosflags(ios∷fixed)<<setprecision(8)<<a; 输出: 123.45678901
6) cout<<setiosflags(ios∷scientific)<<a; 输出: 1.234568e+02
7) cout<<setiosflags(ios∷scientific)<<setprecision(4)<<a;
输出: 1.2346e02
下面是整数输出的例子:
int b=123456; // 对b赋初值
1) cout<<b; 输出: 123456
2) cout<<hex<<b; 输出: 1e240
3) cout<<setiosflags(ios∷uppercase)<<b; 输出: 1E240
4) cout<<setw(10)<<b<<','<<b; 输出:
123456,123456
5) cout<<setfill('*')<<setw(10)<<b; 输出: ****
123456
6) cout<<setiosflags(ios∷showpos)<<b; 输出: +123456
如果在多个cout语句中使用相同的setw(n),并使用setiosflags(ios::right),可以实现各行数据右对齐,如果指定相同的精度,可以实现上下小数点对齐。
例如:各行小数点对齐。
int main( )
{
double
a=123.456,b=3.14159,c=-3214.67;
cout<<setiosflags(ios::fixed)<<setiosflags(ios::right)<<setprecision(2);
cout<<setw(10)<<a<<endl;
cout<<setw(10)<<b<<endl;
cout<<setw(10)<<c<<endl;
system("pause");
return
0;
}
输出如下:
123.46 (字段宽度为10,右对齐,取两位小数)
3.14
-3214.67
先统一设置定点形式输出、取两位小数、右对齐。这些设置对其后的输出均有效(除非重新设置),而setw只对其后一个输出项有效,因此必须在输出a,b,c之前都要写setw(10)。
用流对象的成员函数控制输出格式
除了可以用控制符来控制输出格式外,还可以通过调用流对象cout中用于控制输出格式的成员函数来控制输出格式。用于控制输出格式的常用的成员函数如下:
流成员函数setf和控制符setiosflags括号中的参数表示格式状态,它是通过格式标志来指定的。格式标志在类ios中被定义为枚举值。因此在引用这些格式标志时要在前面加上类名ios和域运算符“::”。格式标志见表13.5。
例:用流控制成员函数输出数据。 int main( )
{
int a=21;
cout.setf(ios::showbase);//显示基数符号(0x或)
cout<<"dec:"<<a<<endl; //默认以十进制形式输出a
cout.unsetf(ios::dec); //终止十进制的格式设置
cout.setf(ios::hex); //设置以十六进制输出的状态
cout<<"hex:"<<a<<endl; //以十六进制形式输出a
cout.unsetf(ios::hex); //终止十六进制的格式设置
cout.setf(ios::oct); //设置以八进制输出的状态
cout<<"oct:"<<a<<endl; //以八进制形式输出a
cout.unsetf(ios::oct);
char *pt="China"; //pt指向字符串"China"
cout.width(10); //指定域宽为
cout<<pt<<endl; //输出字符串
cout.width(10); //指定域宽为
cout.fill('*'); //指定空白处以'*'填充
cout<<pt<<endl; //输出字符串
double pi=22.0/7.0; //输出pi值
cout.setf(ios::scientific); //指定用科学记数法输出
cout<<"pi="; //输出"pi="
cout.width(14); //指定域宽为
cout<<pi<<endl; //输出pi值
cout.unsetf(ios::scientific); //终止科学记数法状态
cout.setf(ios::fixed); //指定用定点形式输出
cout.width(12); //指定域宽为
cout.setf(ios::showpos); //正数输出“+”号
cout.setf(ios::internal); //数符出现在左侧
cout.precision(6); //保留位小数
cout<<pi<<endl; //输出pi,注意数符“+”的位置
system("pause");
return 0;
}
运行情况如下:
dec:21(十进制形式)
hex:0x15 (十六进制形式,以x开头)
oct:025 (八进制形式,以开头)
China (域宽为)
*****China (域宽为,空白处以'*'填充)
pi=**3.142857e+00 (指数形式输出,域宽,默认位小数)
+***3.142857 (小数形式输出,精度为,最左侧输出数符“+”)
对程序的几点说明:
1) 成员函数width(n)和控制符setw(n)只对其后的第一个输出项有效。如:
cout. width(6);
cout <<20 <<3.14<<endl;
输出结果为 203.14
在输出第一个输出项20时,域宽为6,因此在20前面有4个空格,在输出3.14时,width (6)已不起作用,此时按系统默认的域宽输出(按数据实际长度输出)。如果要求在输出数据时都按指定的同一域宽n输出,不能只调用一次width(n),
而必须在输出每一项前都调用一次width(n>,上面的程序中就是这样做的。
2) 在表13.5中的输出格式状态分为5组,每一组中同时只能选用一种(例如dec、hex和oct中只能选一,它们是互相排斥的)。在用成员函数setf和
控制符setiosflags设置输出格式状态后,如果想改设置为同组的另一状态,应当调用成员函数unsetf(对应于成员函数self)或 resetiosflags(对应于控制符setiosflags),先终止原来设置的状态。然后再设置其他状态,大家可以从本程序中看到这点。程序在开
始虽然没有用成员函数self和控制符setiosflags设置用dec输出格式状态,但系统默认指定为dec,因此要改变为hex或oct,也应当先
用unsetf 函数终止原来设置。如果删去程序中的第7行和第10行,虽然在第8行和第11行中用成员函数setf设置了hex和oct格式,由于未终止dec格式,因
此hex和oct的设置均不起作用,系统依然以十进制形式输出。
同理,程序倒数第8行的unsetf 函数的调用也是不可缺少的。
3) 用setf 函数设置格式状态时,可以包含两个或多个格式标志,由于这些格式标志在ios类中被定义为枚举值,每一个格式标志以一个二进位代表,因此可以用位或运算符“|”组合多个格式标志。如倒数第5、第6行可以用下面一行代替:
cout.setf(ios::internal I ios::showpos); //包含两个状态标志,用"|"组合
可以看到:对输出格式的控制,既可以用控制符(如例13.2),也可以用cout流的有关成员函数(如例13.3),二者的作用是相同的。控制符是在头文件iomanip中定义的,因此用控制符时,必须包含iomanip头文件。cout流的成员函数是在头文件iostream 中定义的,因此只需包含头文件iostream,不必包含iomanip。