一·、栈区使用一般不超过8m
堆区一般申请2.7G到2.9G
主要计算行数的时候,看到strlen-1的位置是不是\n,如果数组太短一次只能取一行的一半不能算1行,所以遇到\n才算一行
a[0]就是a的数量,依次类推
二、结构体放字符串如果放错位置,可能能强制装进去但是取不出来
放字符串需要手动添加\0作为结束符,•如果您想要复制字符串并且保持字符串的完整性(包括结束标志),您应该复制 strlen(src) + 1 个字节,以确保 '\0' 也被复制。
三、当在结构体中存放一个字符串时,如果字符串的长度超过了分配给该字符串的空间大小,结构体对齐规则本身不会直接影响字符串超出部分的处理方式。但是,结构体中的字符串通常以 null 终止符('\0')结束,以指示字符串的结束。如果字符串的长度超过了分配的空间,那么可能会发生以下几种情况:
1. 溢出到后续成员:•如果字符串超过了分配的空间,而结构体中的下一个成员紧跟着字符串变量,那么字符串可能会溢出到下一个成员的内存空间中。•这种情况下,可能会破坏结构体中后续成员的数据,导致未定义行为。
2. 溢出到前面的空间:•结构体中的字符串通常不会自动占用前面成员的空间。这是因为结构体的成员是按照声明的顺序依次分配内存的。•如果结构体中前面的成员没有足够的空间来容纳字符串的溢出部分,那么字符串的溢出部分不会自动占用前面成员的空间。
3. 内存对齐的影响:•结构体对齐规则主要是为了提高内存访问效率而设计的,它不会直接影响字符串超出部分的处理方式。•但是,如果字符串紧跟着一个对齐要求较高的成员,那么字符串可能会开始于一个较大的对齐边界上,从而可能占用更多空间。
四、
if(feof(src))
{
break;
}
if(ferror(src))
{
clearerr(src);
}
ferror
检测一个流是否出错
clearerr
void clearerr(FILE *stream);
清除一个流出错的标记
if (feof(fp)) {
printf("到达文件末尾!\n")}
else {printf("未到达文件末尾!\n");}
if (ferror(fp)) {
printf("出错!\n");
clearerr(fp);}
else { printf("未出错!\n");
五、int fseek(FILE *stream, long offset, int whence);
功能:将stream流文件中的文件指针从whence位置开始
偏移offset字节的长度。
参数:stream 要移动文件指针的目标文件流对象。
注意:不支持设备文件,一般用于普通文件。
offset 要在文件内偏移的距离,单位字节。
如果值为整数,则向文件末尾偏移
如果值为负数,则向文件开头偏移
whence 偏移的起始位置,由系统定义的三个宏开始。
SEEK_SET 文件的开头位置
SEEK_CUR 文件的当前位置
SEEK_END 文件的末尾位置
返回值:
成功:0 失败: -1;
如果从文件的指定位置向后偏移过程中已经超过了文件的当前末尾位置,则会自动以'\0'来填充文件内容,从而形成一种被称为"空洞文件" 的特殊文件。
六、long ftell(FILE *stream);rewind(fp);
功能:获取当前文件流指针的具体位置,一般以文件 开头到当前指针的字节数为返回值。
参数:stream 要返回指针距离的文件流对象
返回值:成功 获取到的距离长度,单位是字节 失败 -1;
七、rewind(FILE *stream) 等效于:fseek(stream,0,SEEK_SET);到最开始位置
八、行缓冲,一行为1k, terminal,主要用于人机交互stdout
缓存区满或者遇到\n刷新 1024
行缓存多是关于终端的一些操作
1.遇到\n刷新
2.缓存区满刷新
3.程序正常结束刷新
4.fflush刷新 fflush(stdout);
全缓冲,4k,主要用于文件的读写
缓存区满刷新缓存区 4096
对普通文件进行标准IO操作,建立
的缓存一般为全缓存
刷新条件:
1.缓存区满刷新
2.程序正常结束刷新
3.fflush来刷新 fflush(fp);
无缓冲,0k 主要用于出错处理信息的输出 stderr ,不经过缓冲区
不对数据缓存直接刷新
printf();==>>stdout
fprintf(strerr,"fopen error %s",filename);
界面交互 出错处理
使用gdb查看,FILE结构体,或使用写入数据测试缓冲区。
缓冲区的大小是可以设置
一次缓冲区为块设备大小,512byte,一行为1024byte,两个块设备
九、
文件io
操作系统为了方便用户使用系统功能而对外提供的一组系统函数。称之为 系统调用 其中有个 文件IO
一般都是对设备文件操作,当然也可以对普通文件进行操作。
一个基于Linux内核的没有缓存的IO机制
特性:
.1 没有缓存区
.2 操作对象不在是流,而是文件描述符
.3文件描述符
很小的非负的整数 int 0-1023
内核每打开一个文件就会获得一个文件 描述符
每个程序在启动的时候操作系统默认为其打开
三个描述符与流对象匹配:
0 ==>STDIN_FILENO === stdin
1 ==>STDOUT_FILENO == stdout
2 ==>STDERR_FILENO == stderr
stdin,stdout,stderr,===>FILE*
ansi c
unistd.h ===>POSIX 标准库
fopen fgetc/s/fread system-v 标准
rw- rw- r--
110 100
6 6 4
fopen open
w O_WRONLY|O_CREAT|O_TRUNC
w+ O_RDWR|O_CREAT|O_TRUNC
r O_RDONLY
r+ O_RDWR
a O_WRONLY|O_CREAT|O_APPEND
a+ O_RDWR|O_CREAT|O_APPEND
open
read /write
close
2.函数接口
1.open
open("1.c",O_WRONLY|O_CREAT,0666 );
int open(const char *pathname, int flags,int mode);
功能:
获得一个文件描述符
参数:
pathname:文件名
flags:
O_RDONLY |
O_WRONLY
O_RDWR
O_CREAT, 创建文件
O_EXCL,需要和O_CREAT同时使用,表示新建的文件不能存在,成功,否则open就会失败
O_NOCTTY,不是终端设备
O_TRUNC文件内容清空
O_APPEND追加
O_ASYNC异步io,什么时候io不确定,
O_NONBLOCK非阻塞
返回值:
成功返回文件描述符
失败返回-1
2.write
char buf[1024];
ssize_t write(int fd, const void *buf, size_t count);
功能:
通过文件描述符向文件中写一串数据
参数:
fd:文件描述符
buf:要写入文件的字符串的首地址
count:要写入字符的个数
返回值:
成功返回实际写入的个数
失败返回-1
3.read
ssize_t read(int fd, void *buf, size_t count);
功能:
通过文件描述符读取文件中的数据
参数:
fd:文件描述符
buf:存放数据空间的首地址
count:要读到数据的个数
返回值:
成功返回读到数据的个数
失败返回-1
读到文件结尾返回0