2

尝试创建指向用户输入的数组(字符串)的指针。

在这里,我在我的类中定义了我的指针和数组:

private:

char userWord[200];     // input word
char * userWordPtr; // Pointer to the beginning of the input word

这是读取信息的函数:

void WordFont::inputWord()
{

    cout << "What word would you like to draw?\n"
         << "The useable characters are: A E I O U Y B C D L M N R S T\n" ;
    cout << "Please enter your word: ";
    cin.get(userWord, 200);
    cin.clear();
    cin.ignore(std::numeric_limits<std::streamsize>::max(), '\n');

    userWordPtr = &userWord;

}

用户输入一个单词,我的代码根据单词的字母做一些事情(长 if-else 阶梯)。但是在将 * Ptr 传递给 if-else 阶梯时,当我增加指针的位置时,我无法让 if-else 阶梯识别空 (/0) 字符。使用“&”来引用 char 数组开头的地址时,我也遇到了错误。我无法弄清楚为什么会出现该错误,以及为什么下面的 if-else 梯子不会退出,直到 'i' 到达内存中具有 '/0' 字符的任何随机位置。如果我做一些像输入'AAA'这样简单的事情,它将远远超过'/0'字符所在的第4个位置。

这是循环:

void WordFont::buildOutputArray(char * Ptr)
{

    length = 0;
    bool switchLooper = true;
    int i = 0;

    do
    {
        if(*Ptr + i == 'a' || *Ptr + i == 'A')
            constructA();
        else if (*Ptr + i == 'e' || *Ptr + i == 'E')
            constructE();
        else if (*Ptr + i == 'i' || *Ptr + i == 'I')
            constructI();
        else if (*Ptr + i == 'o' || *Ptr + i == 'O')
            constructO();
        else if(*Ptr + i == 'u' || *Ptr + i == 'U')
            constructU();
        else if(*Ptr + i == 'b' || *Ptr + i == 'B')
            constructB();
        else if(*Ptr + i == 'c' || *Ptr + i == 'C')
            constructC();
        else if(*Ptr + i == 'd' || *Ptr + i == 'D')
            constructD();
        else if(*Ptr + i == 'l' || *Ptr + i == 'L')
            constructL();
        else if(*Ptr + i == 'm' || *Ptr + i == 'M')
            constructM();
        else if(*Ptr + i == 'n' || *Ptr + i == 'N')
            constructN();
        else if(*Ptr + i == 'r' || *Ptr + i == 'R')
            constructR();
        else if(*Ptr + i == 's' || *Ptr + i == 'S')
            constructS();
        else if(*Ptr + i == 't' || *Ptr + i == 'T')
            constructT();
        else if(*Ptr + i == '\0')
            switchLooper = false;
        i++;
    }while(switchLooper);


}

这可能是一个简单的新手错误,我相信你会注意到很多其他问题,但我非常感谢任何帮助。

谢谢,汤姆

4

2 回答 2

4

用户输入一个单词,我的代码根据单词的字母做一些事情(长 if-else 阶梯)。但是在将 * Ptr 传递给 if-else 阶梯时,当我增加指针的位置时,我无法让 if-else 阶梯识别空 (/0) 字符。

实际上,您正在使用*Ptr + i的是:

  • 取消引用您的Ptr指针(您正在访问 指向的地址处的值Ptr
  • 然后您将添加i到地址中包含的值Ptr

Serge给了你答案,你必须用它*(Ptr + i)来获取那个地址的字符。

在这里,您正在移动“块”的Ptr指针。i

使用“&”来引用 char 数组开头的地址时,我也遇到了错误。我不知道为什么我会收到这个错误,

一个char数组(或其他)“就像”一个指针(有很多不同之处,但我让你很高兴发现它们),所以当你使用str[i]它时,它与*(str + i).

以及为什么下面的 if-else 阶梯不会退出,直到 'i' 到达内存中具有 '/0' 字符的任何随机位置。如果我做一些像输入'AAA'这样简单的事情,它将远远超过'/0'字符所在的第4个位置。

你不应该再有这个问题了。

如果用户输入 200 个字符怎么办?

于 2012-10-31T20:34:57.190 回答
0

虽然您这样做的样式不合适,但解决方法是将全部替换*Ptr + i*(Ptr +i). 我建议你阅读一些关于tolower()stricmp()函数的文档

于 2012-10-21T03:50:43.113 回答