2024年最全【维生素C语言】第二章 - 分支和循环_default后面有分号吗,互联网公司面试流程&面试技巧

一、网安学习成长路线图

网安所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

二、网安视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
在这里插入图片描述

三、精品网安学习书籍

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
在这里插入图片描述

四、网络安全源码合集+工具包

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
在这里插入图片描述

五、网络安全面试题

最后就是大家最关心的网络安全面试题板块
在这里插入图片描述在这里插入图片描述

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

🔑 解析:因为n=1,所以进入switch后执行case1的语句m++,此时m=3,由于该语句项末尾没有break,继续向下流到case2的语句n++,此时n=2,又没有break,流向case3,case3中又嵌了一个switch(n),此时因n=2,执行内部switch的case2的语句m++和n++,此时m=4,n=3,后面有break,跳出内部switch,但是外部switch的case3后面依然没有break,所以流向case4,m++,此时m=5,后面终于有break了。运行下来后的结果为 m=5,n=3。

三、循环语句

0x00 while 循环

📚 定义:当满足条件时进入循环,进入循环后,当条件不满足时,跳出循环。

📌 注意事项:while 循环条件将会比循环体多执行一次。

while 循环中,当条件表达式成立时,才会执行循环体中语句,每次执行期间,都会对循环因子进行修改(否则就成为死循环),修改完成后如果 while 条件表达式成立,继续循环,如果不成立,循环结束。

💬 while死循环:表达式结果如果为非0,为真,循环就执行

int main(void) {
    while(1)
        printf("hehe\n");

    return 0;
}

🚩 运行结果如下:

💬 while 循环打印 1~10 的数字:

int main(void) {
    int i = 1;
    while(i<=10) {
        printf("%d ", i);
        i++;
    }

    return 0;
}

🚩 运行结果: 1 2 3 4 5 6 7 8 9 10

0x01 break 语句

📚 break 语句在 while 循环中的效果:

在 while 循环中,break 用于永久地终止循环。

int main(void) {
    int i = 1;
    while(i <= 10) {
        if(5 == i) // i=5时停止循环;
            break;

        printf("%d ", i);
        i++;
    }

    return 0;
}

🚩  运行结果:1 2 3 4

0x02 continue 语句

📚 continue 语句:

int main()
{
    int i = 1;
    while(i<=10) {
        if(i==5) {
            continue;  // 跳至判断部分;
        } 
        printf("%d ", i);
        i++;
    }
    
    return 0;
}

🚩 运行结果: 1 2 3 4(程序会一直判断)

0x03 getchar 和 putchar

📚 getchar:

从流(stream)或键盘上,读取一个字符。

返回值:如果正确,返回ASCII值;如果读取错误吗,返回 EOF(文件结束标志)。

📚 putchar:单纯的输出一个字符。

💬 getchar 使用方法演示: “输入什么就返回什么”

int main(void) {
    int ch = getchar();
    putchar(ch); // 输出一个字符;

    return 0;
}

🚩 运行结果:(假设输入a)  a

💬 getchar 与 while 的结合: “一直从键盘上读取字符的程序”

int main(void) {
    int ch = 0;
    // ctrl+z - getchar 就读取结束;
    while ( (ch = getchar()) != EOF ) {
        putchar(ch);
    }

    return 0;
}

❓ 如果想停止输入,怎么办?

💡 解决方法: 输入 ctrl + z 可以使 getchar 结束读取。

💬 getchar 只打印数字:

int main(void) {
    int ch = 0;
    while( (ch=getchar()) != EOF ) {
        if(ch<'0' || ch>'9') {
            continue; // 发现不是数字,跳回判断部分,重新getchar;
        }
        putchar(ch);
    }

    return 0;
}

💬 清理缓冲区:用户输入密码后,让用户确认(Y/N)

int main(void) {
    char password[20] = {0};
    printf("请输入密码:>");
    scanf("%s", password);
    printf("请确认密码(Y/N) :>");
    int ch = getchar();
    if(ch == 'Y') {
        printf("确认成功\n");
    } else {
        printf("确认失败\n");
    }

    return 0; 
}

🚩 运行结果:(假设用户输入了123456;Y)确认失败

❓  为什么还没有让用户确认(Y/N)就显示确认失败了?

