:.Blizzard.:
17-11-2009, 10:36
Salve.
Non sò se ricordate il progetto a cui stò lavorando per la tesi, ma è venuto fuori un altro problema legato alla classe StringTokenizer che ho utilizzato per la realizzazione di un piccolo parser per funzioni matematiche.
All'interno del codice della mia classe Parser è presente questa riga per istanziare uno StringTokenizer:
str = new StringTokenizer(formula, "* - / + ( )", true);
In particolare, il costruttore della classe è il seguente:
public StringTokenizer(String str, String delim, boolean returnDelims)
Constructs a string tokenizer for the specified string. All characters in the delim argument are the delimiters for separating tokens.
If the returnDelims flag is true, then the delimiter characters are also returned as tokens. Each delimiter is returned as a string of length one. If the flag is false, the delimiter characters are skipped and only serve as separators between tokens.
Questo significa che se ho formula = "2*x/(1+x)", lo StringTokenizer mi parserizza la stringa in questo modo:
2
*
x
/
(
1
+
x
)
E fin qui niente di strano. E' proprio quello che voglio.
Il problema però nasce nel momento in cui voglio utilizzare un delimitatore non più di un solo carattere, ma di più caratteri (esempio: sin, cos, tan).
Ho provato a ridefinire la mia istanza str in questo modo:
str = new StringTokenizer(formula, "* - / + ( ) sin", true);
E il risultato è che mi considera come delimitatore non l'intera stringa sin, ma le singole lettere. Parserizzando quindi sin(x+2) ottengo infatti:
s
i
n
(
x
+
2
)
E non è quello che voglio, infatti avrei bisogno di un risultato del tipo:
sin
(
x
+
2
)
Esiste un modo per ovviare a questo problema? Oppure a questo punto devo scrivermi un Tokenizer da me?
Non sò se ricordate il progetto a cui stò lavorando per la tesi, ma è venuto fuori un altro problema legato alla classe StringTokenizer che ho utilizzato per la realizzazione di un piccolo parser per funzioni matematiche.
All'interno del codice della mia classe Parser è presente questa riga per istanziare uno StringTokenizer:
str = new StringTokenizer(formula, "* - / + ( )", true);
In particolare, il costruttore della classe è il seguente:
public StringTokenizer(String str, String delim, boolean returnDelims)
Constructs a string tokenizer for the specified string. All characters in the delim argument are the delimiters for separating tokens.
If the returnDelims flag is true, then the delimiter characters are also returned as tokens. Each delimiter is returned as a string of length one. If the flag is false, the delimiter characters are skipped and only serve as separators between tokens.
Questo significa che se ho formula = "2*x/(1+x)", lo StringTokenizer mi parserizza la stringa in questo modo:
2
*
x
/
(
1
+
x
)
E fin qui niente di strano. E' proprio quello che voglio.
Il problema però nasce nel momento in cui voglio utilizzare un delimitatore non più di un solo carattere, ma di più caratteri (esempio: sin, cos, tan).
Ho provato a ridefinire la mia istanza str in questo modo:
str = new StringTokenizer(formula, "* - / + ( ) sin", true);
E il risultato è che mi considera come delimitatore non l'intera stringa sin, ma le singole lettere. Parserizzando quindi sin(x+2) ottengo infatti:
s
i
n
(
x
+
2
)
E non è quello che voglio, infatti avrei bisogno di un risultato del tipo:
sin
(
x
+
2
)
Esiste un modo per ovviare a questo problema? Oppure a questo punto devo scrivermi un Tokenizer da me?