大多数人并不认为有几类人猿学校计划非常赞同C学习好,然后看多本书。

仅仅作为读书笔记写。有时还包括一些题目和答案。

这样的公开栏,这两种玉引砖敲,对于自勉,鼓励王!

第一章:手

我每次都是复习的来写。我想是这一章,哪怕是上手也须要有一定的C基础。

总结:提出了stdio.h中一些主要的函数。如scanf(),printf(),getchar(),putchar(),gets(),puts()等io函数。

关于NULL和NUL的差别也说了一些。

NUL也就是字符串中的截尾字符'\n',并不存在与预处理中。

NULL是stdio中定义好的字符,表示指针为空,为整型0。

EOF也是stdio种定义好的字符。表示为指针指向文档的结尾。





警告:

1、在scanf函数的标量參数前并未加入&字符。

首先是标量參数,举个样例,数组元素參数是标量參数。它通过值传递来通过main和函数间传递。

&符号在这里是寻址。假设是数组參数,它本身是个地址,所以就不须要做寻址运算了。

2、机械地把printf函数的格式代码照搬于scanf函数。

3、在应该使用&&操作符的地方误用了&操作符。

一个是逻辑操作符。一个是寻址。一般细心都能够避免这个问题。

4、误用=操作符而不是==操作符来測试相等性。

同上,只是这个问题好像犯错的人很多其它一些。

尤其是在if、while推断中常常出现。

如:while(pointer==EOP)





编程提示:

1、使用#include指令避免反复声明。

同一时候在#include 里面放置函数的原型。

2、使用#define 指令给常量命名。

3、使用数组下标前先检查他们的值。

如:ch = getchar(); 

    while(ch != EOF && ch != '\n')

ch = getchar();

这是个好习惯。

4、在while/if表达式中蕴含赋值操作。

如:

ch = getchar(); 

while(ch != EOF && ch != '\n')

ch = getchar();

就能够写成:

while((ch = getchar()) != EOF && ch != '\n')

;

这样,就能够消除冗余语句。

你能够理直气壮地声称这样的可读性非常差的代码技巧应该避免使用。我也能够理直气壮地告诉你。这是由于你对C不是非常熟。

大牛们在读代码的时候根本不会出现不论什么问题。

5、怎样编写一个空循环体。

while((ch = getchar()) != EOF && ch != '\n')

;

这个分号是很重要的。否则下一句不相关的语句就会被拖入while循环。

6、怎样进行检查。确保数组不越界。

比方在存数组中,必需包含下面:

1、假设输入行结束或者输入行数组已满,跳出循环break;

2、假设输出数据没有足够的空间排,只有傅值它可以容纳数据;

版权声明:本文博客原创文章。博客,未经同意,不得转载。

