【C++初阶】一、入门知识讲解(C++关键字、命名空间、C++输入输出、缺省参数、函数重载)

=========================================================================

相关代码gitee自取

C语言学习日记: 加油努力 (gitee.com)

 =========================================================================

接上期

【数据结构初阶】十一、归并排序(比较排序)的讲解和实现
(递归版本 + 非递归版本 -- C语言实现)-CSDN博客

 =========================================================================

                     

引言:什么是C++

  • C语言结构化模块化的语言适合处理较小规模的程序
    对于复杂的问题规模较大的程序需要高度的抽象和建模时C语言就不合适了
    为了解决软件危机,20世纪80年代,计算机界提出了:
    OOPobject oriented programming面向对象
    思想
    支持面向对象的程序设计语言应运而生

                             
  • 1982年,Bjarne Stroustrup博士C语言的基础上引入并扩充了面向对象的概念
    发明了一种新的程序语言,为了表达该语言与C语言的渊源关系命名为C++
                             
  • 因此:C++基于C语言而产生的,
    即可以进行C语言的过程化程序设计

    又可以进行以抽象数据类型为特点的基于对象的程序设计
    还可以进行面向对象的程序设计
                      
  • C++在C语言的基础之上容纳了面向对象编程思想
    增加了许多有用的以及编程范式
    熟悉C语言的话,对C++的学习有一定的帮助
                    
  • 本篇博客主要目标
    1、补充C语言语法的不足,以及C++如何对C语言设计不合理的地方进行优化的
    如:作用域方面IO方面函数方面指针方面宏方面
    2、为后续了解类和对象打下基础

           

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

             

引言:C++的发展史

1979年,贝尔实验室的本贾尼等人试图分析unix内核的时候
试图将内核模块化,于是在C语言的基础上进行扩展增加了类的机制
完成了一个可以运行的预处理程序称之为 C with classes

                    

C++语言也进行着逐步递进由浅入深过程

C++的历史版本:
阶段内容
C with classes

类及派生类、公有和私有成员、类的构造和析构、友元、内联函数、赋值运算符
重载等

C++1.0添加虚函数概念,函数和运算符重载,引用、常量等
C++2.0更加完善支持面向对象,新增保护成员、多重继承、对象的初始化、抽象类、静态成员以及const成员函数
C++3.0进一步完善,引入模板,解决多重继承产生的二义性问题和相应构造和析构的处理
C++98C++标准第一个版本绝大多数编译器都支持,得到了国际标准化组织ISO)和美国标准化协会认可,以模板方式重写C++标准库引入了STL(标准模板库)
C++03C++标准第二个版本,语言特性无大改变,主要:修订错误、减少多异性
C++05

C++标准委员会发布了一份计数报告(Technical Report -- TR1),正式更名为C++0x,
即:计划在本世纪第一个10年的某个时间发布

C++11增加了许多特性使得C++更像一种新语言
如:正则表达式、基于范围for循环、auto关键字、新容器、列表初始化、标准线程库等
C++14对C++11的扩展,主要是修复C++11中的漏洞以及改进,
如:泛型的lambda表达式,auto的返回值类型推导,二进制字面常量等
C++17在C++11上做了一些小幅改进,增加了19个新特性,
如:static_assert()的文本信息可选,Fold表达式用于可变的模板,
if 和 switch 语句中的初始化器等
C++20自C++11以来最大的发行版引入了许多新的特性
如:模块(Modules)、协程(Coroutines)、范围(Ranges)、概念(Constraints)
等重大特性;
还有对已有特性的更新,如:Lambda支持模板、范围for循环支持初始化等
C++23制定中……

            

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

              

一、C++关键字(C++98版本)

C++总计63个关键字包含C语言的32个关键字

该C++版本关键字表格:
asmdoifreturntrycontinue
autodoubleinlineshorttypedeffor
booldynamic_castintsignedtypeidpublic
breakelselongsizeoftypenamethrow
caseenummutablestaticunionwchar_t
catchexplicitnamespacestatic_castunsigneddefault
charexportnewstructusingfriend
classexternoperatorswitchvirtualregister
constfalseprivatetemplatevoidtrue
const_castfloatprotectedthisvolatilewhile
deletegotoreinterpret_cast

