第七章 C控制语句:分支和跳转

  1. if else 用法

    1. if (expression) //expression为真时,运行花括号内语句
    2. {
    3. statement1
    4. }
    5. else //不为真时,运行else的花括号内语句
    6. {
    7. statement2
    8. }
  2. ctype.h系列的字符函数

    1. #include <stdio.h>
    2. #include <ctype.h> //包含isalpha()的函数原型
    3. int main ()
    4. {
    5. char ch;
    6. while ((ch = getchar()) != '\n')
    7. {
    8. if (isalpha (ch)) //检测输入输入字符是否为字母
    9. putchar(ch + 1);
    10. else
    11. putchar (ch);
    12. }
    13. putchar (ch);
    14. getchar();
    15. getchar();
    16. return 0;
    17. }

    运行程序,输入 Hello! 输出的就是 Ifmmp!

    ctype.h头文件中字符测试函数

函数名 如果是下列参数时,返回值为真
isalnum 字母数字(字母或数字)
isalpha 字母
isblank 标准的空白字符(空格、水平制表符或换行符)或任何其他本地化指定为空白的字符
iscntrl 控制字符,如Ctrl+B
isdigit 数字
isgraph 除空格外的任意可打印字符
islower 小写字母
isprint 可打印字符
ispunct 标点符号(除空格或字母数字字符外的任何可打印字符)
isspace 空白字符(空格、换行符、换页符、回车符、垂直制表符、水平制表符或其他本地化定义的字符)
isupper 大写字母
isxdigit 十六进制字符
  1. 逻辑运算符

    3种逻辑运算符

逻辑运算符 含义
&&
||
!
  1. 条件运算符:?:

    x = (y< 0) ? -y : y;

    如果y<0,则x = -y,否则x = y、

第八章 字符输入/输出和输入验证

  1. getchar()putchar()都是单字符I/O
    1. #include <stdio.h>
    2. int main()
    3. {
    4. char ch;
    5. while ((ch = getchar()) != '#')
    6. putchar(ch);
    7. getchar();
    8. return 0;
    9. }

输入Hello,I'm # here,程序读取到#就停止,后面的内容就不能读取。

getchar();的地方设置断点并验证

  1. 输入验证(防止使用者输错),提前做好预防

第九章 函数

  1. 简单函数
    1. #include <stdio.h>
    2. #define NAME "GIGATHING, INC"
    3. #define ADDRESS "101 Megabuck Plaza"
    4. #define PLACE "Megapolis, CA 94904"
    5. #define WIDTH 40
    6. void starbar(void);
    7. int main()
    8. {
    9. starbar();
    10. printf("%s\n", NAME);
    11. printf("%s\n", ADDRESS);
    12. printf("%s\n", PLACE);
    13. starbar();
    14. getchar();
    15. return 0;
    16. }
    17. void starbar(void) //第一个void 表示函数为void类型,没有返回值;第二个void表示函数不带参数(形参)
    18. {
    19. int count; //count为该函数内的局部变量,即可以在starbar函数外的地方再次定义同名变量
    20. for (count = 1; count <= WIDTH; count++)
    21. putchar('*');
    22. putchar('\n');
    23. }

输出结果:

starbar标识符出现三次,三个作用:函数原型告诉编译器函数的类型,函数调用表示在此处执行函数,函数定义定义了函数内语句的功能

  1. 函数递归

    1. #include <stdio.h>
    2. void up_and_down(int);
    3. int main(void)
    4. {
    5. up_and_down(1);
    6. getchar();
    7. return 0;
    8. }
    9. void up_and_down(int n)
    10. {
    11. printf("Level %d: n location %p\n", n, &n); // #1
    12. if (n < 4) up_and_down(n + 1);
    13. printf("LEVEL %d: n location %p\n", n, &n); // #2
    14. }

输出结果:

注:每次函数调用的n值都是不同的,且每次调用之后都会返回,执行后面的语句

大概就是这样子

第十章 数组和指针

  1. sizeof计算元素个数
    1. #include <stdio.h>
    2. int main(void)
    3. {
    4. const int days[] = { 31,28,31,30,31,30,30,31,30,31,30,31 };
    5. int index;
    6. for (index = 0; index < sizeof days / sizeof days[0]; ++index)
    7. printf("Month %d has %d days.\n", index + 1, days[index]);
    8. getchar();
    9. return 0;
    10. }

注:sizeof days是在计算整个数组的大小,sizeof day[0]是在计算一个int元素的大小

  1. 指针与数组(一维)

    1. #include <stdio.h>
    2. #define MONTH 12
    3. int main(void)
    4. {
    5. const int days[MONTH] = { 31,28,31,30,31,30,30,31,30,31,30,31 };
    6. int index;
    7. for (index = 0; index < MONTH; ++index)
    8. printf("Month %2d has %d days.\n", index + 1, *(days + index));
    9. getchar();
    10. return 0;
    11. }

