Проклятие строки и проблемы с манипуляциями с символами - PullRequest
0 голосов
/ 09 мая 2011

Эй, я пытаюсь заставить addstr () в библиотеке pdCurses работать (windows curses) с предпочитаемым классом string, поэтому я сделал функцию следующей функцией string_to_80char (), которая должна принимать строку и возвращатьмассив символов длиной 80 символов (количество символов помещается на одной строке в консоли), поскольку это единственный параметр, который addstr, похоже, принимает ...

Однако при запуске следующего кода я получаю "Just"строка "напечатана, но со случайным символом, таким как '@' или '4', через 50 пробелов после нее .....

ЧТО ЗАДАЧА ??Спасибо за помощь!=)

#include <curses.h>         /* ncurses.h includes stdio.h */  
#include <string> 
#include <vector>
#include <Windows.h>
#include <iostream>
using namespace std;

char* string_to_80char (const string& aString)
{
    int stringSize = aString.size();
    char charArray[90];

    if(stringSize <= 80)
    {
    for(int I = 0; I< stringSize; I++)
        charArray[I] = aString[I];
    for(int I = stringSize; I < sizeof(charArray); I++)
        charArray [I] = ' ';
    return charArray;
    }

    else
    {
    char error[] = {"STRING TOO LONG"};
    return error;
    }
};


int main()
{
    //   A bunch of Curses API set up:
    WINDOW *wnd;

 wnd = initscr(); // curses call to initialize window and curses mode
 cbreak(); // curses call to set no waiting for Enter key
 noecho(); // curses call to set no echoing

 std::string mesg[]= {"Just a string"};     /* message to be appeared on the screen */
 int row,col;               /* to store the number of rows and *
                     * the number of colums of the screen */
 getmaxyx(stdscr,row,col);      /* get the number of rows and columns */
 clear(); // curses call to clear screen, send cursor to position (0,0)

 string test = string_to_80char(mesg[0]);
 char* test2 = string_to_80char(mesg[0]);
 int test3 = test.size();
 int test4 = test.length();
 int test5 = sizeof(test2);
 int test6 = sizeof(test);

 addstr(string_to_80char(mesg[0]));
 refresh();
 getch();


 cout << endl << "Try resizing your window(if possible) and then run this program again";
  system("PAUSE");
 refresh();
  system("PAUSE");

 endwin();
 return 0;
}

1 Ответ

1 голос
/ 14 июля 2011

Вы объявляете charArray внутри функции, а затем возвращаете указатель на нее. За пределами функции эта память находится вне области видимости, и на нее нельзя ссылаться.

char* string_to_80char (const string& aString)
{
  ...
  char charArray[90];
  ...
  return charArray
}

То же самое для строки ошибки.
Вы можете передать charArray в string_to_80char и написать в него.

void string_to_80char (const string& aString, char charArray[])

Конечно, могут быть и другие проблемы.

...