缓冲区c语言
‘壹’ c语言中buffer到底是什么意思是数组缓冲区为什么一般C程序中都不定义他直接拿来用呢
C语言中buffer是缓冲区的意思。
不定义是不能拿过来直接用的,因为它肯定是在别的地方定义的,比如头文件,或者是个全局变量等。一般是在编译器里面,右键这个变量,选gotodifination就可以看到它在哪定义的了。
缓冲区它是内存空间的一部分。也就是说,在内存空间中预留了一定的存储空间,这些存储空间用来缓冲输入或输出的数据,这部分预留的空间就叫做缓冲区。
(1)缓冲区c语言扩展阅读
C语言循环buffer的实现
#ifdefined(__CIRCLE_BUFFER__)
//"circle_buffer.h"
#ifndef__CIRCLE_BUFFER_H__
#define__CIRCLE_BUFFER_H__
#ifdefined(__CIRCLE_BUFFER__)
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<assert.h>
typedefunsignedcharcb_u8;
typedefunsignedshortintcb_u16;
typedefunsignedintcb_u32;
typedefsignedcharcb_s8;
typedefsignedshortintcb_s16;
typedefsignedintcb_s32;
typedefcharcb_char;
typedefenum{cb_false,cb_true}cb_bool;
typedefstruct{
cb_u8*bufptr;
cb_u32buflen;
cb_u32datalen;
cb_u32readpos;
cb_u32writepos;
}CircleBufferMngr;
typedefstruct{
void(*cb_init)(CircleBufferMngr**,cb_u32);
void(*cb_deinit)(CircleBufferMngr**);
void(*cb_info)(CircleBufferMngr*,cb_char*,cb_u32);
cb_u32(*cb_read)(CircleBufferMngr*,cb_u8*,cb_u32);
cb_u32(*cb_write)(CircleBufferMngr*,cb_u8*,cb_u32);
cb_u32(*cb_datalen)(CircleBufferMngr*);
cb_bool(*cb_full)(CircleBufferMngr*);
cb_bool(*cb_empty)(CircleBufferMngr*);
}CircleBufferApi;
#defineCB_MEMCPYmemcpy
#defineCB_MEMSETmemset
#defineCB_SPRINTsprintf
#defineCB_MALLOCmalloc
#defineCB_MFREEfree
#defineCB_ASSERTassert
#defineCB_SNPRINTsnprintf
#defineCB_TRACEprintf
//锁定,禁止中断和任务调度
#defineCB_GLOBAL_LOCK
#defineCB_GLOBAL_UNLOCK
;
#defineCBMA_INITcircleBufApi.cb_init
#defineCBMA_DEINITcircleBufApi.cb_deinit
#defineCBMA_INFOcircleBufApi.cb_info
#defineCBMA_READcircleBufApi.cb_read
#defineCBMA_WRITEcircleBufApi.cb_write
#defineCBMA_DATALENcircleBufApi.cb_datalen
#defineCBMA_FULLcircleBufApi.cb_full
#defineCBMA_EMPTYcircleBufApi.cb_empty
#endif/*__CIRCLE_BUFFER__*/
#endif/*__CIRCLE_BUFFER_H__*/
‘贰’ C语言缓冲区在哪里
缓冲区具体在哪里是与操作系统、编译器相关的
以VC++为例。察看getchar的源代码(src\fgetchar.c),有:
int __cdecl _fgetchar (void){
return(getc(stdin));
}
#undef getchar
int __cdecl getchar (void){
return _fgetchar();
}
可见getchar()相当于getc(stdin)
继续察看getc(src\fgetc.c),有一段(为便于阅读,有删减):
int __cdecl getc (FILE *stream){
int retval;
_ASSERTE(stream != NULL);
_lock_str(stream);
__try {
retval = _getc_lk(stream);
}
__finally {
_unlock_str(stream);
}
return(retval);
}
这段代码里_lock_str其实是通过Win32 API提供的临街区来锁住文件
接收用户输入发生在_getc_lk,_getc_lk宏调用_filbuf。_filbuf在_filbuf.c中可以查看,这段代码比较长,就不贴出来了
_filbuf主要是调用了_read(_fileno(stream), stream->_base, stream->_bufsiz)
而_read最终则是调用了Win32API ReadFile,以下是用WinDbg输出的getchar的调用栈:
# ChildEBP RetAddr
00 0012fe6c 0040a4e7 kernel32!ReadFile
01 0012fea8 0040a3b9 TestStruct!_read_lk+0x107 [read.c @ 146]
02 0012fec0 00403140 TestStruct!_read+0x69 [read.c @ 75]
03 0012fee8 00401290 TestStruct!_filbuf+0xd0 [_filbuf.c @ 127]
04 0012ff08 004012cc TestStruct!fgetc+0x80 [fgetc.c @ 44]
05 0012ff14 0040103d TestStruct!getc+0xc [fgetc.c @ 56]
06 0012ff20 00401058 TestStruct!_fgetchar+0xd [fgetchar.c @ 37]
07 0012ff28 0040101e TestStruct!getchar+0x8 [fgetchar.c @ 47]
08 0012ff80 0040115c TestStruct!main+0xe [d:\my programs\teststruct\ts.cpp @ 4]
09 0012ffc0 7c816fe7 TestStruct!mainCRTStartup+0xfc [crt0.c @ 206]
0a 0012fff0 00000000 kernel32!BaseProcessStart+0x23
可见,getchar最终调用了ReadFile。关于ReadFile的原理以及缓冲区在哪里,请你再提一个问我再回答