我的C++入门

原创 2011年01月21日 03:11:00

C++入门,第一次把printf改成cout(开始还写成了“count”),scanf改成了cin(开始有个视频写的是“Cin”),一开始觉得在C的基础上还是比较得心应手,只是几个地方要注意;我对.<iostream>和<iostream.h>。。。cin。。。。。cout有了很大的兴趣,由于用的地方比较多,我果断抛弃了其他的基础知识,先研究一下这个。老鸟啊,高手啊不要笑话哦。。

我也是为跟我一样的菜鸟们节约一点宝贵的时间,当然自己也加强巩固一下:

1.<iostream>和<iostream.h>

<iostream>和<iostream.h>是不一样,前者没有后缀,实际上,在你的编译器include文件夹里面可以看到,二者是两个文件,打开文件就会发现,里面的代码是不一样的。

  后缀为.h的头文件c++标准已经明确提出不支持了,早些的实现将标准库功能定义在全局空间里,声明在带.h后缀的头文件里,c++标准为了和C区别开,也为了正确使用命名空间,规定头文件不使用后缀.h。

  因此,当使用<iostream.h>时,相当于在c中调用库函数,使用的是全局命名空间,也就是早期的c++实现;当使用<iostream>的时候,该头文件没有定义全局命名空间,必须使用namespace std;这样才能正确使用cout。

       <iostream>是新的C++标准,使用如下

       

           #include <iosteam>

        using namespace std; (声明定义的变量为全局变量)

 

      <iostream.h>是老的C++标准了。

   2.接着cin,读为 "c in",拼音"sei yin", 当然它获取一个字符的时候没有什么多说的。但是在获取字符串的时候有必要好好看看。

   2.1cin>>

   程序的输入都建有一个缓冲区,即输入缓冲区。一次输入过程是这样的,当一次键盘输入结束时会将输入的数据存入输入缓冲区,而cin函数直接从输入缓冲区中取数据。正因为cin函数是直接从缓冲区取数据的,所以有时候当缓冲区中有残留数据时,cin函数会直接取得这些残留数据而不会请求键盘输入,这就是例子中为什么会出现输入语句失效的原因!

程序:

#include <iostream>

using namespace std;

int main()

{

char str1[10], str2[10];

cin>>str1;

cin>>str2;

cout<<str1<<endl;

cout<<str2<<endl;

return 0;

}

测试一输入:

abcd[Enter]

efgh[Enter]

输出:

abcd

efgh

【分析】输入遇到回车符结束,很正常。



测试二输入:

abcd efgh

输出:

abcd

efgh

【分析】第一次读取字符串时遇到空格则停止了,将abcd读入str1,并舍弃了空格,将后面的字符串给了第二个字符串。这证明了cin读入数据遇到空格结束;并且丢弃空格符;缓冲区有残留数据室,读入操作直接从缓冲区中取数据。

 

 

2.cin.get()和cin.getline()

2.1.cin.get()

该函数有三种格式:无参,一参数,二参数

即cin.get(),cin.get(char ch),cin.get(array_name, Arsize)



读取字符的情况:

输入结束条件:Enter键

对结束符处理:不丢弃缓冲区中的Enter



cin.get()与cin.get(char ch)用于读取字符,他们的使用是相似的,

即:ch=cin.get()与cin.get(ch)是等价的。


cin.get(array_name, Arsize)是用来读取字符串的,可以接受空格字符,遇到Enter结束输入,按照长度(Arsize)读取字符,会丢弃最后的Enter字符。

2.2.cin.getline()

cin.getline()与cin.get(array_name, Arsize)的读取方式差不多,以Enter结束,可以接受空格字符。按照长度(Arsize)读取字符,会丢弃最后的Enter字符。

 

 

 

 

 

 

 

 

 

