1

我有一个类的以下简单代码,并且从c = c ...if 语句开始的每一行都收到一个解析错误。此外,我收到以下错误:

警告:类型与先前的隐式声明不匹配。以前在函数 isUpperCase 中隐式声明 isUpperCase:在“=”标记之前解析错误。isLowerCase 也有类似的错误。

有没有人有任何见解?

#include<stdio.h>
#include<string.h>

#define LOWERCASE_START = 97
#define LOWERCASE_END = 122
#define UPPERCASE_START = 65
#define UPPERCASE_END = 90
#define ALPHABET_LENGTH = 26

void simpleEncryption(char s[]){
    int i;
    for (i=0; i < strlen(s); i++){
        char c = s[i];
        if (isUpperCase(c) == 1){
            c = c - UPPERCASE_START + 1;
            c = c % ALPHABET_LENGTH;
            c = c + UPPERCASE_START;
        } else if (isLowerCase(c) == 1){
            c = c - LOWERCASE_START + 1;
            c = c % ALPHABET_LENGTH;
            c = c + LOWERCASE_START;
        }
        s[i]=c;
    }
}

int isUpperCase(char c) {
    if (c >= UPPERCASE_START && c <= UPPERCASE_END) {
        return 1;   
    } else {
        return 0;
    }
}

int isLowerCase(char c) {
    if (c >= LOWERCASE_START && c <= LOWERCASE_END) {
        return 1;   
    } else {
        return 0;
    }
}
4

2 回答 2

8

您的宏定义不应包含等号,您只需要:

#define LOWERCASE_START 97
#define LOWERCASE_END 122
#define UPPERCASE_START 65
#define UPPERCASE_END 90
#define ALPHABET_LENGTH 26

预处理器的思想相当简单,会盲目地替换= 97成你的 C 来产生像这样的损坏的东西:

c = c - = 97 + 1;

如果你有=#define的 s。

于 2012-04-29T21:57:17.643 回答
6

isUpperCase()并且isLowerCase()在使用之前没有声明:要么为每个添加声明,要么将它们的定义移动到 before simpleEncryption()

正如首先所说的mu 太短,宏定义不正确。要么修复宏,要么改用const int变量:

static const int ALPHABET_LENGTH = 26;
于 2012-04-29T21:56:05.673 回答