简记getchar()和EOF

     刚开始学C,在《C和指针》上经常看到如下关于getchar()EOF的语句,所以在百度文库搜到一份文档,稍作整理作为自己的学习笔记。

            printf("Input your data:\n");

            char ch;

            while((ch=getchar())!=EOF)

            {

                putchar(ch);

            }

  1getchar()通常返回为字符,但基本是以返回负值来结束输入,如EOF;

       getchar()通常返回字符,这些字符的ASCII值都是非负的,所以上面的代码就可能会出现问题。ch的类型是char,所以getchar()不能返回EOF(在某些函数库中定义为-1)ch。因此正确的写法应该是:

       int ch;

       ch=getchar();

       如果类型是ch,就有两种结果:

       1)某些合法的输入字符在被“截断”后使得ch取值与EOF相同,程序将在文件复制的工程中中断;

       2ch根本娶不到EOF这个值,程序陷入死循环;

  2getchar()以行为单位进行存取;

       输入hello world 然后回车,程序就会执行putchar(ch),hello world和一个回车输出。然后光标会自动换行等待下次输入,直到遇到换行符,系统将之前的输入输出到终端。那么getchar()怎么才能停止等待输入呢?

       我们用getchar()在控制台取字符的时候,它首先要把所有取得的东西按照顺序放在内存的某个临时的地方,但我们输入回车时塔就会把之前的输入按顺序取出,当取到回车时就是上次输入的结束。在程序中不论我们调用多少次getchar(),它都会放在一个地方,并且不断增加。只有取到换行符才表示这个地方空了,下次getchar()时控制台才会停顿等待输入。

       经验证,只能在getchar()提示新一次输入时,输入Ctrl+Z(Windows下的EOF)加上回车才能结束输入。

    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 等保2.0标准中对技术安全要求主要包括信息安全类要求(简记为x)、服务保证类要求(简记为s)、其他安全保护类要求(简记为g)和数据设备类要求(简记为f)。 a. 信息安全类要求(x)是等保2.0标准中的一项重要要求,它涉及了信息系统的安全保护、安全管理和信息安全技术的实施要求,包括身份认证、访问控制、审计、加密等内容。 b. 服务保证类要求(s)也是等保2.0标准中的一项重要要求,它主要围绕着信息系统的可用性、可靠性和稳定性进行要求,包括灾备备份、容灾恢复、业务连续性等内容。 c. 其他安全保护类要求(g)是等保2.0标准中的一项综合要求,主要涉及到对软硬件安全配置、网络安全和物理环境安全等方面的要求,包括网络隔离、漏洞修复、环境监控等内容。 d. 数据设备类要求(f)是等保2.0标准中专门对数据安全进行要求的一项内容,它主要包括数据备份、数据恢复、数据存储、数据传输等方面的安全要求。 综上所述,a、b、c、d选项所描述的等保2.0标准中对技术安全要求的分工是正确的。 ### 回答2: 等保2.0标准中对技术安全要求主要包含了信息安全类要求、服务保证类要求、其他安全保护类要求和数据设备类要求。 a. 信息安全类要求指的是对信息系统的各种组成部分、信息传输和处理过程以及相关的信息安全协议、算法等进行安全要求和控制。这是等保2.0标准中非常重要的一部分。 b. 服务保证类要求主要涉及系统的可用性、可靠性、灾备能力、响应能力等方面的要求。这些要求旨在确保信息系统随时可用,并且能够及时处理异常情况。 c. 其他安全保护类要求主要包括物理环境安全、人员安全、网络安全、应用软件安全等方面的要求。这些要求涉及到信息系统运行环境的各个方面和安全管理控制的要求。 d. 数据设备类要求主要涉及到数据的存储、传输、备份、还原等方面的要求。这些要求着重保护重要数据的安全性和完整性。 所以以上说法都正确,它们都是等保2.0标准中对技术安全方面的要求的不同分类。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值