🔑 解析:输入函数并不是从键盘上读取,而是从缓冲区中读取内容的;键盘输入123456时敲下回车键,此时为 “123456\n”,这时scanf将123456取走,getchar读取到的就是“\n”了,因为“\n”不是Y,执行了else的结果,所以显示确认失败。

💡 解决方案:在 scanf 后加上一个“读取 \n ”的 getchar()

int main(void) {
    char password[20] = {0};
    printf("请输入密码:>");
    scanf("%s", password);
    printf("请确认密码(Y/N) :>");
    // 清刷缓冲区;
    getchar()
    
    int ch = getchar();
    if(ch == 'Y') {
        printf("确认成功\n");
    } else {
        printf("确认失败\n");
    }

    return 0; 
}

🚩 (假设用户输入了123456;Y)确认成功

🚩 (假设用户输入了123 456;Y)确认失败

❓“用户输入了空格,确认Y,为什么显示确认失败?”

🔑 解析:刚才加入的一个getchar()处理掉了空格,导致后面“\n”没人管了;

💡 解决方案:加入循环

int main(void) {
    char password[20] = {0};
    printf("请输入密码:>");
    scanf("%s", password);
    printf("请确认密码(Y/N) :>");
    // 清理缓冲区的多个字符;
    int tmp = 0;
    while( (tmp = getchar()) != '\n' ) {
        ;
    }

    int ch = getchar();
    if(ch == 'Y') {
        printf("确认成功\n");
    } else {
        printf("确认失败\n");
    }

    return 0; 
}

🚩 (假设用户输入了123 456;Y)确认成功

0x04 for 循环

📚 定义:

① 表达式1:初始化部分,用于初始化循环变量。

② 表达式2:条件判断部分,用于判断循环终止。

③ 表达式3:调整部分,用于循环条件的调整。

📌 注意事项:

① 为了防止for循环失去控制,禁止在for循环体内修改循环变量。

② for循环内的表达式可以省略,但是得注意。

📜 建议:

① 建议使用“左闭区间,右开区间”的写法:

for( i=0; i<10; i++ ) 左闭,右开区间 ✅

for( i=0; i<=9; i++ ) 左右都是闭区间 ❎

② 不要在for循环体内修改循环变量,防止for循环失去控制。

💬 for 的使用方法演示

① 利用 while 循环打印1~10数字:

int main(void) {
    int i = 1; // 初始化
    while(i<=10) { //判断部分
        printf("%d ", i);
        i++; // 调整部分
    }
    return 0;
} 

🚩 运行结果:1 2 3 4 5 6 7 8 9 10

② 利用 for 循环打印1~10数字:

int main(void) {
    int i = 0;
    for(i=1; i<=10; i++) {
        printf("%d ", i);
    }
    return 0;
}

🚩 运行结果:1 2 3 4 5 6 7 8 9 10

💬 break 语句在 for 循环中的效果:

int main(void) {
    int i = 0;
    for(i=1; i<=10; i++) {
        if(i==5) {    // 当i==5时;
            break;    // 直接跳出循环;
        }
        printf("%d ", i);
    }
}

🚩 运行结果:1 2 3 4

❓  什么没有打印5?

🔑 解析:因为当 i==5 时,break 跳出了循环,循环中 break 之后的语句全都不再执行,printf 位于 break 之后,所以5自然不会被打印出来;

💬 continue 在 for 循环中的效果

if 中的 continue 会陷入死循环,但是在 for 中并不会:

int main(void) {
    int i = 0;
    for(i=1; i<=10; i++) {
        if(i == 5)
            continue; // 跳至调整部分(i++);
        printf("%d ", i);
    }
}

🚩 运行结果:1 2 3 4 6 7 8 9 10

❓  这里为什么又没打印 5?

🔑 解析:因为当 i==5 时,continue 跳至调整部分,此时 i++,i 为6。同上,所以5自然不会被打印。i 为6时,if 不成立,继续打印,最终结果为 1 2 3 4 6 7 8 9 10(跳过了5的打印);

💬 for 循环体内修改循环变量的后果:

int main(void) {
    int i = 0;
    for (i=0; i<10; i++) {
        if (i = 5) {
            printf("haha\n");
        }
        printf("hehe\n");
    }

    return 0;
}

🚩   hehehahahehehaha…… 💀死循环

0x05 for 循环的嵌套

📚 定义:

