我目前正在处理一个在main()中初始化的字符串,由于某种原因,如果我试图使它成为全局的,它就会变得异常(它会变成一串非字符)。我想知道是否可以在程序中声明一个函数来访问这个变量.函数本身只会在main或main调用的函数中执行,但是编译器在到达main()之前不会看到变量名。
下面是相关代码的精简版本:
string getCommand(int input_pos,string inputstring)
{
int temp_paren=0;
int begin_pos = stdinstring.rfind("(",input_pos);
int len = 0;
while (temp_paren>0 && len < 10)
{
if (stdinstring.substr(begin_pos+len,1)=="(") {temp_paren++;}
if (stdinstring.substr(begin_pos+len,1)==")") {temp_paren--;}
len++;
}
return stdinstring.substr(begin_pos,len);
}
int main(void) {
string stdinstring = "";
}我一直在考虑向前声明,每次使用变量时都会手动将变量传递给函数,甚至创建一个类来保存该变量.解决这个问题最简单的方法是什么?理想情况下,我会有足够的时间把它变成一个全局变量,并找出错误的地方/原因,但我只需要完成这个任务。谢谢你的帮助。
编辑:对于任何感兴趣的人来说:如果我尝试将字符串变成全局字符串,就会发生这种情况。所有的字符都变成"“(不知道,如果这是可见的)
编辑编辑:好的,这是我的代码的更完整的版本。而且,我试着粘贴上面的符号是带有"0 0 0 1“(ASCII字符代码?)的框。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<stdint.h>
//#include<regex>
#define PI M_PI
#define VERBOSE 1
using namespace std;
string stdinstring;
template <class dataclass>
struct linkm {
dataclass value;
linkm *next;
};
template <class dataclass>
class linklist
{
public:
linklist()
{top = NULL;}
~linklist()
{}
void push(dataclass num)
{
linkm<dataclass> *temp = new linkm<dataclass>;
temp->value = num;
temp->next = top;
top = temp;
}
dataclass pop()
{
if (top == NULL)
return 0;
linkm<dataclass> * temp;
temp = top;
dataclass value;
value = temp->value;
top = temp->next;
delete temp;
return value;
}
bool isEmpty()
{
if (top == NULL)
return 1;
return 0;
}
private:
linkm<dataclass> *top;
};
double evaluateExpression(string expression)
{
// sample expression : (* (/ a 1) (+ b 2))
if (expression.substr(0,2)=="(+") {cout << "add found"<<endl;}
else if (expression.substr(0,2)=="(-") {cout << "sub found"<<endl;}
else if (expression.substr(0,2)=="(*") {cout << "mult found"<<endl;}
else if (expression.substr(0,2)=="(/") {cout << "div found"<<endl;}
else if (expression.substr(0,2)=="(sin") {cout << "sin found"<<endl;}
else if (expression.substr(0,2)=="(cos") {cout << "cos found"<<endl;}
else {cout << "Error: invalid operation";} // or is it just a number?
}
string getCommand(int input_pos,string inputstring)
{
int temp_paren=0;
int begin_pos = stdinstring.rfind("(",input_pos);
int len = 0;
while (temp_paren>0 && len < 10)
{
if (stdinstring.substr(begin_pos+len,1)=="(") {temp_paren++;}
if (stdinstring.substr(begin_pos+len,1)==")") {temp_paren--;}
len++;
}
return stdinstring.substr(begin_pos,len);
}
class symContainer
{
public:
string index[500];
float value[500];
int currindex;
symContainer () { currindex = 0 ; }
void add(string id,float invalue)
{
index[currindex] = id;
value[currindex] = invalue;
currindex++;
}
float get(string id)
{
int i=0;
while (i<currindex)
{
if(id==index[i]) {return value[i];}
i++;
}
cout << "Invalid input - an unassigned symbol was requested:" << id << endl;
exit(2);
}
};
struct transform { int type; double arguments[4]; } ;
struct point { double x; double y; } ;
struct drawing { linklist<point> points; linklist<transform> transforms; void applyTransforms(linklist<transform> * trsptr) {} } ;
struct group : public drawing { linklist<int> drawings; void transform(linklist<transform> * trsptr) {} } ;
struct symbol {string index; double value;};
char getNext() { //for the lookaround function. has hard-filters, like replacing newlines/tabs with spaces
char temp = getchar();
if (temp=='\n') {temp=' ';}
if (temp=='\t') {temp=' ';}
return temp;
}
int main(void) {
stdinstring="a";
char command[20], args[2048];
int commandindex=0; //'i' for what command we're on
int stdinsize=2;
double argsArray[8];
bool filled=0;
int parenlevel = 0;
symContainer symbol;
//1 is the character that will be written at the end of each loop. 0 and 2 are 1 char ahead/behind, respectively
char c_lookaround[2];
c_lookaround[0]=NULL;
c_lookaround[1]=getNext();
c_lookaround[2]=getNext();
unsigned long i=0;
bool write=0;
while( c_lookaround[2] != EOF )
{
write=1;
// Lookaround logic goes here. (Clearing duplicate whitespaces, newlines, and the like)
while ( c_lookaround[1]==' ' && c_lookaround[2]==' ' ) {c_lookaround[2]=getNext();}
while (c_lookaround[0]=='(' && c_lookaround[1]==' ' ) {c_lookaround[1]=c_lookaround[2]; c_lookaround[2]=getNext();}
while ( c_lookaround[1]==' ' && c_lookaround[2]==')' ) {c_lookaround[1]=c_lookaround[2]; c_lookaround[2]=getNext();}
while (c_lookaround[0]==NULL && c_lookaround[1]==' ' ) {c_lookaround[1]=c_lookaround[2]; c_lookaround[2]=getNext();}
//while (c_lookaround[0]==')' && c_lookaround[1]==' ' && c_lookaround[2]=='(' ) {c_lookaround[1]=c_lookaround[2]; c_lookaround[2]=getNext();}
//while (c_lookaround[0]==')' && c_lookaround[1]==' ' && c_lookaround[2]=='\0' ) {cout<<"aa";c_lookaround[1]=c_lookaround[2]; c_lookaround[2]=getNext();}
if (c_lookaround[0]=='(' && c_lookaround[1]==':' && c_lookaround[2]=='=')
{
getCommand(i,stdinstring);
}
//Determine current parentheses level
if (c_lookaround[1] == '(') { parenlevel++;}
if (parenlevel==0) {write=0;}
if (c_lookaround[1] == ')') { parenlevel--;}
//Write the character
if (write) {stdinstring.push_back(c_lookaround[1]);}
cout << stdinstring<< endl;
//Advance the tape!
i++;
c_lookaround[0]=c_lookaround[1];
c_lookaround[1]=c_lookaround[2];
c_lookaround[2]=getNext();
}
stdinsize = i;
}发布于 2012-03-12 14:35:37
如果从getCommand()调用main(),则应该能够传递变量。
int main(void) {
string stdinstring = "";
string answer = getCommand(0, stdinstring);
}如果要从其他地方调用getCommand(),则必须将变量从main()传递给该函数,然后传递给getCommand()。而且,您应该能够使它成为全局的,但没有代码,我不知道为什么您不能。
//stdinstring = "a" in the case (how is this set to anything but it?
string getCommand(int input_pos,string inputstring)
{
int temp_paren=0;
int begin_pos = stdinstring.rfind("(",input_pos); //This equals -1
int len = 0;
while (temp_paren>0 && len < 10) //There is no ( so the loop terminates with len=10
{
if (stdinstring.substr(begin_pos+len,1)=="(") {temp_paren++;}
if (stdinstring.substr(begin_pos+len,1)==")") {temp_paren--;}
len++;
}
return stdinstring.substr(begin_pos,len); //returns the first 10 chars of stdinstring which would be "a"
}https://stackoverflow.com/questions/9668985
复制相似问题