红色关键字之前C语言博客有提到或使用过的关键字

         

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

             

二、namespace -- 命名空间关键字

(1). 命名空间的作用:

C/C++中,变量函数后面要了解的类都是大量存在的,
这些变量函数的名称都将存在于全局作用域可能会导致很多冲突
使用命名空间的目的对标识符的名称进行本地化,以避免命名冲突名字污染
namespace关键字的出现就是针对这种问题

示例:

                     

                     


                    

(2). 命名空间的定义:

  • 定义命名空间需要使用到namespace关键字

    关键字后接命名空间的名称然后再加上一对大括号{}即可

    大括号{}中内容命名空间的成员
                      

  • 一般开发中会使用项目的名称作为命名空间的名称
                            

一般命名空间的定义:

命名空间嵌套子命名空间:

存在多个相同名称的命名空间:
  • 同一个工程中允许存在多个相同名称的命名空间
    编译器最后会合并成同一个命名空间
                 
  • 一个工程中的 test.h头文件)  text.cppC++文件
    两个同名命名空间会被合并成一个

                     

                     


                    

(3). 命名空间的使用:

定义一个命名空间定义了一个新的作用域

命名空间中的所有内容局限于该命名空间中

所以不能通过直接调用来使用命名空间中的内容

命名空间的使用三种方式

                      

方式一:
加命名空间名称和作用域限定符
  • 作用域限定符两个冒号) --   : :

                       

方式二:
using namespace 命名空间名称 展开命名空间
  • 使用 using namespace 命名空间名称 可以展开对应的命名空间
    展开后可以直接通过该命名空间中成员的名称使用该成员
                        
  • 但是使用该方式对命名空间的展开
    会导致命名空间的所有内容暴露出来
    可能又会导致命名冲突问题
                   
  • 所以一般在自己使用时为了方便才会使用该方式
    如果是项目工程该方式一定要慎重使用,可能会出大问题的

                 

方式三:
使用using关键字只展开命名空间中的某个成员
  • 通过方式二直接展开命名空间会有命名冲突的风险
    那么我们可以通过
    using 命名空间名称::指定成员
    指定只展开命名空间中的某个成员
                         
  • 这种方式比较常用的,
    通常是对一些常用的成员对象进行使用
    避免频繁使用方式一调用命名空间减轻代码冗余

            

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

             

三、C++输出&输入

C++中有了新的输入和输出方法,虽然说有了新的输入输出方法,
之前C语言中的输入和输出方法也是可以用的
了解C++的输入和输出方法前,需要先了解以下概念

                     

                     

std -- C++标准库命名空间

stdC++标准库的命名空间名C++标准库的定义实现都放在这个命名空间中
上一标题我们知道了使用命名空间的三种方式,而使用std命名空间的方式要考虑实际情况

               

std命名空间的使用惯例:

  • 在自己的日常练习中,建议直接方式二即可
    即:using namespace std
    这样使用std命名空间就很方便了,不用频繁使用方式一进行操作
                     
  • 而在项目工程中,using namespace std 展开方式二展开),
    标准库就全部暴露出来了,如果我们定义了跟库中重名的 类型/对象/函数
    就会存在命名冲突问题。该问题在日常练习中很少出现
    但是项目开发中代码较多规模大,就很容易出现
                        
  • 所以建议在项目开发中使用方式三指定展开
    即:using std::成员(对象)
    指定展开std命名空间中常用的几个库对象/类型/成员
    像是C++输出时使用的cout输入时使用的cin

                         

                         


                        

cout 和 cin

  • cout  --  console(控制台) out  --  标准输出对象(控制台)  --  流插入
    cin  --  console(控制台) in  --  标准输入对象(键盘)  --  流提取
                        
  • 使用cout标准输出对象cin标准输入对象
    需要包含 <iostream> 头文件IO流头文件以及 按命名空间使用方法使用std