① for 循环是允许嵌套的;

② 外部的 for 循环称为外部循环,内部的 for 循环称为内部循环;

💬 for 嵌套的演示:

int main(void) {
    int i = 0;
    int j = 0;

    for (i=0; i<10; i++) {
        for (j=0; j<10; j++) {
            printf("hehe\n");
        }
    }
    // 10x10 == 100
    return 0;
}

🚩 (打印了100个hehe)

0x06 for 循环的省略

📚 for 循环的省略:

① for 循环的 “初始化、判断部分、调整部分” 都可以省略。

② 判断部分的省略 - 判断部分恒为真 - 死循环 💀。

③ 如果不是非常熟练,建议不要省略。

💬 判断部分的省略:

int main(void) {
    // 判断部分恒为真 - 死循环
    for(;;) {
        printf("hehe\n");
    }

    return 0;
}

🚩 hehehehehehe…… 💀死循环

💬 省略带来的弊端

假设我们希望下列代码能打印 9 个呵呵:

int main(void) {
    int i = 0;
    int j = 0;
    for(; i<3; i++) {
        for(; j<3; j++) {
            printf("hehe\n");
        }
    }

    return 0;
}

🚩  运行结果:hehe hehe hehe (只打印了3个)

🔑 解析:因为 i=0,内部 for 打印了3次 hehe,此时 j=3,这时 i++,j因为没有初始化,所以此时 j仍然是3,而判断部分要求 j<3,自然就不再打印了,程序结束。

❓ 请问要循环多少次?

int main(void) {
    int i = 0;
    int k = 0;
    int count = 0;
    for(i=0,k=0; k=0; i++,k++) {
        k++;
        count++;
    }
    printf("count:%d", count);
    
    return 0;
}

💡 答案:count = 0,一共循环0次。

🔑 解析:判断部分 k=0,赋值为 0 时为假,所以一次都不会循环。

0x07 do…while 循环

📚 定义:在检查 while() 条件是否为真之前,该循环首先会执行一次 do{} 之内的语句,然后在 while() 内检查条件是否为真,如果条件为真,就会重复 do…while 这个循环,直至 while() 为假。

📌 注意事项:

① do…while 循环的特点:循环体至少执行一次。

② do…while 的使用场景有限,所以不是经常使用。

③ 简单地说就是:不管条件成立与否,先执行一次循环,再判断条件是否正确。

💬 do…while 使用方法演示:

int main(void) {
    int i = 1;
    do {
        printf("%d ", i);
        i++;
    } while(i<=10);
    
    return 0;
}

🚩 运行结果: 1 2 3 4 5 6 7 8 9 10

💬 break 语句在 do…while 循环中的效果:

int main(void) {
    int i = 1;
    do {
        if(i==5) {
            break;
        }
        printf("%d ", i);
        i++;
    } while(i<10);
    
    return 0;
}

🚩 运行结果:1 2 3 4

💬 continue 语句在 do…while 循环中的效果:

int main(void) {
    int i = 1;
    do {   
        if(i == 5)
            continue;
        printf("%d ", i);
        i++;
    }
    while(i<=10);
    
    return 0;
}
0x08 goto 语句

📚 C语言中提供了可以随意滥用的 goto 语句和标记跳转的标号。最常见的用法就是终止程序在某些深度嵌套的结构的处理过程。

“ goto 语句存在着争议”

  1. goto 语句确实有害,应当尽量避免。

  2. 理论上讲goto语句是没有必要的,实践中没有goto语句也可以很容易的写出代码。

  3. 完全避免使用 goto 语句也并非是个明智的方法,有些地方使用 goto 语句,会使程序流程 更清楚、效率更高。

📌 注意事项:goto 语句只能在一个函数内跳转。

💬 可以考虑使用 goto 的情形:

for(...) {
    for(...) {
        for(...) {
            // HOW TO ESCAPE?
        }
    }
}

💬 体会 goto 语句的特点:

