1.在允许使用某种类型变量值的任何场合,都可以使用该类型的更复杂的表达式
2.for循环分为三部分,第一部分为初始化,仅在进入循环前执行一次。第二部分是控制循环的测试或者
条件部分,循环控制将对该条件求值,如果结果值为真,则执行一次循环体。然后执行第三部分,然后在求条件值,根据值的结果决定是否执行循环体。
3.#define 定义符号常量的过程中后边没有符号‘;’。
4.标准库提供的标准输入输出模型非常简单。无论文本从何处输入,输出到何处,其输入/输出都是按照字符流的方式处理。文本流是由多行字符构成的字符序列,而每行字符则由0个或多个字符组成,行末是一个换行符。
5.
#define getchar() getc(stdin) 说明getchar()函数和getc(stdin)函数的作用是一样的
#define getc(_stream) (--(_stream)->_cnt>=0?Oxff&*(_stream)->_ptr++:_filbuf(_stream))
类似于 if(--(_stream)->_cnt>=0)
return Oxff&*(_stream)->_ptr++;
else
_CRTIMP extern FILE _iob[];
struct _iobuf{
char *_ptr;读指针的位置
int _cnt;缓冲区的输入的字节数目
char *_base;缓冲区基地址
int _flag;
int _file;
int _charbuf;
int _bufsize; 缓冲区的大小
char *_tmpfname;
};
typedef struct _iobuf FILE;
2.for循环分为三部分,第一部分为初始化,仅在进入循环前执行一次。第二部分是控制循环的测试或者
条件部分,循环控制将对该条件求值,如果结果值为真,则执行一次循环体。然后执行第三部分,然后在求条件值,根据值的结果决定是否执行循环体。
3.#define 定义符号常量的过程中后边没有符号‘;’。
4.标准库提供的标准输入输出模型非常简单。无论文本从何处输入,输出到何处,其输入/输出都是按照字符流的方式处理。文本流是由多行字符构成的字符序列,而每行字符则由0个或多个字符组成,行末是一个换行符。
5.
#define getchar() getc(stdin) 说明getchar()函数和getc(stdin)函数的作用是一样的
#define getc(_stream) (--(_stream)->_cnt>=0?Oxff&*(_stream)->_ptr++:_filbuf(_stream))
类似于 if(--(_stream)->_cnt>=0)
return Oxff&*(_stream)->_ptr++;
else
_filbuf(_stream));清空缓存
_CRTIMP extern FILE _iob[];
struct _iobuf{
char *_ptr;读指针的位置
int _cnt;缓冲区的输入的字节数目
char *_base;缓冲区基地址
int _flag;
int _file;
int _charbuf;
int _bufsize; 缓冲区的大小
char *_tmpfname;
};
typedef struct _iobuf FILE;
--(_stream)->_cnt>=0判断缓冲区是否有数据,有的话减一,并读取了一个数据return 0xff&*(stdin)->ptr++,并且指针向前移动一个位置。
比如运行如下函数体
main()
{
char c;
c=getchar();
c=getchar();
printf("%c",c);
}
运行后输入a然后在单击enter键
输出回车,原因在于利用了缓冲机制,将a以及回车的对应的字符存储到缓冲区,然后判断缓冲区中的_cnt(字符的个数)减以后为1,大于零,所以执行return语句,将缓冲区中的字符输出,接下来同样的判断仍符合要求,接着将缓冲区中的字符赋值给c输出回车。