• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
Moria
   首页    新随笔    联系   管理    订阅  订阅
C 语言学习 2

 

循环辅助语句

2-1 break 语句

跳出当前循环体。

程序在中途跳出循环。执行 break 语句程序会直接跳出循环。

例子:如下代码判断一个数是不是素数。

#include<stdio.h>
int main() {
    long long i, num;
    _Bool flag = 1;
    printf("请输入一个整数:");
    scanf_s("%lld", &num);
    for (i = 2; i < num / 2; i++) {
        if (num % i == 0) {
            flag = 0;
        }
    }
    if (flag) {
        printf("%lld是一个素数!\n", num);
    }
    else {
        printf("%lld不是一个素数!\n", num);
    }
    return 0;
}

当 num 是 100000 时,循环体要从 2 到 50000。但是很明显 100000 已经可以被 2 整除,之后的循环没必要执行。

所以在程序代码中添加 break 语句可以提高程序的执行效率。在 flag = 0; 下一行添加 break; 跳出for循环。

2-2 continue 语句

跳过本循环体中剩余的语句而执行下一次循环。

2-3 scanf 和 scanf_s

在 Visual Studio 使用 scanf 会出现以下报错:

错误 C4996 'scanf': This function or variable may be unsafe. Consider using scanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details. 

这个函数或变量可能是不安全的。考虑使用 scanf_s 。

解决方法可以添加 #define _CRT_SECURE_NO_WARNINGS,可以继续使用 scanf,不过推荐 scanf_s 。

#define _CRT_SECURE_NO_WARNINGS //最开头添加
#include<stdio.h>
int main() {
    long long i, num;
    _Bool flag = 1;
    printf("请输入一个整数:");
    scanf("%lld", &num);
    for (i = 2; i < num / 2; i++) {
        if (num % i == 0) {
            flag = 0;
        }
    }
    if (flag) {
        printf("%lld是一个素数!\n", num);
    }
    else {
        printf("%lld不是一个素数!\n", num);
    }
    return 0;
}

scanf() 函数是标准 C 中提供的标准输入函数,用以用户输入数据。

scanf_s() 函数是 Microsoft 公司 VS 开发工具提供的一个功能相同的安全标准输入函数,从 VC++ 2005 开始,VS 提供了 scanf_s() 。在调用该函数时,提供一个数字以表明最多读取多少位字符。

原因和区别:

scanf() 在读取数据时不检查边界,所以可能会造成内存访问越界:

//例如:分配了 5 字节的空间但是用户输入了 10 字节,就会导致 scanf() 读到 10 个字节
char buf[5]={'\0'};
scanf("%s", buf);
//如果输入 1234567890,则 5 以后的部分会被写到别的变量所在的空间上去,从而可能会导致程序运行异常。

以上代码如果用 scanf_s() 则可避免此问题:

char buf[5]={'\0'};
scanf_s("%s",buf,5); //最多读取 4 个输入的字符,因为 buf[4] 要放 '\0' 
//如果输入 1234567890,则 buf 只会接受前 4 个字符

scanf_s 最后一个参数 n 是接收缓冲区的大小(即上 buf 的容量),表示最多读取 n-1 个输入的字符。

很多带“_s”后缀的函数是为了让原版函数更安全,传入一个和参数有关的大小值,避免引用到不存在的元素,防止黑客利用原版的不安全性(漏洞)黑掉系统。

详见 docs 文档:https://docs.microsoft.com/zh-cn/cpp/c-runtime-library/reference/scanf-s-scanf-s-l-wscanf-s-wscanf-s-l?view=vs-2019

posted on 2020-04-16 11:50  正版Moriafly  阅读(203)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3