1、命名空间、C++的复合类型、缺省参数

命名空间

1、命名空间的定义

使用namespace定义,使用作用域限定符::访问

#include <iostream>
namespace ICBC{int money  = 0;void save( int m){money += m;}
}
int main( void ){ICBC::save( 100);  std::cout << "工行卡余额:"  << ICBC::money << std::endl;return 0;
}

2、声明定义分开

#include <iostream>namespace BOC{int money  = 0;void save( int m){  // 声明同时定义money += m;}void pay( int m);   // 声明
}
void BOC::pay( int m){  // 定义money -= m;
}int main( void ){BOC::save( 100);BOC::pay( 50);std::cout << "中国银行余额:"  << BOC::money << std::endl;return 0;
}

3、命名空间的自动合并

多个文件或位置的相同namespace会被编译器自动合并。

#include <iostream>namespace ICBC{int money  = 0;void save( int m){money += m;}
}namespace BOC{int money  = 0;void save( int m){  // 声明同时定义money += m;}void pay( int m);   // 声明
}namespace ICBC{void pay( int m){money -= m;}
}void BOC::pay( int m){  // 定义money -= m;
}int main( void ){ICBC::save( 100);  ICBC::pay( 50);std::cout << "工行余额:"  << ICBC::money << std::endl;BOC::save( 1000);BOC::pay( 500);std::cout << "中国银行余额:"  << BOC::money << std::endl;return 0;
}

3、命名空间指令

C++中有 定义表和可见表。
using namespace std为名字空间指令,表示从这行代码开始,std中的内容在当前作用域可见,在可见表

// 命名空间指令
#include <iostream>
using namespace std;
namespace ns{int g_value = 0;
}//int g_value = 0;
//using namespace ns; // 命名空间指令:从这行代码开始,ns中的内容在当前作用域可见int main( void ){
//  int g_value = 0;using namespace ns; // 命名空间指令:从这行代码开始,ns中的内容在当前作用域可见g_value = 666;  //  /*std::*/cout << "ns::g_value = " << ns::g_value << /*std::*/endl;return 0;
}

4、命名空间声明

命名空间声明会让其出现在定义表中

// 命名空间声明
#include <iostream>
using namespace std;namespace ns{int g_value = 0;
}//int g_value = 0;
//using ns::g_value; // 从这行代码开始,ns中的g_value引入当前作用域(相当于定义)int main( void ){
//  int g_value = 0;using ns::g_value; // 从这行代码开始,ns中的g_value引入当前作用域(相当于定义)g_value = 666;  //  cout << "ns::g_value = " << ns::g_value << endl;return 0;
}

5、命名空间嵌套和别名

命名空间嵌套

  • 内层标识符与外层同名标识符为隐藏关系
  • 嵌套的命名空间需要逐层分解

命名空间别名

  • 可通过命名空间别名简化书写 namespace ns four = ns1::ns2::ns3::ns4;
#include <iostream>
using namespace std;namespace ns1{int g_value = 100;namespace ns2{int g_value = 200;namespace ns3{int g_value = 300;namespace ns4{int g_value = 400;}}}
}int main( void ){namespace ns_four = ns1::ns2::ns3::ns4; // 别名cout << ns_four::g_value << endl;return 0;
}

C++的复合类型

  • C++的结构体
    • 结构体内部可以定义成员函数
    • 在成员函数的内部可以直接访问本结构体的成员,无需通过 .->
  • C++的联合
    • 支持匿名联合
  • C++的枚举
    • 独立的类型,和整型数据之间不能隐式转换
    • 表示布尔量的数据类型
      • bool
    • 布尔类型的字面值常量
      • true 表示真
      • false 表示假
    • 布尔类型的本质
      • 单字节整数,用1和0表示真和假
    • 任何基本类型的数据都可以被隐式转换为布尔类型
      • 非0即真,0即假
