fclose不明确,我用fprintf写一个文件,之前是用wb方式打开,一直写一直写,是不是只有在fclose的时候才能把数据写到文件
fclose不明确,我用fprintf写一个文件,之前是用wb方式打开,一直写一直写,是不是只有在fclose的时候才能把数据写到文件详细介绍
本文目录一览: 小弟最近编写了两个c语言源程序,但其中种种问题无法解决,特来求助
文件一:使用getch() 要添加头文件#include
。
你只是在最后做个断点而已,使用getchar() 就够了。
getchar()和getch()功能上是有区别的。这个你最近百度下就是了。
文件二:
倒数第二句代码:fcloce(in);fclose(out); 写错了。。。
改为fclose(in);fclose(out);
这两个问题都解决了,程序可以运行了。多学学调试技巧,加油吧少年。
getch() 要添加头文件#include
是fclose
首先我们来讨论下第一个程序。
第一个程序的问题并不大,编译的时候编译器提示:
错误 3 error C3861: “getch”: 找不到标识符
我们分析这个错误,是编译器无法识别"getch"这个函数。经过查询,我们了解到getch()函数的确存在,并且详细信息如下:
函数名
getch
功 能
在windows平台下从控制台无回显地取一个字符,在linux下是有回显的。
返回值
从键盘上读取到的字符
头文件
#include
注意这里提到的头文件,就是包含了这个函数定义的文件,你需要在文件开始加入进去进行编译才可以。所以加入#include
后即编译通过!
程序如下:
#include
#include
#include
int main(){ FILE *out; char outfile[20],ch; long i=0; printf("!\n"); scanf("%s",outfile); if((out=fopen(outfile,"r"))==NULL) printf("NO !\n"); for(i=0;!feof(out);i++) ch=fgetc(out); fclose(out); getch(); return 0;}
再来看第二个程序。
首次编译后提示错误如下:
错误 5 error C3861: “fcloce”: 找不到标识符提示如同上一个程序中关于"getch"的提示。我们查询后发现floce并不存在,但是联系上下文可以判断此处应当是关闭文件指针的操作,对应的函数应当为fclose。因此将其更改为fclose(in)即可编译通过。
程序如下:
#include
#include
int main(){ FILE *in,*out; char ch,infile[20],outfile[20]; long i=0; printf("in\n"); scanf("%s",infile); printf("out\n"); scanf("%s",outfile); if((in=fopen(infile,"r"))==NULL) { printf("NO in!\n");exit(0); } if((out=fopen(outfile,"w"))==NULL) { printf("NO out!\n");exit(0); } for(i=0;!feof(in);i++) { ch=fgetc(in); fputc(ch,out); printf("%ld//****\n",i); } fclose(in); fclose(out); return 0;}
问题都是小问题,但是反映出了一些问题。
1、首先是程序的书写问题。程序二中你将fclose(in)和fclose(out)放在了一行里书写,这样如果某一个语句出现了错误,程序提示错误出现在第几行的时候你无法准确判断究竟是哪一个语句出现了错误。所以建议单条语句单行书写。
2、其次是关于定义变量时的书写问题。我注意到你在定义文件指针的时候是将FILE*in,out;连在一起书写的。其实在定义指针类型的变量的时候,*号是跟随着变量名称的,所以尽量在FILE和*号之间添加上一个空格,便于查看。
3、最后是关于查看错误信息的能力问题。通常编译错误的时候,编译器都会明确的通知你错误是什么,以及错误出现在程序中的第几行。有时候可能编译器显示不全,你可以右键后点击复制,然后将其错误信息粘贴出来查看。如下图所示:
如果实在不知道如何来解决,可以尝试将错误信息黏贴到百度或是其他搜索引擎上面查找,试图看看有没有网友遇到过相同或是相似的问题,从而获得解决办法。
望有所帮助,并祝愿楼主编程能力更进一步!
为什么fclose之后remove还是不成功
进程在占用那个文件,只有那个进程能删。比如你的程序fclose之后,调用函数删除,是可以成功删除的。
#include
int main(){
FILE *fp;
fp = fopen("file", "r+");
fclose(fp);
remove("file");
return 0;
}文件会成功被删除。
在程序结束时,应当用fclose函数关闭已打开的文件。对不对吗
对的,打开的文件肯定要关闭,这样才是好的操作
可以用fcloseall关闭所有打开文件
fopen的时候,会向操作系统申请文件句柄。
单个进程能够打开的最大文件句柄数量是有限制的,打开的文件句柄数越多响应时间肯定会越慢。如果程序结束的时候不用fclose释放文件句柄,文件句柄不能被回收。
对的!
fclose 函数名: fclose 功 能: 关闭一个流。注意:使用fclose函数就可以把缓冲区内最后剩余的数据输出到磁盘文件中,并释放文件指针和有关的缓冲区。 用 法: int fclose(FILE *stream); 程序例: #include
#include
int main(void) { FILE *fp; char buf[11] = "0123456789"; /* create a file containing 10 bytes */ fp = fopen("DUMMY.FIL", "w"); fwrite(&buf, strlen(buf), 1, fp); /* close the file */ fclose(fp); return 0; } 如果流成功关闭,fclose 返回 0,否则返回EOF(-1)。 如果流为NULL,而且程序可以继续执行,fclose设定error number给EINVAL,并返回EOF。
c语言编程报错!
重载函数二义性,不知道用哪个转换将int转换之后更好,这三个函数都是标准转换,所以一样好。你可以用转换把int类型参数static_cast
(x),T可以是float就行,因为它应该足够表示int了。很多VC6下可以运行的程序,到了VC2008下,都不会直接通过,因为VC2008更标准了,VC6应该说有点老了。
你要创建标准的C语言控制台程序,不要 #include "stdafx.h" 头文件。
设fp是指向某文件的文件指针,若函数fclose(fp)操作不成功,返回值是_________。
b
应该是。
选择【C.EOF】
fclose正常完成关闭文件操作时,fclose函数返回值为0,否则返回EOF。
在程序结束之前应关闭所有文件,这样做的目的是防止因为没有关闭文件而造成的数据流失。
C语言错误
C语言里的数组是必须要在编译时知道元素个数的。
float a[]没有指定元素个数,是错的。
float a[10]; //必须指定一个值表示元素个数float a[] = {1,2,3,4,5,6,7,8,9,10}; //可也以用初始化列表,列表元素个数就确定数组元素个数。
C语言中不允许在定义数组时不指明数组元素个数或对数组元素个数做动态定义(即不允许元素个数是变量) 如:
#include
int main()
{
int a;
scanf("%d",&a);
int i[a];
}
报错。
float a[]; 数组大小不知道。
(1) 如果带初始化是可以的: float a[] = {1,2,3,4,5,6,7,8};
(2) 你可以开一个能满足需要的大数组,例如: float a[100];
(3) 你可以动态分配:
float *a;
scanf("%d",&i); 后面加 a = (float *) malloc(sizeof(float) * i);
#include
#include
int main()
{
int gg(int i);
int i;
while(1){
i=0;
printf(" 1.查看历史日程表\n");
printf(" 2.输入新的日程表\n");
printf(" 3.查看已完成的日程表\n");
printf(" 4.查看未完成的日程表\n");
printf(" 5.退出登录\n");
printf(" 请选择相应序号: ");
scanf("%d",&i);
if(i==5){
break;
}
gg(i);
printf("\n");
printf("\n");
printf("\n");
}
}
int gg(int i){
int aa();
int bb();
int cc();
int dd();
switch(i){
case 1:
aa();break;
case 2:
bb();break;
case 3:
cc();break;
case 4:
dd();break;
}
}
int aa(){
FILE*fp;
int length=1000;
char str[1001];
if((fp=fopen("11s.txt","r"))==NULL){
printf("无文件");
return 0;
}
while(fgets(str,length,fp)!=NULL){
printf("%s",str);}
return 1;
fclose(fp);
}
int bb(){
FILE*fp;
char str[400];
printf("内容如下:\n");
scanf("%s",str);
if((fp=fopen("11s.txt","a+"))==NULL){
printf("文件不存在");
return 0;
}
fputs("\n",fp);
fputs(str,fp);
printf("加入成功");
fclose(fp);
return 1;
}
int cc(){
FILE*fp;
int length=1000;
char str[1001];
printf("内容如下:\n");
if((fp=fopen("11s.txt","r"))==NULL){
printf("无文件");
return 0;
}
while(fgets(str,length,fp)!=NULL){
if(strstr(str,"已完成")!=NULL){
printf("%s",str);
}
}
fclose(fp);
return 1;
}
int dd(){
FILE*fp;
int lenght=1000;
char str[1001];
printf("内容如下:\n");
if((fp=fopen("11s.txt","r"))==NULL){
printf("无文件");
return 0;
}
while(fgets(str,lenght,fp)!=NULL){
if(strstr(str,"未完成")!=NULL){
printf("%s",str);
}
}
fclose(fp);
return 1;
}
float a[]是个指针吧不能直接拿来用,
可以在printf("请输入你的%d个数:\n",i);之前把float a[] new出来
a=new float[i];
1. Ambiguous operators need parentheses — 不明确的运算需要用括号括起
2. Ambiguous symbol 'xxx' — 不明确的符号
3. Argument list syntax error — 参数表语法错误
4. Array bounds missing — 丢失数组界限符
5. Array size toolarge — 数组尺寸太大
6. Bad character in paramenters — 参数中有不适当的字符
7. Bad file name format in include directive — 包含命令中文件名格式不正确
8. Bad ifdef directive synatax — 编译预处理ifdef有语法错
9. Bad undef directive syntax — 编译预处理undef有语法错
10. Bit field too large — 位字段太长
11. Call of non-function — 调用未定义的函数
12. Call to function with no prototype — 调用函数时没有函数的说明
13. Cannot modify a const object — 不允许修改常量对象
14. Case outside of switch — 漏掉了case 语句
15. Case syntax error — Case 语法错误
16. Code has no effect — 代码不可能执行到
17. Compound statement missing{ — 分程序漏掉"{"
18. Conflicting type modifiers — 不明确的类型说明符
19. Constant expression required — 要求常量表达式
20. Constant out of range in comparison — 在比较中常量超出范围
21. Conversion may lose significant digits — 转换时会丢失意义的数字
22. Conversion of near pointer not allowed — 不允许转换近指针
23. Could not find file 'xxx' — 找不到XXX文件
24. Declaration missing ; — 说明缺少";"
25. Declaration syntax error — 说明中出现语法错误
26. Default outside of switch — Default 出现在switch语句之外
27. Define directive needs an identifier — 定义编译预处理需要标识符
28. Division by zero — 用零作除数
29. Do statement must have while — Do-while语句中缺少while部分
30. Enum syntax error — 枚举类型语法错误
31. Enumeration constant syntax error — 枚举常数语法错误
32. Error directive :xxx — 错误的编译预处理命令
33. Error writing output file — 写输出文件错误
34. Expression syntax error — 表达式语法错误
35. Extra parameter in call — 调用时出现多余错误
36. File name too long — 文件名太长
37. Function call missing ) — 函数调用缺少右括号
38. Fuction definition out of place — 函数定义位置错误
39. Fuction should return a value — 函数必需返回一个值
40. Goto statement missing label — Goto语句没有标号
41. Hexadecimal or octal constant too large — 16进制或8进制常数太大
42. Illegal character 'x' — 非法字符x
43. Illegal initialization — 非法的初始化
44. Illegal octal digit — 非法的8进制数字
45. Illegal pointer subtraction — 非法的指针相减
46. Illegal structure operation — 非法的结构体操作
47. Illegal use of floating point — 非法的浮点运算
48. Illegal use of pointer — 指针使用非法
49. Improper use of a typedefsymbol — 类型定义符号使用不恰当
50. In-line assembly not allowed — 不允许使用行间汇编
51. Incompatible storage class — 存储类别不相容
52. Incompatible type conversion — 不相容的类型转换
53. Incorrect number format — 错误的数据格式
54. Incorrect use of default — Default使用不当
55. Invalid indirection — 无效的间接运算
56. Invalid pointer addition — 指针相加无效
57. Irreducible expression tree — 无法执行的表达式运算
58. Lvalue required — 需要逻辑值0或非0值
59. Macro argument syntax error — 宏参数语法错误
60. Macro expansion too long — 宏的扩展以后太长
61. Mismatched number of parameters in definition — 定义中参数个数不匹配
62. Misplaced break — 此处不应出现break语句
63. Misplaced continue — 此处不应出现continue语句
64. Misplaced decimal point — 此处不应出现小数点
65. Misplaced elif directive — 不应编译预处理elif
66. Misplaced else — 此处不应出现else
67. Misplaced else directive — 此处不应出现编译预处理else
68. Misplaced endif directive — 此处不应出现编译预处理endif
69. Must be addressable — 必须是可以编址的
70. Must take address of memory location — 必须存储定位的地址
71. No declaration for function 'xxx' — 没有函数xxx的说明
72. No stack — 缺少堆栈
73. No type information — 没有类型信息
74. Non-portable pointer assignment — 不可移动的指针(地址常数)赋值
75. Non-portable pointer comparison — 不可移动的指针(地址常数)比较
76. Non-portable pointer conversion — 不可移动的指针(地址常数)转换
77. Not a valid expression format type — 不合法的表达式格式
78. Not an allowed type — 不允许使用的类型
79. Numeric constant too large — 数值常太大
80. Out of memory — 内存不够用
81. Parameter 'xxx' is never used — 能数xxx没有用到
82. Pointer required on left side of -> — 符号->的左边必须是指针
83. Possible use of 'xxx' before definition — 在定义之前就使用了xxx(警告)
84. Possibly incorrect assignment — 赋值可能不正确
85. Redeclaration of 'xxx' — 重复定义了xxx
86. Redefinition of 'xxx' is not identical — xxx的两次定义不一致
87. Register allocation failure — 寄存器定址失败
88. Repeat count needs an lvalue — 重复计数需要逻辑值
89. Size of structure or array not known — 结构体或数给大小不确定
90. Statement missing ; — 语句后缺少";"
91. Structure or union syntax error — 结构体或联合体语法错误
92. Structure size too large — 结构体尺寸太大
93. Sub scripting missing ] — 下标缺少右方括号
94. Superfluous & with function or array — 函数或数组中有多余的"&"
95. Suspicious pointer conversion — 可疑的指针转换
96. Symbol limit exceeded — 符号超限
97. Too few parameters in call — 函数调用时的实参少于函数的参数不
98. Too many default cases — Default太多(switch语句中一个)
99. Too many error or warning messages — 错误或警告信息太多
100. Too many type in declaration — 说明中类型太多
101. Too much auto memory in function — 函数用到的局部存储太多
102. Too much global data defined in file — 文件中全局数据太多
103. Two consecutive dots — 两个连续的句点
104. Type mismatch in parameter xxx — 参数xxx类型不匹配
105. Type mismatch in redeclaration of 'xxx' — xxx重定义的类型不匹配
106. Unable to create output file 'xxx' — 无法建立输出文件xxx
107. Unable to open include file 'xxx' — 无法打开被包含的文件xxx
108. Unable to open input file 'xxx' — 无法打开输入文件xxx
109. Undefined label 'xxx' — 没有定义的标号xxx
110. Undefined structure 'xxx' — 没有定义的结构xxx
111. Undefined symbol 'xxx' — 没有定义的符号xxx
112. Unexpected end of file in comment started on line xxx — 从xxx行开始的注解尚未结束文件不能结束
113. Unexpected end of file in conditional started on line xxx — 从xxx 开始的条件语句尚未结束文件不能结束
114. Unknown assemble instruction — 未知的汇编结构
115. Unknown option — 未知的操作
116. Unknown preprocessor directive: 'xxx' — 不认识的预处理命令xxx
117. Unreachable code — 无路可达的代码
118. Unterminated string or character constant — 字符串缺少引号
119. User break — 用户强行中断了程序
120. Void functions may not return a value — Void类型的函数不应有返回值
121. Wrong number of arguments — 调用函数的参数数目错
122. 'xxx' not an argument — xxx不是参数
123. 'xxx' not part of structure — xxx不是结构体的一部分
124. xxx statement missing ( — xxx语句缺少左括号
125. xxx statement missing ) — xxx语句缺少右括号
126. xxx statement missing ; — xxx缺少分号
127. xxx' declared but never used — 说明了xxx但没有使用
128. xxx' is assigned a value which is never used — 给xxx赋了值但未用过
c语言中fopen若不容fclose关掉 默认什么时候关掉
不会,等程序结束时才会关掉
有效
这个是和语言实现相关的。不过几乎所有的平台上这些函数的表层行为都是一致的(标准也要求这么做),因为实现很近似——用通常对程序员而言不可见的全局文件缓冲区保存文件信息。由于是全局的,和具体在哪一个函数中调用没有关联,因此函数结束也不会引起文件打开状态的改变,也就是说要关闭文件的话需要手动添加fclose的代码,若没有写,那么调用(不管是直接还是间接地)到fopen以后对应文件就处于打开状态。所以只要后面没有用到这个文件,LZ立刻用fclose关闭是正确的做法。
如果到进程结束前也没有显式地关闭文件,系统会对打开的文件缓冲区进行清理,以维护系统本身的稳定性。一般的PC中,程序在程序退出时由操作系统完成这个工作。在打开文件、使用结束后应该尽可能明确地关闭,不要把这个任务推卸给系统;这样的资源管理方式是合理的,不容易造成资源耗尽。
===
[原创回答团]
在vc中用fopen写入一个文本文件,但用fclose无法关闭,是不是这个文件被其他进程占用了
没这么悬吧,你怎么知道是没关闭呢,是没开还是没关~~
CFile::modeDenyRead打开文件拒绝其它进程对文件的读访问
CFile::modeDenyWrite打开文件拒绝其它进程对文件的写访问
每次都失败吗?是否是多线程,你一个线程关闭了,其他的线程又打开了?
调用int _fcloseall( void );
The _fcloseall function closes all open streams except stdin, stdout, stderr (and, in MS-DOS, _stdaux and _stdprn). It also closes and deletes any temporary files created by tmpfile
速求 做c程序 谢谢
程序挺简单,但是要做的事挺多,哈哈~~
下面是用C语言基于你给题目的要求量身打造的,希望对你有所帮助!
#include
#include
#include
#include
#define STU_NUM 100
#define EPS 1e-3
typedef struct Student
{
int number;
char name[20];
int score;
}STU;
static int i = 0;
STU S[STU_NUM];
void load_file()
{
FILE *in;
assert((in=fopen("stuin.txt", "r"))!=NULL);
while (!feof(in))
{
fscanf(in, "%d", &S[i].number);
fscanf(in, "%s", S[i].name);
fscanf(in, "%d", &S[i].score);
i++;
}
fclose(in);
}
double average()
{
int n = i;
int sum = 0;
while (n--)
sum += S[n].score;
return ((double)sum/i);
}
void write_file(const double avg)
{
FILE *out;
assert((out=fopen("stuout.txt", "w"))!=NULL);
int n = 0; //循环变量
int high = S[0].score;
for (n=0; n
<i; n++)
if (S[n].score > high)
high = S[n].score;
//写入成绩最高的学生信息
fprintf(out, "%s", "成绩最高的人的学号、姓名和成绩\n");
for (n=0; n
<i; n++)
if (S[n].score == high)
fprintf(out, "%d\t%s\t%d\n", S[n].number, S[n].name, S[n].score);
//显示平均成绩、高于、低于和等于平均成绩的人数
int ln = 0; //低于平均分人数计数
int hn = 0; //高域平均分人数计数
int en = 0; //等于平均分人数计数
for (n=0; n
<i; n++)
{
if (avg - S[n].score > EPS)
ln++;
else if (avg - S[n].score < EPS)
hn++;
else
en++;
}
fprintf(out, "%s", "平均成绩、高于、低于和等于平均成绩的人数\n");
fprintf(out, "%d\t%d\t%d\n", ln, hn, en);
//显示成绩为优秀(90~100)、良好(80~89)、中等(70~79)、
//及格(60~69)、不及格(0~59)的人数和所占百分比
int sn = 0; //成绩为优秀(90~100)书生人数
int gn = 0; //成绩为良好(80~89)书生人数
int mn = 0; //成绩为中等(70~79)书生人数
int pn = 0; //成绩为及格(60~69)书生人数
int fn = 0; //成绩为不及格(0~59)书生人数
for (n=0; n
<i; n++)
{
if (S[n].score > 90)
sn++;
else if (S[n].score > 80)
gn++;
else if (S[n].score > 70)
mn++;
else if (S[n].score > 60)
pn++;
else
fn++;
}
fprintf(out, "%s", " 显示成绩为优秀、良好、中等、及格、不及格的人数和所占百分比\n");
fprintf(out, "%lf\t%lf\t%lf\t%lf\t%lf\n",
(double)sn/i, (double)gn/i, (double)mn/i, (double)pn/i, (double)fn/i);
fclose(out);
}
int main()
{
load_file();
write_file(average());
return 0;
}
部分截图:
通过这次实训,增加了我学习软件技术的兴趣,虽然还不明确软件技术包含的具体内容,但从C语言这门课程开始,已发现程序设计的乐趣,在学习C语言的过程中也学到了许多计算机应用基础知识,对计算机的机体也有了一个大体的了解。
这次实训是老师给了范例程序,经过自己的改写,实现要求。先做简单的输出,一步步的再做其它图案,在实际操作过程中犯的一些错误还会有意外的收获,感觉实训很有意思。在具体操作中对这学期所学的C语言的理论知识得到巩固,达到实训的基本目的,也发现自己的不足之出,在以后的上机中应更加注意,同时体会到C语言具有的语句简洁,使用灵活,执行效率高等特点。发现上机实训的重要作用,特别是对数组和循环有了深刻的理解。
通过实际操作,学会C语言程序编程的基本步骤、基本方法,开发了自己的逻辑思维能力,培养了分析问题、解决问题的能力。深刻体会到“没有做不到的,只有想不到的”,“团结就是力量”,“实践是检验真理的标准”,“不耻下问”……的寓意。
计时在此希望以后应多进行这样的实训,加长设间,培养学生独立思考问题的能力,提高实际操作水平。
八、参考资料:《C语言程序设计教程》
参考资料:《C语言程序设计教程》1.总结
通过本次的C++课程设计,让我学会了把书本上的知识应用到了实际中来。虽然在这几周中有过挫折和坎坷,有的问题一直到了最后才被解决,但是我认为这未必就不是好事,这样能锻炼我的意志,磨练我的耐心,失败是成功之母,这话一点都没错,没有失败就没有成功。
让我没有失去信心的是关怀我们的老师,当我们有了问题和疑问,老师就很耐心的给予讲解,让我们有了一个良好的学习氛围。
我用fprintf写一个文件,之前是用wb方式打开,一直写一直写,是不是只有在fclose的时候才能把数据写到文件
不一定。
文件流输出有一个Buffer的,为的是减少直接磁盘操作。如果buffer满了就会自动将buffer中的内容输出到磁盘。如果调用fclose时buffer中仍有内容,则这些尚未输出的数据会在文件关闭之前写入文件。
fclose函数只是执行关闭一个文件,你说的一直写,可能是你程序中的循环出问题了
每执行一次fprintf函数就写一次,但是执行完后必须写fclose保存,如果你是用wb方式打开那么他永远只是写第一行,甚至有时后会不写,所以如果要连续写数据的话 用fopen函数打开的时候最好用a+方式打开,这样他就会一行一行的往下写,如果你用一个for语句写那就另当别论了!
如下:
for(int=0;i=??;i++ )
{
fprint(fp,格式,数据)
}
fclose(fp);
如果你是一直在写那么建议你用 a+ fopen