垃圾字符回收

本文详细讨论了C语言中getchar和scanf函数对输入字符的处理,特别是如何影响缓冲区,以及在多输入输出或循环中处理垃圾字符的重要性。作者提醒在编程时注意垃圾字符的回收以避免潜在问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<stdio.h>

int main()
{
    int a,b;
   a=getchar();
    printf("%d",a);
   getchar();            //回收回车
   scanf("%c",&b);
      printf("%d",b);
    return 0;
}

运行结果

a                  //输入a值
970             //输出a值,输入b值(0)
48               //输出b值
[Process completed - press Enter]

下面这个为缺失垃圾回收的该代码段及其运行结果

#include<stdio.h>

int main()
{
    int a,b;
   a=getchar();
    printf("%d",a);
   scanf("%c",&b);
      printf("%d",b);
    return 0;
}

运行结果

a                       //输入a值
9710                //输出a值,此处的回车就是垃圾字符,无法给变量b赋值
[Process completed - press Enter]

 以上为getchar函数输入案例,下面这个是scanf函数输入案例

#include<stdio.h>

int main()
{
    char a,b;
   scanf("%c",&a);
    printf("%d",a);
   getchar();                      //回收回车
   scanf("%c",&b);
      printf("%d",b);
    return 0;
}

运行结果

a                     //输入a值
970                 //输出a值,输入b值
48                  //输出b值
[Process completed - press Enter]

上面是有字符垃圾回收的情况,下面是没有垃圾字符回收的情况

#include<stdio.h>

int main()
{
    char a,b;
   scanf("%c",&a);
    printf("%d",a);
   scanf("%c",&b);
      printf("%d",b);
    return 0;
}

运行结果

a                            //输入a值
9710                      //输出a值,此处未给b赋值,回车(缓冲区内的垃圾字符)填入b,并输出
[Process completed - press Enter]

下面是垃圾字符在循坏语句里的情况

#include <stdio.h>
int main(int argc, char const *argv[])
{while(1)
  { char a;
    char b;
    scanf("%c",&a);
     getchar();                                 //回收回车(垃圾字符)
    printf("%c",a);
  }
    return 0;
}

​​​​​​​​​​​​​​总结:

C语言采用缓冲区的机理。输入的字符(包括回车)都会先存入缓冲区,scanf()、getchar()函数,实际上是读取缓冲区内容的命令,如果缓冲区中有内容,就直接读取缓冲区中的内容,只有当缓冲区中没有任何内容,才会要求键盘输入。

个人体会:

当我们有多个顺序输入输出或循环输入输出时,一定不要忘记垃圾字符的存在。关于垃圾字符的回收方法在我的c语言笔记day1里给出了其他方法,大家如果需要,可以去看看。

### C语言中的垃圾字符回收方法与解决方案 C语言本身并不具备内置的垃圾回收机制,这意味着内存管理完全依赖于程序员的手动操作。然而,“垃圾字符”的概念通常指的是不再使用的动态分配内存或未初始化变量所遗留下来的无意义数据。为了有效管理和释放这些资源,可以采取以下几种策略和技术。 #### 动态内存管理 在C语言中,动态内存分配主要依靠`malloc()`、`calloc()`以及`realloc()`等函数实现,而相应的释放则需调用`free()`。如果未能正确地释放已分配但不再使用的内存块,就会形成所谓的“内存泄漏”。虽然严格意义上讲这不是传统意义上的“垃圾回收”,但是良好的实践能够帮助减少这类问题的发生频率及其影响程度。 ##### 自定义封装函数 创建一些辅助性的宏定义或者小型工具类库可以帮助简化复杂的指针运算过程,并且统一管理不同类型的对象实例生命周期。例如: ```c #define SAFE_FREE(ptr) {if (ptr != NULL){ free(ptr); ptr=NULL;}} ``` 这样可以在任何地方方便快捷地销毁某个特定指向地址的内容而不必担心重复调用带来的崩溃风险[^1]。 #### 静态分析工具的应用 除了编写严谨规范化的源代码之外,还可以借助第三方静态检测软件扫描项目工程内部可能存在隐患的地方。像Valgrind这样的开源平台就非常适合用来诊断Linux环境下编写的C/C++应用程序是否存在越界访问数组元素、悬空指针引用等问题。它不仅可以发现常规测试难以察觉的小概率事件,还能统计总体消耗了多少字节大小的空间从而评估整体性能表现如何优化进一步提升效率[^2]。 #### 参考Java GC理念设计轻量化框架 尽管原生C并未支持自动化的GC功能模块,但我们仍然可以从高级别的编程范式里汲取灵感构建类似的简易版结构体来模拟相似效果。比如引入引用计数器的概念跟踪每个节点当前关联次数;每当新增连接关系时增加对应值反之减少直至降为零即刻触发清理流程。这种方法特别适合那些树形拓扑图状的数据集合场景下运用因为它们天然具有明确父子级层次关系便于维护更新状态信息记录表单以便查询检索所需资料更加高效便捷[^3]. 此外还有一种叫做"标记-清扫"(Mark-and-Sweep)的技术思路也可以移植过来应用于解决大规模复杂网络环境当中产生的孤立片段现象。其核心原理在于遍历可达域范围内的全部实体单元逐一打上活动标志位随后再逐一遍历整个存储池剔除掉所有缺少相应标识的部分最终达到整理整顿的目的同时兼顾保留有用成分不受干扰破坏保持原有特性不变样貌依旧如初[^4]. --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值