请求版主帮忙删帖
本帖最后由 落单的袜子 于 2023-9-10 18:08 编辑#include<io.h>
#include<direct.h>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAX 256
long total;
int countLines(const char *filename);
void findAllCodes(const char *path);
void findALLFiles(const char *path);
int countLines(const char *filename)
{
FILE *fp;
int count=0;
int temp;
if((fp=fopen(filename,"r"))==NULL)
{
fprintf(stderr,"Can not open the file:%s\n",filename);
return 0;
}
while((temp=fgetc(fp))!=EOF)
{
if(temp=='\n')
{
count++;
}
}
fclose(fp);
return count;
}
void findAllCodes(const char *path)
{
struct _finddate_t fa;
long handle;
char thePath,target;
strcpy(thePath,path);
if((handle=_findfirst(strcat(thePath,"/*.c"),&fa)) != -1L)
{
do
{
sprintf(target,"%s%s",path,fa.name);
total+=countLines(target);
}while(_findnext(handle,&fa)==0;
}
_findclose(handle);
}
void findALLDirs(const char *path)
{
struct _finddate_t fa;
long handle;
char thePath;
strcpy(thePath,path);
if((handle=_findfirst(strcat(thePath,"/*"),&fa))==-1L)
{
fprintf(stderr,The path %s is wrong!\n,path);
return;
}
do
{
if(!strcmp(fa.name,".")||!strcmp(fa.name,".."))
continue;
if(fa.attrib==_A_SUBDIR)
{
sprintf(thePath,"%s%s",path,fa.name);
findAllCodes(thePath);
findALLDirs(thePath);
}
}while(_findnext(handle,&fa)==0);
_findclose(handle);
}
int main()
{
char path=".";
printf("计算中···\n");
findAllCodes(path);
findAllDirs(path);
printf("目前你总共写了 %ld 行代码!\n\n",total);
system("pause");
return 0;
}
第42行报错 第42行代码是:
}while(_findnext(handle,&fa)==0);
错误提示是:
error: expected expression before ‘)’ token
原因是在函数调用中,括号不匹配。将代码修改为:
}while(_findnext(handle,&fa)==0);
即可。 根据你提供的代码,第42行报错的原因是函数名称错误。将 findALLDirs 改为 findALLFiles 即可解决此问题。
修改后的代码如下:
#include <io.h>
#include <direct.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 256
long total;
int countLines(const char *filename);
void findAllCodes(const char *path);
void findALLFiles(const char *path);
int countLines(const char *filename){
FILE *fp;
int count = 0;
int temp;
if ((fp = fopen(filename, "r")) == NULL) {
fprintf(stderr, "Cannot open the file: %s\n", filename);
return 0;
}
while ((temp = fgetc(fp)) != EOF) {
if (temp == '\n') {
count++;
}
}
fclose(fp);
return count;
}
void findAllCodes(const char *path){
struct _finddata_t fa;
long handle;
char thePath;
char target;
strcpy(thePath, path);
if ((handle = _findfirst(strcat(thePath, "/*.c"), &fa)) != -1L) {
do {
sprintf(target, "%s%s", path, fa.name);
total += countLines(target);
} while (_findnext(handle, &fa) == 0);
}
_findclose(handle);
}
void findALLFiles(const char *path){
struct _finddata_t fa;
long handle;
char thePath;
strcpy(thePath, path);
if ((handle = _findfirst(strcat(thePath, "/*"), &fa)) == -1L) {
fprintf(stderr, "The path %s is wrong!\n", path);
return;
}
do {
if (!strcmp(fa.name, ".") || !strcmp(fa.name, "..")) {
continue;
}
if (fa.attrib == _A_SUBDIR) {
sprintf(thePath, "%s%s", path, fa.name);
findAllCodes(thePath);
findALLFiles(thePath);
}
} while (_findnext(handle, &fa) == 0);
_findclose(handle);
}
int main(){
char path = ".";
printf("Calculating...\n");
findAllCodes(path);
findALLFiles(path);
printf("You have written a total of %ld lines of code!\n\n", total);
system("pause");
return 0;
}
希望这个解答对您有帮助。如果您有任何其他问题,请随时提问。
如果问题已经解决,请设置最佳答案 问题分析:
根据给出的代码,第42行报错。请通过分析代码和错误提示,找出错误的原因并进行修正。
问题解决:
根据代码的逻辑,在第42行调用_findnext函数时,发现函数名使用了中文括号而不是英文括号导致编译报错。
将_findnext(handle,&fa)修改为_findnext(handle, &fa)即可修复此问题。
修复后的代码如下:
#include <io.h>
#include <direct.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 256
long total;
int countLines(const char *filename);
void findAllCodes(const char *path);
void findALLDirs(const char *path);
int countLines(const char *filename)
{
FILE *fp;
int count = 0;
int temp;
if ((fp = fopen(filename, "r")) == NULL)
{
fprintf(stderr, "Can not open the file:%s\n", filename);
return 0;
}
while ((temp = fgetc(fp)) != EOF)
{
if (temp == '\n')
{
count++;
}
}
fclose(fp);
return count;
}
void findAllCodes(const char *path)
{
struct _finddata_t fa;
long handle;
char thePath, target;
strcpy(thePath, path);
if ((handle = _findfirst(strcat(thePath, "/*.c"), &fa)) != -1L)
{
do
{
sprintf(target, "%s%s", path, fa.name);
total += countLines(target);
} while (_findnext(handle, &fa) == 0);
}
_findclose(handle);
}
void findALLDirs(const char *path)
{
struct _finddata_t fa;
long handle;
char thePath;
strcpy(thePath, path);
if ((handle = _findfirst(strcat(thePath, "/*"), &fa)) == -1L)
{
fprintf(stderr, "The path %s is wrong!\n", path);
return;
}
do
{
if (!strcmp(fa.name, ".") || !strcmp(fa.name, ".."))
continue;
if (fa.attrib == _A_SUBDIR)
{
sprintf(thePath, "%s%s", path, fa.name);
findAllCodes(thePath);
findALLDirs(thePath);
}
} while (_findnext(handle, &fa) == 0);
_findclose(handle);
}
int main()
{
char path = ".";
printf("计算中···\n");
findAllCodes(path);
findALLDirs(path);
printf("目前你总共写了 %ld 行代码!\n\n", total);
system("pause");
return 0;
}
修复后,错误应该就解决了。如果还有其他问题,请及时提问。
球一个最佳答案谢谢啦!这对我非常重要!{:10_254:}{:10_254:}{:10_254:}
Mike_python小 发表于 2023-9-10 14:52
问题分析:
根据给出的代码,第42行报错。请通过分析代码和错误提示,找出错误的原因并进行修正。
改完了,第43还是报错 落单的袜子 发表于 2023-9-10 12:09
改完了,第43还是报错
根据您提供的代码,第 43 行报错是因为 `strcat()` 函数将两个字符串连接在一起时,可能会导致缓冲区溢出。这是因为 `thePath` 数组的大小为 `MAX`,而连接后的字符串可能超出这个大小。
为了解决这个问题,您可以使用更安全的函数 `strncat()`,它允许您指定连接的最大长度。在这种情况下,您可以修改第 43 行的代码如下:
strncat(thePath, "/*.c", MAX - strlen(thePath) - 1);
这样可以确保连接后的字符串不会超出 `thePath` 数组的大小。
另外,建议您在使用 `strncpy()` 和 `strncat()` 函数时总是指定目标数组的大小,以避免缓冲区溢出。
希望这对您有所帮助!如果还有其他问题,请随时提问。
页:
[1]