cin.get(array_name, Arsize)当输入的字符串超长时,不会引起cin函数的错误,后面的cin操作会继续执行,只是直接从缓冲区中取数据。但是cin.getline()当输入超长时,会引起cin函数的错误,后面的cin操作将不再执行.

比如:

#include <iostream>

using namespace std;

int main ()

{

char a[20];
char b[20];

cin.get(a, 7);
cin.get(b, 7);

cout<<a<<endl;
cout<<b<<endl;

return 0;

}

测试:eeee空格ee回车

 结果:eeee空格e

        e

有第二行输出

 第七个字符用/0代替了,然后把第七个字符放到第二个里面(剔除“回车”字符)。

 

如果把cin.get改成cin.getline。。结果如

输入:eee eeeee

输出:eee ee

无第二行输出!!

3.cout:读为 "c out"。

cout<<a<<endl;(endl在这里相当于C里面的/n);输出a的值。

cout<<"a="<<a<<endl;  输出a=“值”;

 

 

 

 

 




版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

CUDA编程(九)并行矩阵乘法

CUDA编程(九)矩阵乘法 在之前我们一直围绕着一个非常简单的求立方和的小程序学习CUDA,不过这个立方和的小程序没有什么实际意义,这篇博客我们用CUDA并行了矩阵乘法,问题也比较简单,基于上一个立方...

CUDA编程(一)第一个CUDA程序

CUDA(Compute Unified Device Architecture),是显卡厂商NVIDIA推出的运算平台。 CUDA™是一种由NVIDIA推出的通用并行计算架构,该架构使GPU能够解决...

CUDA编程(二) CUDA初始化与核函数

这次给大家介绍CUDA的初始化和如何在显卡上运行程序,即先将数据从内存复制到显存,再写好运算的核函数,之后用CUDA调用核函数,完成GPU上的计算,之后将结果复制回内存,释放掉显存的整个过程。

CUDA编程(八)树状加法

CUDA编程(八)树状加法上一篇博客我们介绍了ShareMemory和Thread同步,最后利用这些知识完成了block内部线程结果的加和,减轻了CPU的负担,结果还是比较令人满意的,但是block的...

CUDA编程(三)评估CUDA程序的表现

CUDA编程(三)评估CUDA程序的表现 这篇博客主要讲解了怎么去获取核函数执行的准确时间,以及如何去根据这个时间评估CUDA程序的表现,也就是推算所谓的内存带宽,总的来说有了这些准备,我们接下来就...

CUDA编程(十)使用Kahan's Summation Formula提高精度

CUDA编程(十) 使用Kahan’s Summation Formula提高精度 之前我们用CUDA完成了矩阵乘法,但是当然会存在很多问题,除了速度问题,GPU浮点数运算的精度也很差,本篇博客从...

CUDA编程(六)进一步并行

CUDA编程(六)进一步并行 在上一篇博客中给大家介绍了一个访存方面非常重要的优化,我们通过使用连续的内存存取模式,取得了令人满意的优化效果,最终内存带宽也达到了GB/s的级别。之前也已经提到过了,...

CUDA编程(五)关注内存的存取模式

CUDA编程(五)关注内存的存取模式 除了通过Block继续提高线程数量来优化性能,这次想给大家先介绍一个访存方面非常重要的优化,同样可以大幅提高程序的性能,即通过尽可能的连续操作内存,减少内存存取...

CUDA编程(七)共享内存与Thread的同步

CUDA编程(七)共享内存与Thread的同步在之前我们通过block,继续增大了线程的数量,结果还是比较令人满意的,但是也产生了一个新的问题,即,我们在CPU端的加和压力变得很大,所以我们想到能不能...

CUDA编程(四)并行化我们的程序

CUDA编程(四)并行化我们的程序 上一篇博客主要讲解了怎么去评估CUDA程序的表现,博客的最后我们计算了在GPU上单线程计算立方和的程序的内存带宽,发现其内存带宽的表现是十分糟糕的。 这篇博...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)