C和指针 (pointers on C)——第一章:高速启动的更多相关文章

  1. 《C和指针》读书笔记——第一章 快速上手

    1.注释代码可以用: #if 0 statements #endif 2.参数被声明为const,表明函数将不会修改函数调用者的所传递的这个参数. 3.scanf("%d",&am ...

  2. flask第一章 flask启动 路由视图 FlaskRequest jinja2 FlaskSession

    一.简单了解flask web框架 优点: 小而精,组件只有session,第三方机构强烈支持flask,极其简单 缺点: 由于第三方软件的关系,稳定性相对较差,flask-session 扩展知识: ...

  3. Netty源码分析第1章(Netty启动流程)---->第1节: 服务端初始化

    Netty源码分析第一章:  Server启动流程 概述: 本章主要讲解server启动的关键步骤, 读者只需要了解server启动的大概逻辑, 知道关键的步骤在哪个类执行即可, 并不需要了解每一步的 ...

  4. Netty源码分析第1章(Netty启动流程)---->第2节: NioServerSocketChannel的创建

    Netty源码分析第一章:  Server启动流程 第二节:NioServerSocketChannel的创建 我们如果熟悉Nio, 则对channel的概念则不会陌生, channel在相当于一个通 ...

  5. Netty源码分析第1章(Netty启动流程)---->第3节: 服务端channel初始化

    Netty源码分析第一章:Netty启动流程   第三节:服务端channel初始化 回顾上一小节的initAndRegister()方法: final ChannelFuture initAndRe ...

  6. Netty源码分析第1章(Netty启动流程)---->第4节: 注册多路复用

    Netty源码分析第一章:Netty启动流程   第四节:注册多路复用 回顾下以上的小节, 我们知道了channel的的创建和初始化过程, 那么channel是如何注册到selector中的呢?我们继 ...

  7. Netty源码分析第1章(Netty启动流程)---->第5节: 绑定端口

    Netty源码分析第一章:Netty启动步骤 第五节:绑定端口 上一小节我们学习了channel注册在selector的步骤, 仅仅做了注册但并没有监听事件, 事件是如何监听的呢? 我们继续跟第一小节 ...

  8. 《C与指针》第十二章练习

    本章例程 //12.3 #include <stdio.h> #include <stdlib.h> typedef struct NODE{ struct NODE *lin ...

  9. 第一章.C语言简介

    C语言第一章 C语言简介   目录 一.C语言介绍 二.C语言特点 三.Hello World 四.转义符 五.占位符 六.俄罗斯方块游戏 七.文件下载 一.C语言介绍 C是一种通用的编程语言,广泛用 ...

随机推荐

  1. Duanxx的Design abroad: C++矩阵运算库Eigen 概要

    一.概要 这两天想起来要做神经网络的作业了,要求用C++完毕神经网络的算法. 摆在面前的第一个问题就是,神经网络算法中大量用到了矩阵运算.可是C++不像matlab那样对矩阵运算有非常好的支持.本来准 ...

  2. 【Android进阶】判断网络连接状态并自动界面跳转

    用于判断软件打开时的网络连接状态,若无网络连接,提醒用户跳转到设置界面 /** * 设置在onStart()方法里面,可以在界面每次获得焦点的时候都进行检测 */ @Override protecte ...

  3. HDU 3415 Max Sum of Max-K-sub-sequence(单调队列)

    转载请注明出处:http://blog.csdn.net/u012860063 Max Sum of Max-K-sub-sequence Time Limit: 2000/1000 MS (Java ...

  4. UVa10000_Longest Paths(最短路SPFA)

    解题报告 求最长路. 用SPFA求最长路,初始化图为零,dis数组也为零 #include <iostream> #include <cstdio> #include < ...

  5. 设计模式-----观察者模式(Obsever)

    它定义了对象之间一对多的依赖关系.因此,.当一个对象的状态变化,对吸毒成瘾者,他将收到通知和更新自己主动. 观察者模式的组成: 抽象主题角色:把全部对观察者对象的引用保存在一个集合中.抽象主题提供一个 ...

  6. android大概是通过logcat拦截Log

    我们必须在系统的环境变量先增加adb 路径: 在原有环境的后面增加;E:\Android\android-sdk-r16\platform-tools(;是不能缺少的) 然后我们在cmd中输入adb, ...

  7. SynchronousQueue、LinkedBlockingQueue、ArrayBlockingQueue性能测试(转)

    听说JDK6对SynchronousQueue做了性能优化,避免对竞争资源加锁,所以想试试到底平时是选择SynchronousQueue还是其他BlockingQueue. 对于容器类在并发环境下的比 ...

  8. SGU 200. Cracking RSA(高斯消元+高精度)

    标题效果:鉴于m整数,之前存在的所有因素t素数.问:有多少子集.他们的产品是数量的平方. 解题思路: 全然平方数就是要求每一个质因子的指数是偶数次. 对每一个质因子建立一个方程. 变成模2的线性方程组 ...

  9. 恢复SQLServer实例连接

    原文:恢复SQLServer实例连接 译自: http://www.mssqltips.com/sqlservertip/2682/recover-access-to-a-sql-server-ins ...

  10. POJ 2155 Matrix (D区段树)

    http://poj.org/problem?id=2155 Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 1 ...