// C++的复合类型#include <iostream>
#include <cstring>
using namespace std;void TestStruct(){struct Student{int m_age;         // 成员变量char m_name[256];  // 成员变量 void getInfo(){    // 成员函数cout << "getInfo(): 姓名:" << m_name << ", 年龄:" << m_age << endl;}};/*struct*/ Student s;s.m_age = 22;strcpy(s.m_name,"张三");cout << "姓名:" << s.m_name << ", 年龄:" << s.m_age << endl;s.getInfo();
}
void TestUnion(){union{  // 匿名联合,主要想体现所有的成员共用同一块内存空间int i;char c[4];};i = 0x12345678; // 小端字节序  cout << hex << (int)c[0] << ' ' << (int)c[1] << ' ' << (int)c[2] << ' ' << (int)c[3] << endl;
}
void TestEnum(){enum Color{red, green, blue};/*enum*/ Color c = red; // 0;errorstd::cout << c << std::endl;
}
void TestBool(){bool a = "Hello"; // 0.0000001; // 123; // true;bool b = NULL;  // 0.0000000; // 0;   // false;cout << "a=" << a << ", b=" << b << endl;
} 
int main(void){
//  TestStruct();
//  TestUnion();
//  TestEnum();TestBool();return 0;
}

缺省/默认参数

  • 可以为函数的形参指定缺省 (默认) 值,这种参数称之为缺省参数
    • 当调用该函数时若未指定实参,则使用形参的缺省(默认)值
  • 如果函数的某一个形参具有缺省值,那么该形参后面的所有形参必须都具有缺省值
  • 尽量避免因为使用缺省参数而导致重载匹配歧义
  • 函数形参的缺省值只能在函数声明中指定
  • 注意:默认值不是初始值
// 函数的缺省参数: 带默认值的形参 (默认值不是初始值)#include <iostream>
using namespace std;void foo(int a, float b = 3.14, double c = 5.67, short d = 10, char e = 'A');   // 声明void foo(int a, float b, double c, short d, char e){   // 定义cout << "e: " << e << endl;
}void foo(int i){
}int main(void){foo(12, 3.45, 6.78, 34);  // 没有给第五个参数提供实参,所以使用缺省值foo(12, 3.45, 6.78, 34, 'B'); // 给第五个参数提供了实参,使用实参//  foo(12); // 因为使用缺省参数,导致重载匹配歧义(不知道选择哪一个)return 0;
}

问题

  1. 任何基本类型的数据,都可以隐式转换为布尔类型,那复合类型的数据,如何转换为布尔类型?

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/197407.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

@Scheduled,Quartz,XXL-JOB三种定时任务总结

Scheduled&#xff0c;Quartz&#xff0c;XXL-JOB三种定时任务总结 一、Scheduled 简介 Scheduled 是 Spring 框架中用于声明定时任务的注解。通过使用 Scheduled 注解&#xff0c;你可以指定一个方法应该在何时执行&#xff0c;无需依赖外部的调度器。 这个注解通常与Enab…

javascript object转换成json格式

JavaScript中object与json的转换 1、JSON字符串: var str1 { "name": "cxh", "sex": "man" };2、JSON对象: var str2 { "name": "cxh", "sex": "man" };3、JSON字符串转换为JSON对象 要使…

判断是否存在重复的数

系列文章目录 进阶的卡莎C_睡觉觉觉得的博客-CSDN博客数1的个数_睡觉觉觉得的博客-CSDN博客双精度浮点数的输入输出_睡觉觉觉得的博客-CSDN博客足球联赛积分_睡觉觉觉得的博客-CSDN博客大减价(一级)_睡觉觉觉得的博客-CSDN博客小写字母的判断_睡觉觉觉得的博客-CSDN博客纸币(C…

(C语言)通过循环按行顺序为一个矩阵赋予1,3,5,7,9,等奇数,然后输出矩阵左下角的值。

#include<stdio.h> int main() {int a[5][5];int n 1;for(int i 0;i < 5;i ){for(int j 0;j < 5;j ){a[i][j] n;n 2;}}for(int i 0;i < 5;i ){for(int j 0;j < i;j )printf("%-5d",a[i][j]);printf("\n");}return 0; } 运行截图…

深入理解JVM内存空间的担保策略

Java虚拟机&#xff08;JVM&#xff09;的内存管理是Java性能调优中最重要的方面之一&#xff0c;特别是在处理大型应用和服务时。JVM内存管理的一个关键组成部分是垃圾回收&#xff08;GC&#xff09;。在GC过程中&#xff0c;JVM需要确保有足够的内存来创建新对象&#xff0c…

STM32串口接收不定长数据(空闲中断+DMA)

玩转 STM32 单片机&#xff0c;肯定离不开串口。串口使用一个称为串行通信协议的协议来管理数据传输&#xff0c;该协议在数据传输期间控制数据流&#xff0c;包括数据位数、波特率、校验位和停止位等。由于串口简单易用&#xff0c;在各种产品交互中都有广泛应用。 但在使用串…

Java中的锁

Java常见锁 【超全面】_java锁-CSDN博客 一文看懂Java中的锁 - 知乎 一文读懂 Java 中的各种锁 - 知乎 java中锁的分类总结_java string 锁-CSDN博客 https://www.cnblogs.com/hangychn/p/17184814.html https://www.cnblogs.com/durenniu/p/10949491.html 锁-Java - 知…

【LeeCode】链表总结

理论基础 链表的种类主要为&#xff1a;单链表&#xff0c;双链表&#xff0c;循环链表 链表的存储方式&#xff1a;链表的节点在内存中是分散存储的&#xff0c;通过指针连在一起。 链表是如何进行增删改查的。 数组和链表在不同场景下的性能分析。 经典题目 虚拟头节点 …

Passkey模式

以下内容参考自谷歌的代码&#xff1a; 原文地址 Passkey 模式用于以比简单地将其他类设置为友元类更细粒度的方式将类的部分方法暴露给另一个类。本质上&#xff0c;它涉及创建一个“passkey”类&#xff0c;该类只能由特定的其他类构造&#xff0c;并要求在调用您希望限制使…

手把手教你做基于stm32的红外、语音、按键智能灯光控制(下)

目录&#xff1a; 4.6. DHT11温湿度传感器模块4.7. 语音识别模块4.7. OLED显示屏模块 5. 不同的工作模式6. 总结 在接着&#xff08;上&#xff09;写之前&#xff0c;首先来看一下效果&#xff1a; 链接: link 需要源码什么的可以私信我哦 4.6. DHT11温湿度传感器模块 这个…

C陷阱与缺陷——第2章语法陷阱

1. 理解函数声明 硬件将调用首地址为0位置的子例程 (*(void(*)())0)(); 任何C变量的声明都由两部分组成&#xff1a;类型以及一组类似表达式的声明符&#xff0c;声明符从表面看与表达式有些类似&#xff0c;对它求值应该返回一个声明中给定类型的结果。 假定变量fp是一个函…

[go 面试] 构建高效微服务通信:选择合适的通信方式

关注公众号【爱发白日梦的后端】分享技术干货、读书笔记、开源项目、实战经验、高效开发工具等&#xff0c;您的关注将是我的更新动力&#xff01; 构建分布式系统或微服务架构时&#xff0c;服务间通信成为至关重要的一环。不同的通信方式各有优劣&#xff0c;因此在选择时需根…

数据库sql是什么?

数据库是什么&#xff1f; 为了将数据持久保存&#xff0c;java中的对象都是在内存中&#xff0c;程序结束数据就会销毁&#xff0c;在学习IO过程中将数据存储在文件中&#xff0c;但是内容整体是字符串&#xff0c;使用起来不方便。所以需要数据库长久保存数据还便于提取 数…

值和引用的传递与初始化块

值&#xff1a;1.基本类型数据&#xff1b;2.对象的地址 引用&#xff1a;传句柄的地址 在java中只有按值传递没有按引用传递&#xff0c;c语言也只有按值传递&#xff0c;只有c才有引用传递。 块&#xff1a; 静态块>块>构造方法 package com;public class Person {pri…

揭秘预付费电表怎么无线收费——方便快捷收费

【摘要】针对目前市场上普遍以Ic卡作为售电介质的预付费售电系统存在的问题&#xff0c;介绍了一种新型的无线预付费售电系统及其构成&#xff0c;并给出了整个系统设计的完整方案。整个系统包括用户终端和电力管理系统端&#xff0c;它们之间通过双工通信可以将用户用电信息和…

Kubernetes存储搭建NFS挂载失败处理

搞NFS存储时候发现如下问题&#xff1a; Events:Type Reason Age From Message---- ------ ---- ---- -------Normal Scheduled 5m1s default-scheduler Successful…

JavaScrip之函数柯理化、参数复用、提前确认、延迟执行

MENU 1、参数复用2、提前确认 (惰性函数)3、延迟运行4、初步封装5、递归封装6、经典面试题 1、参数复用 // 普通函数验证 function check(regExp, text) {return regExp.test(text); }console.log(check(/^\d$/g, 123)); // true console.log(check(/^\d$/g, 2d)); // false…

LeetCode算法练习top100:(7)递归回溯

package top100.递归回溯;import java.util.*;public class TOP {//46. 不含重复数字的全排列List<List<Integer>> res new ArrayList<>();public List<List<Integer>> permute(int[] nums) {LinkedList<Integer> path new LinkedList&l…

电子学会全国青少年软件编程等级考试 中小学生python一级历年真题解析【更新至2023年9月 持续更新】

中国电子学会python等级考试一级历年真题解析 一、考级知识点分析 一、 了解Python多种开发环境&#xff0c;熟练使用Python自带的IDLE开 发环境&#xff0c;能够进行程序编写、调试和分析&#xff0c;具备使用Python开发 环境进行程序设计的能力 了解Python常见的几种编程环…

堆排序详细解读

简介 堆排序是一种基于二叉堆数据结构的排序算法&#xff0c;它的特点是不同于传统的比较排序算法&#xff0c;它是通过建立一个堆结构来实现的。堆排序分为两个阶段&#xff0c;首先建立堆&#xff0c;然后逐步将堆顶元素与堆的最后一个元素交换并调整堆&#xff0c;使得最大…