重新学习C语言的getchar()函数以及某些体会
2014-09-19 22:46
302 查看
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
_filbuf(_stream));清空缓存
#define stdin (&_iob[0]) stdin的类型就是一个_iob[0]的地址
_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输出回车。
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));清空缓存
#define stdin (&_iob[0]) stdin的类型就是一个_iob[0]的地址
_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输出回车。
相关文章推荐
- 重新学习C语言 ----- getchar()&&&&putchar()
- C语言学习笔记(三) 输入输出函数的基本用法以及运算符
- C语言学习笔记之字符I/O(getchar()函数与putchar()函数)
- 函数06 - 零基础入门学习C语言37
- Oracle基础重新学习以及思考
- 函数01 - 零基础入门学习C语言32
- 重新学习忘光光的C语言
- 重新学习C语言
- 函数05 - 零基础入门学习C语言36
- 学习51笔记与一份从网上找的资料:单片机C语言中_nop_函数的使用及C语言的延时计算2010-
- 学习笔记——atoi函数的用法及用C语言实现atoi
- 函数03 - 零基础入门学习C语言34
- 重新学习C语言
- 函数03 - 零基础入门学习C语言34
- 函数04 - 零基础入门学习C语言35
- 函数01 - 零基础入门学习C语言32
- 学习C语言的函数
- 重新学习c语言(1.2)
- C/C++学习笔记1 - 深入了解scanf()/getchar()和gets()等函数(原创)
- 函数02 - 零基础入门学习C语言33