注:C++ <iostream>头文件 不需要像C语言一样加“.h”后缀

早期标准库所有功能全局域中实现声明在“.h”后缀的头文件
使用时只需包含对应头文件即可后来将标准库所有功能实现在std命名空间
为了和C语言头文件区分,也为了正确使用命名空间规定C++头文件不加“.h”后缀
旧编译器(vc 6.0)中还支持 <iostream.h> 格式,后续编译器已不支持,
因此推荐使用 <iostream> + std命名空间 的方式
                   

  • cout cin 全局的流对象endlendline)是特殊的C++符号表示换行输出
    他们都包含在 <iostream>头文件
                         
  • 使用cout进行输出时还需要用到<<  --  流插入运算符
    使用cin进行输入时还需要用到>>  --  流提取运算符
    (在C语言中<<>> 位于算符在C++中又多了以上身份
                    
  • 使用C++输入和输出相对C语言更方便
    不需要像 scanf / printf 输入输出时要手动控制格式%d%p……),
    C++的输入和输出可以自动识别变量类型
                         
  • 实际上 cout cin 分别是 ostream istream 类型对象
    >> <<涉及运算符重载等知识这里只是简单了解并使用
    关于coutcin还有很多更复杂的用法
    比如控制浮点数输出精度控制整型输出进制格式等,但并不常用
    实在需要使用时可以用C语言来操作C++兼容C语言的操作
示例:

对应代码:
//包含IO流头文件:
#include <iostream>//指定展开命名空间成员:
using std::cout;  //指定展开标准输出对象(控制台)
using std::cin;  //指定展开标准输入对象(键盘)
using std::endl;  //指定展开C++换行符号int main()
{int a = 10; //整型变量double b = 3.14; //浮点型变量cout << "使用cout打印当前a和b:" << endl;//使用cout进行输出:cout << a << endl << b << endl;/** 通过cout标准输出对象和<<流插入运算符进行输出打印:* * 先将a这个变量流进std::cout这个控制台中打印,* 再进行endl换行,再将b这个变量* 流进std::cout这个控制台中打印,再换行。* * 即使 a变量 和 b变量 的类型不同也能打印* C++的输入和输出可以自动识别变量类型*/cout << "使用cin分别输入数据到a和b:" << endl;//使用cin进行输入:cin >> a >> b;/** 通过cin标准输入对象和>>流提取运算符对数据进行输入:** 让你在控制台上输入的数据分别流入a和b这两个变量中** 即使 a变量 和 b变量 的类型不同也能输入* C++的输入和输出可以自动识别变量类型*/cout << "输入后再使用cout进行输出打印:" << endl;cout << a << endl << b << endl;return 0;
}

            

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

             

四、缺省参数

(1). 缺省函数的概念:

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

有了缺省参数可以调整参数的各种形式来调用该函数

                        

  • 缺省值必须是常量或者全局变量
                    
  • C语言不支持缺省参数编译器不支持
                             
  • 缺省参数不能在函数声明和定义中同时出现

                     


                    

(2). 缺省函数的分类:

全缺省参数:

函数的所有参数都设置对应的缺省参数

图示:

                          

                   

半缺省参数:

只对函数的部分参数设置对应的缺省参数

                       

  • 半缺省参数必须从右往左依次来给出不能间隔着给
    传参从左往右半缺省参数从右往左
图示:

            

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

             

五、函数重载

自然语言中,一个词可以有多重含义
人们可以通过上下文来判断该词真实的含义,即该词被重载

                           

函数重载的概念:

函数重载是函数的一种特殊情况
C++允许在同一作用域中声明几个功能类似的同名函数
这些同名函数的形参列表参数个数参数类型类型顺序不同
函数重载常被用来处理实现功能类似但数据类型不同的问题

图示:

                     

                     


                    

(难)C++支持函数重载的原理 -- 名字修饰(name Mangling)

为什么C语言不支持函数重载而C++支持函数重载