int main(void) {
flag:
    printf("hehe\n");
    printf("haha\n");
    goto flag;



### 如何自学黑客&网络安全


#### 黑客零基础入门学习路线&规划


**初级黑客**  
 **1、网络安全理论知识(2天)**  
 ①了解行业相关背景,前景,确定发展方向。  
 ②学习网络安全相关法律法规。  
 ③网络安全运营的概念。  
 ④等保简介、等保规定、流程和规范。(非常重要)


**2、渗透测试基础(一周)**  
 ①渗透测试的流程、分类、标准  
 ②信息收集技术:主动/被动信息搜集、Nmap工具、Google Hacking  
 ③漏洞扫描、漏洞利用、原理,利用方法、工具(MSF)、绕过IDS和反病毒侦察  
 ④主机攻防演练:MS17-010、MS08-067、MS10-046、MS12-20等


**3、操作系统基础(一周)**  
 ①Windows系统常见功能和命令  
 ②Kali Linux系统常见功能和命令  
 ③操作系统安全(系统入侵排查/系统加固基础)


**4、计算机网络基础(一周)**  
 ①计算机网络基础、协议和架构  
 ②网络通信原理、OSI模型、数据转发流程  
 ③常见协议解析(HTTP、TCP/IP、ARP等)  
 ④网络攻击技术与网络安全防御技术  
 ⑤Web漏洞原理与防御:主动/被动攻击、DDOS攻击、CVE漏洞复现


**5、数据库基础操作(2天)**  
 ①数据库基础  
 ②SQL语言基础  
 ③数据库安全加固


**6、Web渗透(1周)**  
 ①HTML、CSS和JavaScript简介  
 ②OWASP Top10  
 ③Web漏洞扫描工具  
 ④Web渗透工具:Nmap、BurpSuite、SQLMap、其他(菜刀、漏扫等)  
 恭喜你,如果学到这里,你基本可以从事一份网络安全相关的工作,比如渗透测试、Web 渗透、安全服务、安全分析等岗位;如果等保模块学的好,还可以从事等保工程师。薪资区间6k-15k


到此为止,大概1个月的时间。你已经成为了一名“脚本小子”。那么你还想往下探索吗?


如果你想要入坑黑客&网络安全,笔者给大家准备了一份:282G全网最全的网络安全资料包评论区留言即可领取!


**7、脚本编程(初级/中级/高级)**  
 在网络安全领域。是否具备编程能力是“脚本小子”和真正黑客的本质区别。在实际的渗透测试过程中,面对复杂多变的网络环境,当常用工具不能满足实际需求的时候,往往需要对现有工具进行扩展,或者编写符合我们要求的工具、自动化脚本,这个时候就需要具备一定的编程能力。在分秒必争的CTF竞赛中,想要高效地使用自制的脚本工具来实现各种目的,更是需要拥有编程能力.


如果你零基础入门,笔者建议选择脚本语言Python/PHP/Go/Java中的一种,对常用库进行编程学习;搭建开发环境和选择IDE,PHP环境推荐Wamp和XAMPP, IDE强烈推荐Sublime;·Python编程学习,学习内容包含:语法、正则、文件、 网络、多线程等常用库,推荐《Python核心编程》,不要看完;·用Python编写漏洞的exp,然后写一个简单的网络爬虫;·PHP基本语法学习并书写一个简单的博客系统;熟悉MVC架构,并试着学习一个PHP框架或者Python框架 (可选);·了解Bootstrap的布局或者CSS。

**8、超级黑客**  
 这部分内容对零基础的同学来说还比较遥远,就不展开细说了,附上学习路线。  
 ![img](https://img-blog.csdnimg.cn/img_convert/3fd39c2ba8ec22649979f245f4221608.webp?x-oss-process=image/format,png)


#### 网络安全工程师企业级学习路线


![img](https://img-blog.csdnimg.cn/img_convert/931ac5ac21a22d230645ccf767358997.webp?x-oss-process=image/format,png)  
 如图片过大被平台压缩导致看不清的话,评论区点赞和评论区留言获取吧。我都会回复的


视频配套资料&国内外网安书籍、文档&工具


当然除了有配套的视频,同时也为大家整理了各种文档和书籍资料&工具,并且已经帮大家分好类了。

![img](https://img-blog.csdnimg.cn/img_convert/153b2778a3fe5198265bed9635d63469.webp?x-oss-process=image/format,png)  
 一些笔者自己买的、其他平台白嫖不到的视频教程。  
 ![img](https://img-blog.csdnimg.cn/img_convert/32eb4b22aa740233c5198d3c161b37e8.webp?x-oss-process=image/format,png)



**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以点击这里获取](https://bbs.csdn.net/topics/618540462)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 15
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值