fgets(send_buf, sizeof(send_buf), stdin);fget函数的使用
时间: 2023-06-15 13:04:05 浏览: 121
fgets() 是一个常用的 C 语言函数,用于从标准输入流(stdin)中读取一行文本。它的函数原型是:
```c
char *fgets(char *str, int n, FILE *stream);
```
其中,str 是用来存储读取到的文本的字符数组;n 是要读取的最大字符数(包括结尾的 '\0');stream 是文件指针,通常用 stdin 表示从标准输入读取。
fgets() 会读取一行文本,包括结尾的换行符('\n'),并将其存储到 str 中。如果读取成功,则返回 str 的值;否则返回 NULL。当读取到文件结尾或者发生错误时,fgets() 也会返回 NULL。
需要注意的是,fgets() 会将换行符也读取进来,因此需要将其从 str 中去掉,可以使用以下代码实现:
```c
fgets(send_buf, sizeof(send_buf), stdin);
send_buf[strcspn(send_buf, "\n")] = '\0';
```
其中,strcspn() 函数用于查找第一个 '\n' 的位置,并返回其在字符串中的下标。然后将其替换为 '\0',即可去掉换行符。
相关问题
fgets(buf,sizeof(buf),stdin);
这段代码是 C 语言中用于从标准输入流(stdin)中读取一行数据的函数调用。其中,fgets 函数的第一个参数 buf 是用于存储读取数据的缓冲区,第二个参数 sizeof(buf) 是缓冲区的大小,第三个参数 stdin 表示从标准输入流中读取数据。
该函数会读取标准输入流中的一行数据,直到遇到换行符或缓冲区满为止,并将其存储在缓冲区 buf 中。如果读取成功,则返回 buf 的地址,否则返回 NULL。
int rank_t() { typedef struct node_t{ char ch_x[1024];//数据域 char ch_y[1024]; }Node_T; FILE *fp = fopen("node_htl.txt", "r"); if (fp == NULL) { printf("Failed to open the file.\n"); return -1; } // 处理每一行数据,将成绩记录到 buf_score 数组中 char buf[1024] = {0}; Node_T ch_buf[5]; int count = 0; // 提取姓名 int i, j; while (fgets(buf, sizeof(buf), fp)) { char buf2[4] = {0}; char buf3[7] = {0}; for(;buf[j] != ' ';j++) { buf2[j] = buf[j]; } while(buf[++j] == '\n') { if(buf[j] == ' ') { for(;buf[++j] == '\n';) { buf3[j-4] = buf[j]; } } } strcpy(ch_buf[count].ch_x, buf2); strcpy(ch_buf[count].ch_y, buf3); } for(i = 0; i<count-1;i++) { for(j=0;j<count-1-i; j++) { if(strcmp(ch_buf[j].ch_y,ch_buf[j+1].ch_y) < 0) { int ch_buf1[1024]; int ch_buf2[1024]; strcpy(ch_buf1, ch_buf[j].ch_x); strcpy(ch_buf2, ch_buf[j].ch_y); strcpy(ch_buf[j].ch_x, ch_buf[j+1].ch_x); strcpy(ch_buf[j].ch_y, ch_buf[j+1].ch_y); strcpy(ch_buf[j+1].ch_x, ch_buf1); strcpy(ch_buf[j+1].ch_y, ch_buf2); } } } int buf_y = 50; for(j=0;j<count;j++) { fprintf(buf, "%s %s", ch_buf[j].ch_x,ch_buf[j].ch_y); drawboard(buf,200,buf_y, 0x00ffffff); buf_y += 50; } fclose(fp); return 0; }为什么不行
这段代码中存在一些问题:
1. 在排序时,将 `ch_buf1` 和 `ch_buf2` 声明为了 `int` 类型数组,但实际上应该是字符数组,应该使用 `char` 类型数组来保存字符串。
2. 在排序时,将 `ch_buf1` 和 `ch_buf2` 中的字符串内容复制到了 `ch_buf[j].ch_x` 和 `ch_buf[j].ch_y` 中,而实际上应该是互换两个结构体中的 `ch_x` 和 `ch_y`。
3. 在输出排好序的字符串时,将输出结果写入了一个 `buf` 变量中,但是 `buf` 变量在前面已经被用来保存读取文件的每一行数据了,应该使用另外一个变量来保存输出结果。
修改后的代码如下:
```
int rank_t() {
typedef struct node_t {
char ch_x[1024];//数据域
char ch_y[1024];
} Node_T;
FILE *fp = fopen("node_htl.txt", "r");
if (fp == NULL) {
printf("Failed to open the file.\n");
return -1;
}
// 处理每一行数据,将成绩记录到 buf_score 数组中
char buf[1024] = {0};
Node_T ch_buf[5];
int count = 0;
// 提取姓名
int i, j;
while (fgets(buf, sizeof(buf), fp)) {
char buf2[1024] = {0};
char buf3[1024] = {0};
for (j = 0; buf[j] != ' '; j++) {
buf2[j] = buf[j];
}
while (buf[++j] == '\n') {
if (buf[j] == ' ') {
for (; buf[++j] == '\n';) {
buf3[j - 4] = buf[j];
}
}
}
strcpy(ch_buf[count].ch_x, buf2);
strcpy(ch_buf[count].ch_y, buf3);
count++;
}
for (i = 0; i < count - 1; i++) {
for (j = 0; j < count - 1 - i; j++) {
if (strcmp(ch_buf[j].ch_y, ch_buf[j + 1].ch_y) < 0) {
char ch_buf1[1024] = {0};
char ch_buf2[1024] = {0};
strcpy(ch_buf1, ch_buf[j].ch_x);
strcpy(ch_buf2, ch_buf[j].ch_y);
strcpy(ch_buf[j].ch_x, ch_buf[j + 1].ch_x);
strcpy(ch_buf[j].ch_y, ch_buf[j + 1].ch_y);
strcpy(ch_buf[j + 1].ch_x, ch_buf1);
strcpy(ch_buf[j + 1].ch_y, ch_buf2);
}
}
}
int buf_y = 50;
FILE *fp_out = fopen("out.txt", "w");
for (j = 0; j < count; j++) {
fprintf(fp_out, "%s %s\n", ch_buf[j].ch_x, ch_buf[j].ch_y);
drawboard(buf, 200, buf_y, 0x00ffffff);
buf_y += 50;
}
fclose(fp);
fclose(fp_out);
return 0;
}
```
注意,这里将输出结果保存到了 `out.txt` 文件中,如果需要在程序中进行显示,需要将 `drawboard` 函数的参数改为 `fp_out`。
阅读全文