解决这个问题,需要先了解一下编译链接的过程,往期相关博客:
学C的第三十四天【程序环境和预处理】_高高的胖子的博客-CSDN博客
                        

简单解释编译链接过程:

假设我们现在有三个文件

Func.h                Func.cpp                Test,cpp

函数声明)        (函数实现)        (主函数调用

执行主函数时需要进行以下过程

预处理  =>  编译  =>  汇编  =>  链接

现有文件和其内容:

                     

预处理:
  • 预处理过程操作包括:头文件展开(主要)  /  ​​​宏替换  /  条件编译  /​  去除注释​​​

Fun.cpp文件Test.cpp文件 中,因为都包含了 Func.h头文件

所以在预处理时对头文件进行展开,之后会生成预处理文件Func.i文件 和 Test.i文件

所以在 Func.i文件 中就会有Func函数的声明和实现Func.i函数声明和定义),

Test.i文件会有被调用的函数的声明和调用Test.i函数的声明和实际调用

                           

编译:
  • 编译过程操作包括:检查语法是否错误 / 生成汇编代码

进行编译时生成汇编代码文件.s文件),

Func.s文件Test.s文件分别由 Func.i文件 Test.i文件 生成),

Func.s文件存放了两个重载函数对应的汇编代码

Test.s文件 中则存放了主函数main函数的汇编代码

包括被调用的两个重载函数的汇编代码

要调用这两个重载函数,还需要用到汇编语言中的 call指令获取函数的地址

但在编译阶段,因为 Test.i文件 中只包含了 Func.h头文件只有函数声明没有函数实现

所以 call指令无法获得对应的函数地址

在这种情况下,编译器判断调用的函数和头文件中函数是否匹配,如果匹配的话

即使 call指令 还没找到函数地址也可以先让其通过编译方便实现多文件项目

                  

汇编:
  • 汇编过程操作包括:将汇编代码文件中的代码转换为二进制的机器码
    二级制的机器码CPU能读懂的代码

汇编后生成目标文件.o文件),
 Func.o文件 Test,o文件分别由 Func.s文件Test.s文件 生成),

两个文件都将汇编代码转换成了对应的二进制机器码

                 

链接: 
  • 链接过程操作包括:将目标文件链接合并到一起链接一些没有确定函数地址等等

汇编操作中Func.o文件 Test.o文件 合并为 a.out文件默认情况下),

合并后的 a,out文件 中:

之前在编译过程call指令未找到的函数地址可以在合并后的 a.out文件 中找到
(因为合并前 Func.o文件包含对应函数的实现

                          

                          
---------------------------------------------------------------------------------------------

                       

C++支持重载函数,而C语言不支持的原因:

通过上面对编译链接过程的简单了解,我们可以知道:

编译过程中 call指令 还未找到被调用函数的地址,直到链接过程合并文件后才能够找到

                   

C语言不支持重载函数的原因:

C语言中没有重载函数,即函数名唯一的情况下

找函数地址只需要通过唯一的函数名即可找到
即在链接过程中通过唯一的函数名 Func.o目标文件 中的符号表进行对地址的查找

所以如果C语言中有重载函数函数名不唯一的情况下无法在链接过程中找到函数地址

因此C语言无法支持重载函数

                      

C++支持重载函数的原因 -- 名字修饰(name Mangling):

不同编译器实现方式不同,这里Linux中的g++为例

C++中有重载函数的情况下,即函数名不唯一的情况下

C++有一个函数,可以通过函数名参数情况修饰出一个新的函数名字

函数名相同参数情况不同,就能修饰出不同的函数名字

通过修饰出的函数名字查找对应的函数地址

  • 修饰名字构成方式
    _Z  函数名字符个数  +  函数名  +  各参数首字母
    假设有一个函数:Func(int a, double b)修饰后的函数名字为:_Z4Funcid
    假设有另一个函数:Func(double b, int a) 修饰后的函数名字为:_Z4Funcdi
    所以即使函数名相同也可以通过参数情况来创建出不同的函数名字

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

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

相关文章

pytest全局变量的使用

这里重新阐述下PageObject设计模式&#xff1a; PageObject设计模式是selenium自动化最成熟&#xff0c;最受欢迎的一种模式&#xff0c;这里用pytest同样适用 这里直接提供代码&#xff1a; 全局变量 conftest.py """ conftest.py 全局变量&#xff0c;主要实…

探索ChatGPT在学术写作中的应用与心得

随着人工智能的迅猛发展&#xff0c;ChatGPT作为一种强大的自然语言处理模型&#xff0c;逐渐在学术界引起了广泛的关注。本文将探讨ChatGPT在学术写作中的应用&#xff0c;并分享使用ChatGPT进行学术写作时的一些经验和心得。 01 — ChatGPT在学术写作中的应用 1.文献综述和…

高速串行总线——SATA

SATA简介 SATA的全称是Serial Advanced Technology Attachment(串行高级技术附件&#xff0c;一种基于行业标准的串行硬件驱动器接口)&#xff0c;它是一种电脑总线&#xff0c;主要功能是用作主板和大量存储设备&#xff08;如硬盘及光盘驱动器&#xff09;之间的数据传输 SA…

挑战100天 AI In LeetCode Day04(热题+面试经典150题)

挑战100天 AI In LeetCode Day04&#xff08;热题面试经典150题&#xff09; 一、LeetCode介绍二、LeetCode 热题 HOT 100-62.1 题目2.2 题解 三、面试经典 150 题-63.1 题目3.2 题解 一、LeetCode介绍 LeetCode是一个在线编程网站&#xff0c;提供各种算法和数据结构的题目&am…

Flink SQL Window TopN 详解

Window TopN 定义&#xff08;⽀持 Streaming&#xff09;&#xff1a; Window TopN 是特殊的 TopN&#xff0c;返回结果是每⼀个窗⼝内的 N 个最⼩值或者最⼤值。 应⽤场景&#xff1a; TopN 会出现中间结果&#xff0c;出现回撤数据&#xff0c;Window TopN 不会出现回撤数据…

蓝桥杯每日一题2023.11.5

题目描述 方格分割 - 蓝桥云课 (lanqiao.cn) 题目分析 对于每个图我们可以从中间开始搜索&#xff0c;如果到达边界点就说明找到了一种对称的方法&#xff0c;我们可以直接对此进行答案记录每次进行回溯就会找到不同的图像&#xff0c;如果是一样的图像则算一种情况&#xff…

[Kettle] Excel输入

Excel文件采用表格的形式&#xff0c;数据显示直观&#xff0c;操作方便 Excel文件采用工作表存储数据&#xff0c;一个文件有多张不同名称的工作表&#xff0c;分别存放相同字段或不同字段的数据 数据源 物理成绩(Kettle数据集2).xls https://download.csdn.net/download/H…

AI智能公文写作助手“文山会海“

公文写作痛点 没思路&#xff0c;公文写作无从下手公文类型繁多&#xff0c;一时难以全面掌握公文内容组织难度大&#xff0c;不易清晰、有逻辑的进行表达时间紧任务急&#xff0c;往往需要在有限的时间内完成大量写作工作反复修改优化&#xff0c;需满足更多新要求&#xff0…

Linux学习之vim跳转到特定行数

参考的博客&#xff1a;《Vim跳到最后一行的方法》 《oeasy教您玩转vim - 14 - # 行头行尾》 《Linux&#xff1a;vim 中跳到首行和最后一行》 想要跳到特定行的话&#xff0c;可以在命令模式和正常模式进行跳转。要是对于vim的四种模式不太熟的话&#xff0c;可以到博客《Linu…

使用VSCODE链接Anaconda

打代码还是在VSCODE里得劲 所以得想个办法在VSCODE里运行py文件 一开始在插件商店寻找插件 但是没有发现什么有效果的 幸运的是VSCODE支持自己选择Python的解释器 打开VSCODE 按住CtrlShiftP 输入Select Interpreter 如果电脑已经安装上了Python的环境 VSCODE会默认选择普通…

Redis中的渐进式遍历-Scan命令

之前我们学习过遍历命令keys,而keys *是一次性的把整个redis中所有的key都获取到.在不知道当前redis中有多少key的情况下,这个操作是非常危险的,可能会一下子得到太多的key而阻塞redis服务器.从而使其他redis客户端卡顿. 通过渐进式遍历,就可以做到,既可以获取到所有的key,同时…

视频集中存储EasyCVR平台播放一段时间后出现黑屏是什么原因?该如何解决?

安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快&#xff0c;可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等&#xff0c;以及支持厂家私有协议与SDK接入&#xff0c;包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安…

零代码编程:用ChatGPT批量提取flash动画swf文件中的mp3

文件夹&#xff1a;C:\迅雷下载\有声绘本_flash[淘宝-珍奥下载]\有声绘本 flash&#xff0c;里面有多个flash文件&#xff0c;怎么转换成mp3文件呢? 可以使用swfextract工具从Flash动画中提取音频&#xff0c;下载地址是http://www.swftools.org/download.html&#xff0c;也…

Python学习-shutil模块和OS模块学习

shutil模块 针对文件的拷贝&#xff0c;删除&#xff0c;移动&#xff0c;压缩和解压操作 # 1.copyfileobj只能复制文件内容&#xff0c;无法复制权限#复制文件时&#xff0c;要选择自己有权限的目录执行操作&#xff0c;创建的文件会根据系统umask设定的参数来指定用户权限 s…

理解交叉熵(Cross Entropy)

交叉熵&#xff08;Cross-Entropy&#xff09;是一种用于衡量两个概率分布之间的距离或相似性的度量方法。在机器学习中&#xff0c;交叉熵通常用于损失函数&#xff0c;用于评估模型的预测结果与实际标签之间的差异。 在分类问题中&#xff0c;交叉熵损失函数通常用于多分类问…

项目构建工具maven的基本配置+idea 中配置 maven

&#x1f451; 博主简介&#xff1a;知名开发工程师 &#x1f463; 出没地点&#xff1a;北京 &#x1f48a; 2023年目标&#xff1a;成为一个大佬 ——————————————————————————————————————————— 版权声明&#xff1a;本文为原创文…

数据结构与算法—双链表

前言 前面有很详细的讲过线性表(顺序表和链表)&#xff0c;当时讲的链表以单链表为主&#xff0c;但在实际应用中双链表有很多应用场景&#xff0c;例如大家熟知的LinkedList。 双链表与单链表区别 单链表和双链表都是线性表的链式实现&#xff0c;它们的主要区别在于节点结构…

一文掌握 Apache SkyWalking

Apache SkyWalking SkyWalking是一个开源可观测平台&#xff0c;用于收集、分析、聚合和可视化来自服务和云原生基础设施的数据。SkyWalking 提供了一种简单的方法来保持分布式系统的清晰视图&#xff0c;甚至跨云。它是一种现代APM&#xff0c;专为云原生、基于容器的分布式系…

【图像分类】【深度学习】【Pytorch版本】AlexNet模型算法详解

【图像分类】【深度学习】【Pytorch版本】AlexNet模型算法详解 文章目录 【图像分类】【深度学习】【Pytorch版本】AlexNet模型算法详解前言AlexNet讲解卷积层的作用卷积过程特征图的大小计算公式Dropout的作用AlexNet模型结构 AlexNet Pytorch代码完整代码总结 前言 AlexNet是…

【网络协议】

网络协议 1 网络通讯1.1 防火墙1.2 子网掩码1.3 网关1.4 2 SSH2.1 SSH2.2 SSH12.3 SSH2 3 Telnet4 Telnet/SSL5 NFS6 TFTP7 FTP8 SFTP9 HTTP10 HTTPS11 NAT12 加密 1 网络通讯 1.1 防火墙 所谓“防火墙”&#xff0c;是指一种将内部网和公众访问网(如Internet)分开的方法&…