• C++基础——输入输出和缺省参数讲解


    上篇文章中,我们学习了C++的域名空间,这次继续来学习C++的基础知识。

    目录

    一.C++的输入输出

    总结:

    二.缺省参数

    全缺省案例:

    部分缺省案例:


    一.C++的输入输出

    例:

    1. #include
    2. using std::cout;
    3. using std::cin;
    4. using std::endl;
    5. int main() {
    6. cout << "Hello World" << endl;
    7. int a;
    8. double b;
    9. char c;
    10. cin >> a;
    11. cin >> b >> c;
    12. cout<
    13. return 0;
    14. }

     

            由结果可知:cout和cin具有可以自动识别变量的类型的功能,这是C++优于C语言的printf和scanf,但这也是它的缺点所在,cout不能够控制小数的位数,不能轻易输出字符变量c的ASCII码值,而printf可以。

    1. int main(){
    2. int a;
    3. double b;
    4. char c;
    5. //C++的输入输出可以自动识别变量的类型
    6. cin >> a;
    7. cin >> b >> c;
    8. cout << "C++版本的输出:" << endl;
    9. cout << "int a : "<< a<
    10. cout <<"double b : " << b << " char c : " << c << endl;
    11. cout << " ——————————————————————————————"<
    12. printf("C的输出:\n");
    13. printf("int a:%d\n", a);
    14. printf("double b:%.2lf\n", b);
    15. printf("char c:%d\n", c);
    16. }

             

     但C++是兼容C语言的,我们可以将cin和printf混合着用,方便又快捷。

    对于以上这些,我对C++的输入输出做个总结:

    1. 使用cout标准输出对象(控制台)和cin标准输入对象(键盘)时,必须包含< iostream >头文件 以及按命名空间使用方法使用std。

    2. cout和cin是全局的流对象,endl是特殊的C++符号,表示换行输出,他们都包含在包含< iostream >头文件中。

    3. >>是流提取运算符;<<是流插入运算符。

    4. 使用C++输入输出更方便,不需要像printf/scanf输入输出时那样,需要手动控制格式。 C++的输入输出可以自动识别变量类型。

    5. 实际上cout和cin分别是ostream和istream类型的对象,>>和<<也涉及运算符重载等知识, 这些知识我们我们后续才会学习,所以我们这里只是简单学习他们的使用。

    二.缺省参数

            定义:缺省参数是声明或定义函数时为函数的参数指定一个缺省值。在调用该函数时,如果没有指定实参,则采用该形参的缺省值,否则使用指定的实参。

    例:

    1. void F(int a = 0) { //函数缺省形参
    2. cout <<"a的值为:"<< a << endl;
    3. }
    4. int main() {
    5. F(); //缺省——省去实参赋值传递,系统会默认调用形参给出的值
    6. F(10); //未缺省——使用实参的值,那么调用时就不会使用形参的值了
    7. return 0;
    8. }

      

    全缺省案例:

    1. void F(int a = 10, int b = 20, int c = 30) { //全缺省形参

     //注:给值时只能从左到右给,不能给a,c不给b!!!

     还有就是:实参值传给形参的使用权限要大于使用缺省参数给出的值,所以一旦实参给出了值,编译器就不会再使用缺省参数给出的值!

    部分缺省案例:

    1. void F(int a, int b=15, int c = 30) {
    2. cout << " a=" << a << " b=" << b << " c=" << c << endl;
    3. }
    4. int main() {
    5. F(); ——报错,因为形参a在函数种本就没有值,所以实参必须给值,否则报错
    6. F(17);
    7. F(17, 29);
    8. F(17, 29, 63);
    9. return 0;
    10. }

    部分缺省的核心:从右往左连续缺省,也就是说当有一个的实参没传时,那么这个函数对应位置的形参一定处在最左边,即至少要给函数F传一个值及以上。

            若是非要只给b缺省也可以:void F(int a=20, int c int b=15){}       把c写到b前面即可。

            此外还要注意:缺省参数的函数在进行声明和定义分离时,缺省参数不能在函数声明和定义中同时出现,这是为什么?

    例:

    .h文件

    1. #include
    2. #include
    3. namespace bit {
    4. typedef struct Stack {
    5. int* a;
    6. int size;
    7. int capacity;
    8. }ST;
    9. //函数声明
    10. void StackInit(ST* pst, int capa=4);
    11. void StackPush(ST* pst, int x);
    12. }

    .cpp文件

    1. #include"Stack.h"
    2. namespace bit {
    3. void StackInit(struct Stack* pst, int Capa=4) {
    4. pst->a = (int*)malloc(sizeof(int) * Capa);
    5. assert(pst->a);
    6. pst->size = 0;
    7. pst->capacity = Capa;
    8. }
    9. void StackPush(struct Stack* pst, int x){
    10. //.....
    11. }

     

            声明和定义同时出现缺省参数值,就会报错。原因就是因为在编写代码的过程中万一声明中写出的缺省参数值和定义中写出的缺省参数值不一致,有异议,系统就不知道该执行哪一个,所以以后缺省参数统一在声明中写,它只认定声明的缺省参数。 

     

     

          

  • 相关阅读:
    对一个即将上线的网站,如何做一个较完整的Web应用/网站测试?
    使用Unity制作3D驾驶游戏
    HarmonyOS Next开发学习手册——ExtensionAbility
    LVS-群集架构介绍(linux 虚拟服务)
    pnpm快速创建 Vue.js 项目(npm类似)
    redis
    老卫带你学---leetcode刷题(347. 前 K 个高频元素)
    基于改进人工蜂群算法的 K 均值聚类算法(Matlab代码实现)
    vue学习之组件传值、自定义事件
    红蓝对抗-攻防演练中红队如何识别蜜罐保护自己
  • 原文地址:https://blog.csdn.net/weixin_69283129/article/details/127728797