*(days + index)相当于days[index]

  1. const的其他内容

    const int days[MONTH] = { 31,28,31,30,31,30,30,31,30,31,30,31 };

    起到保护数组内容的作用,更改days数组内的值会发生编译错误

    1. int days[MONTH] = { 31,28,31,30,31,30,30,31,30,31,30,31 };
    2. const int *ptr = days;

    这样的话就可以更改days数组的内容,但是ptr指针就是固定指向days数组

  2. 指针和多维数组

    1. #include <stdio.h>
    2. int main()
    3. {
    4. int a[4][2] = { {2,4},{6,8},{1,3},{5,7} };
    5. int (*ptr)[2] = a; //括号是必须的!
    6. int i, v;
    7. for (i = 0; i < 4; ++i)
    8. {
    9. for (v = 0; v < 2; ++v)
    10. {
    11. printf("%d\t", *(*(ptr + i) + v));
    12. }
    13. putchar('\n');
    14. }
    15. getchar();
    16. return 0;
    17. }

输出结果:

注:C语言中二维数组长这样:

不出意外的话,这应该是我对这本书的最后的笔记了,后面好多都是的看不懂的理论,也就没办法做出来笔记......

感兴趣的朋友可以自行买书回来看一下呀

《C Primer Plus》第六版笔记--7~10章的更多相关文章

  1. C++ Primer Plus 第六版笔记

    C++ Primer Plus 第六版笔记 关于对象声明的思考 转自:http://www.cnblogs.com/weiqubo/archive/2009/11/02/1930042.html C+ ...

  2. 《C Primer Plus》第六版笔记--4~6章

    目录 第四章 字符串和格式化输入/输出 第五章 运算符.表达式和语句 第六章 C控制语句:循环 虽然匆匆忙忙,但还是要做笔记,虽然大概都知道...... 挑一些容易忘记的地方 第四章 字符串和格式化输 ...

  3. 《C Primer Plus》第六版笔记--1~3章

    目录 第一章 初识C语言 1 使用C语言的7个步骤 1.1 定义程序目标 1.2 设计程序(功能实现) 1.3 编写代码 1.4 编译 1.5 运行程序 1.6 测试和调试程序 1.7 维护和修改代码 ...

  4. <NET CLR via c# 第4版>笔记 第10章 属性

    10.1 无参属性 10.1.1 自动实现的属性 10.1.2 合理定义属性 属性可以只读或只写,而字段访问总是可读和可写的(一个例外是 readonly 字段仅在构造器中可写). 属性方法可能抛出异 ...

  5. c++ primer plus 第6版 部分三 9章 - 章

    c++ primer plus 第6版                                               部分三 9章 - 章 第9章   内存模型和名称空间 1.单独编译 ...

  6. 《C++Primer》第五版习题答案--第一章【学习笔记】

    C++Primer第五版习题解答---第一章 ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2022/1/7 第一章:开始 练习1.3 #includ ...

  7. 《C++Primer》第五版习题答案--第二章【学习笔记】

    C++Primer第五版习题解答---第二章 ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/9 第二章:变量和基本类型 练习2.1: 类 ...

  8. c++ primer plus 第6版 部分二 5- 8章

    ---恢复内容开始--- c++ primer plus 第6版 部分二    5-  章 第五章 计算机除了存储外 还可以对数据进行分析.合并.重组.抽取.修改.推断.合成.以及其他操作 1.for ...

  9. c++ primer plus 第6版 部分一 1-4章

    c++ primer plus 第6版 源代码 ---编译器---目标代码---连接程序(启动代码--库代码)---可执行代码 源代码扩展名:c   cc   cxx     C    cpp     ...

随机推荐

  1. 大数据学习之路之ambari的安装

    之前按照正常方式安装的hbase不能插入数据 所以今天来尝试下ambari能不能行 已经打了快照 如果不能还能恢复之前的样子

  2. java基础-多线程互斥锁

    多线程(JDK1.5的新特性互斥锁)* 1.同步 * 使用ReentrantLock类的lock()和unlock()方法进行同步* 2.通信 * 使用ReentrantLock类的newCondit ...

  3. ztree详解

    1.添加样式.js <link rel="stylesheet" href="${ctx}/hollybeacon/resources/plugins/zTree_ ...

  4. js验证邮箱格式

    function test() { var temp = document.getElementById("text1"); //对电子邮件的验证 var myreg = /^([ ...

  5. Linux操作系统与项目部署

    Linux操作系统与项目部署 注意:本版块会涉及到操作系统相关知识. 现在,几乎所有智能设备都有一个自己的操作系统,比如我们的家用个人电脑,基本都是预装Windows操作系统,我们的手机也有Andro ...

  6. 集成JUnit测试

    集成JUnit测试 既然使用了Spring,那么怎么集成到JUnit中进行测试呢,首先大家能够想到的肯定是: public class TestMain { @Test public void tes ...

  7. Problem N: 输出回字形

    这个题如果用for循环直接做的话恐怕得做上几个小时吧,加上一点小技巧,用坐标法来写这个题.就像下面这样: 坐标原点不在矩形的角上,而在矩形的中心处,这只是算是一个技巧,理解起来好理解而已.

  8. zabbix 6.0 docker-compose 部署

    zabbix 6.0 docker-compose 部署 zabbix6.0 已是新LTS版本.根据zabbix-docker上的trunk版本来搭建zabbix6.0. 根据踩坑,记录docker- ...

  9. NodeJs学习日报day6——路由模块

    const express = require('express') const app = express() app.get('/user', function(req, resp) { resp ...

  10. C#面向抽象编程第二讲

    抽象编程怎么说呢,以观察者模式为例: 观察者模式有两个对象,一个是观察者,一个是可观察者(字面翻译很别扭observable),消息发布者(提供者). 第一层如下,三个对象A.B.C分别有一个接收消息 ...