赞
踩
还是直接贴代码:
// Main function.
while (1){
unsigned long k = 1, i = 0;
char *s_buf = (char *)malloc(k * N_ABUFSIZE);
if (s_buf == NULL){
printf("Memory error!");
return 1;
}
memset(s_buf, 0, k * N_ABUFSIZE);
char *s_tmp = NULL;
char c = 0;
printf("\n#%s>", s_name);
while (1){
c = getchar();
if (c == EOF || c == '\n'){
break;
}
s_buf[i] = c;
i++;
if (i % N_ABUFSIZE == 0){
s_tmp = (char *)malloc((k * N_ABUFSIZE + 2));
if (s_tmp == NULL){
printf("Memory error!");
return 1;
}
strncpy(s_tmp, s_buf, k * N_ABUFSIZE);
free(s_buf);
s_buf = s_tmp;
k++;
}
}
s_buf[i] = '\0';
先来解释一下这段代码:
这段代码是主要代码,如各位朋友需要完整的实现代码可以发我邮箱。(2608184397@qq.com)
这段代码的主要原理是:使用一个主要缓冲区,一个协同缓冲区,(其实也不叫协同)
主要缓冲区就是用来存储数据的,
而协同缓冲区呢就是用来辅助扩展贮存空间的,(大概是这样的:代码的最前面,先分配一小部分内存空间,然后在不够用时,先把内存空间分配到协同缓冲区里面,然后将主要缓冲区的内容copy到协同缓冲区里面,然后释放主要缓冲区的内存,最后将协同缓冲区的地址赋予主要缓冲区)就是这么简单!
注意事项:
1:笔者使用的GCC(c99)编译,(个别编译器可能会报错),
2:注意识别内存是否分配成功。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。