Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/21: Рейтинг темы: голосов - 21, средняя оценка - 4.62
0 / 0 / 0
Регистрация: 24.04.2008
Сообщений: 10

_fastcall::TForm2(TComponent *)' is not a member of 'TForm2

24.04.2008, 23:50. Показов 4329. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Помогите новичку.
Такя проблема, изначально программа написана под консоль, в консоли работает нормально, хотел перевести в Windows но, выдает ошибку при компиляции, вот код cpp файла, описания исп. ф-й лежат в .h файле в разделе public:.

Выдает ошибку при компиляции:
Unit2.cpp(17):E2316'_fastcall::TForm2(TC omponent *)' is not a member of 'TForm2'

Вообще не знаю что делать, понятно, что _fastcall::TForm2(TComponent *) не является элементом 'TForm2', но вот как это исправить не понимаю.
Поиск результатов не дал, юзаю Borland Developer Studio 2006
Программа из книги Фридман C++ архив программ
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
#include <vcl.h> 
#pragma hdrstop 
 
#include "Unit2.h" 
//--------------------------------------------------------------------------- 
#pragma package(smart_init) 
#pragma resource "*.dfm" 
#include <iostream> 
#include <cctype> 
#include <cstring> 
TForm2 *Form2; 
//--------------------------------------------------------------------------- 
__fastcall TForm2::TForm2(TComponent* Owner) 
    :TForm(Owner) 
{ 
//Конструктор 
template <class PType> parser<PType>::parser() 
{ 
    int i; 
    exp_ptr = 0; 
    for(i=0; i<NUMVARS; i++) 
    { 
    vars[i] = (PType) 0; 
    } 
 
} 
//Входная точка анализатора 
template <class PType> PType parser<PType>::eval_exp(char *exp) 
{ 
    PType result; 
    exp_ptr = exp; 
    get_token(); 
    if(!*token) 
    { 
    serror(NOEXP); //Выроженние отсуцтвует 
    return (PType) 0; 
    } 
    eval_exp1(result); 
    if(*token) serror(SERROR); //Последняя лексема должна быть нулевой 
    return result; 
} 
//Обработать присваивание 
template <class PType> void parser<PType>::eval_exp1(PType &result) 
{ 
    int slot; 
    typesT ttok_type; 
    char temp_token[80]; 
    if(tok_type == VARIABLE) 
    { 
         //Сохранить старую лексему 
         strcpy(temp_token, token); 
         ttok_type = tok_type; 
         //Вычислить индекс переменной 
         slot =  toupper(*token) - 'A'; 
         get_token(); 
         if(*token != '=')// Не присваивание 
         { 
            putback(); // Возвратить текущую лексему 
            // Восстановить старую лексему 
            strcpy(token, temp_token); 
            tok_type = ttok_type; 
         } 
         else 
         { 
             get_token(); // Получить следующую часть выражения 
             eval_exp2(result); 
             vars[slot] = result; 
             return; 
         } 
    } 
    eval_exp2(result); 
} 
//Сложить или вычесть два члена 
template <class PType> void parser<PType>::eval_exp2(PType &result) 
{ 
    register char op; 
    PType temp; 
    eval_exp3(result); 
    while((op = *token) == '+' || op == '-') 
    { 
        get_token(); 
        eval_exp3(temp); 
        switch(op) 
        { 
            case '-': 
            result = result - temp; 
            break; 
            case '+': 
            result = result + temp; 
            break; 
        } 
    } 
} 
//Перемножить или поделить два сомножителя 
template <class PType> void parser<PType>::eval_exp3(PType &result) 
{ 
  register char op; 
  PType temp; 
  eval_exp4(result); 
  while((op = *token) == '*' || op == '/' || op == '%') 
  { 
      get_token(); 
      eval_exp4(temp); 
      switch(op) 
      { 
          case '*': 
          result = result * temp; 
          break; 
          case '/': 
          if(!temp) serror(DIVZERO); 
          else result = result / temp; 
          break; 
          case '%': 
          result = (int) result % (int) temp; 
          break; 
      } 
  } 
} 
//Обработка степени 
template <class PType> void parser<PType>::eval_exp4(PType &result) 
{ 
    PType temp, ex; 
    register int t; 
    eval_exp5(result); 
    if(*token == '^') 
    { 
        get_token(); 
        eval_exp4(temp); 
        ex = result; 
        if(temp == (PType) 0) 
        { 
            result = (PType) 1; 
            return; 
        } 
        for(t=(int)temp-1; t>0; --t) 
        { 
            result = result * ex; 
        } 
    } 
} 
//Оценить унарный + или - 
template <class PType> void parser<PType>::eval_exp5(PType &result) 
{ 
    register char op; 
    op = 0; 
    if((tok_type == OPERATOR) && *token == '+' || *token == '-') 
    { 
        op = *token; 
        get_token(); 
    } 
    eval_exp6(result); 
    if(op == '-') result = -result; 
} 
//Обработка вырожения в скобках 
template <class PType> void parser<PType>::eval_exp6(PType &result) 
{ 
    if((*token == '(')) 
    { 
        get_token(); 
        eval_exp2(result); 
        if(*token != ')') 
        { 
            serror(PARENS); 
        } 
        get_token(); 
    } 
    else atom(result); 
} 
//Получить значение числа или переменной 
template <class PType> void parser<PType>::atom(PType &result) 
{ 
    switch(tok_type) 
    { 
        case VARIABLE: 
        result = find_var(token); 
        get_token(); 
        case NUMBER: 
        result = (PType) atof(token); 
        get_token(); 
        return; 
        default: 
        serror(SERROR); 
    } 
} 
//Возвратить лексему во входной поток 
template <class PType> void parser<PType>::putback() 
{ 
    char *t; 
    t = token; 
    for(; *t; t++) 
    { 
        exp_ptr--; 
    } 
}  
//Сообщить о синтаксической ошибке 
template <class PType>void parser<PType>::serror(errorsT error) 
{ 
   static char *e[]= {"Syntax error", "Unbalanced Parentheses", 
   "No expression Present", "Division by zero"}; 
   cout << e[error] << endl; 
} 
//Извлеч следующую лексему 
template <class PType> void parser<PType>::get_token() 
{ 
    register char *temp; 
    tok_type = UNDEFTOK; // неизвестный тип 
    temp = token; 
    *temp = '\0'; 
    if(!*exp_ptr) return; //Конец выражения 
    while(isspace(*exp_ptr))//Пропустить пробелы 
    { 
        ++exp_ptr; 
    } 
    if(strchr("+-*/%^=()", *exp_ptr)) 
    { 
        tok_type = OPERATOR; 
        *temp++ = *exp_ptr++;//Перейти к следующему символу 
    } 
 
    else if(isalpha(*exp_ptr)) 
    { 
    while(!isdelim(*exp_ptr)) 
    {*temp++ = *exp_ptr++;} 
    tok_type = VARIABLE; 
    } 
 
    else if(isdigit(*exp_ptr)) 
    { 
        while(!isdelim(*exp_ptr)) { *temp++ = *exp_ptr++; } 
        tok_type = NUMBER; 
    } 
    *temp = '\0'; 
} 
//Возвратить true, если с - разделитель 
template <class PType> bool parser<PType>::isdelim(char c) 
{ 
          if(strchr(" +-/*%^=()", c) || c == 9 || c == '\r' || c == 0) 
    { return true; } 
    return false; 
} 
//Возвратить значение переменной 
template <class PType> PType parser<PType>::find_var(char *s) 
{ 
    if(!isalpha(*s)) 
    { 
        serror(SERROR); 
        return (PType) 0; 
    } 
    return vars[toupper(*token) - 'A']; 
} 
 
 
    __fastcall TForm2(TComponent* Owner); 
};
Вот код Unit2.h:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
//#ifndef Unit2H 
#define Unit2H 
//--------------------------------------------------------------------------- 
#include <Classes.hpp> 
#include <Controls.hpp> 
#include <StdCtrls.hpp> 
#include <Forms.hpp> 
#include <iostream> 
#include <cctype> 
#include <cstring> 
using  namespace std; 
//--------------------------------------------------------------------------- 
class TForm2 : public TForm 
{ 
__published:    // IDE-managed Components 
    TButton *Button1; 
    TEdit *Edit1; 
    TLabel *Label1; 
private:    // User declarations 
public: template <class PType> 
class parser { 
static const int NUMVARS = 26; 
enum typesT {UNDEFTOK, OPERATOR, NUMBER, VARIABLE}; 
enum errorsT {SERROR, PARENS, NOEXP, DIVZERO}; 
 
char *exp_ptr; //Указатель на вырожение 
char token[80]; //содержится текущая лексема 
typesT tok_type; //Тип лексемы 
PType vars[NUMVARS];//Хранит значения переменных 
 
void eval_exp1(PType &result); 
void eval_exp2(PType &result); 
void eval_exp3(PType &result); 
void eval_exp4(PType &result); 
void eval_exp5(PType &result); 
void eval_exp6(PType &result); 
void atom(PType &result); 
void get_token(); 
void putback(); // Возвратить текушую лексему 
void serror(errorsT error); 
PType find_var(char *s); 
bool isdelim(char c); 
public: 
parser(); 
PType eval_exp(char *exp); 
}; 
 
 
};
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.04.2008, 23:50
Ответы с готовыми решениями:

Перемещение формы - E2316 'Image1MouseDown is not a member of 'TForm2'
Нашел данный код, который позволяет перемещать форму, перетаскивая картинку: void __fastcall TForm2::Image1MouseDown(TObject *Sender,...

Создание массива указателей на методы класса TForm2
Здравствуйте! Разрабатываю приложение, состоящие из трех форм. Первая форма представляет собой меню из которого вызывается вторая или...

Вызывается 2 раза void __fastcall TForm2::ListBox1Click(TObject *Sender)
Помогите. В чём дело? Функция void __fastcall TForm2::ListBox1Click(TObject *Sender) сробатывает два раза подрят! Ставлю точку останова и...

14
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
25.04.2008, 09:56
а что тут сложно, в хидере пропиши прототип конструктора формы да и все... __fastcall TForm2(TComponent* Owner);
0
0 / 0 / 0
Регистрация: 24.04.2008
Сообщений: 10
25.04.2008, 19:20  [ТС]
Не совсем понятно, прототип получается на строчку выше самого конструктора получается
C++
1
2
3
4
__fastcall TForm2(TComponent* Owner);
__fastcall TForm2::TForm2(TComponent* Owner)
    :TForm(Owner)
{
Все равно выдает ошибку
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
29.04.2008, 09:26
ты не там вставил, этот прототип должен находится в описании класса в разделе public...
0
1 / 1 / 0
Регистрация: 01.04.2012
Сообщений: 15
30.04.2008, 14:19
Стоп. Вопрос первый: у тебя реализация всех тех методов стоит в конструкторе формы? Если да, то вытащи их оттуда, и напиши реализацию в h-файле. А если нет, то ты забыл закрывающую скобку поставить в конструкторе формы.
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
30.04.2008, 15:05
Цитата Сообщение от Матвей Посмотреть сообщение
Стоп. Вопрос первый: у тебя реализация всех тех методов стоит в конструкторе формы? Если да, то вытащи их оттуда, и напиши реализацию в h-файле. А если нет, то ты забыл закрывающую скобку поставить в конструкторе формы.

я его сырцы тоже долго изучал, но видать так можно, хотя никогда такого не видел...
0
0 / 0 / 0
Регистрация: 24.04.2008
Сообщений: 10
06.05.2008, 18:29  [ТС]
Матвей
Переделал как вы сказали, осталась только одна ошибка, все та же
_fastcall::TForm2(TComponent *)' is not a member of 'TForm2
вот переделанный код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <vcl.h>
#pragma hdrstop
 
#include "Unit2.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
#include <iostream>
#include <cctype>
#include <cstring>
TForm2 *Form2;
//---------------------------------------------------------------------------
__fastcall TForm2::TForm2(TComponent* Owner)
    :TForm(Owner)
{
//  __fastcall TForm2(TComponent* Owner);
};
 
//---------------------------------------------------------------------------
 
 
void __fastcall TForm2::Button1Click(TObject *Sender)
{
char expstr[80];
parser ob;
strcpy(expstr, LabeledEdit1->Text);
LabeledEdit1->Text = ob.eval_exp(expstr);
}
. Фаил
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
//#ifndef Unit2H
#define Unit2H
//---------------------------------------------------------------------------
#include <Classes.hpp>
#include <Controls.hpp>
#include <StdCtrls.hpp>
#include <Forms.hpp>
#include <ExtCtrls.hpp>
#include <iostream>
#include <cctype>
#include <cstring>
using  namespace std;
//---------------------------------------------------------------------------
class TForm2 : public TForm
{
__published:    // IDE-managed Components
    TButton *Button1;
    TLabeledEdit *LabeledEdit1;
    void __fastcall Button1Click(TObject *Sender);
private:    // User declarations
public:
class parser {
static const int NUMVARS = 26;
enum typesT {UNDEFTOK, OPERATOR, NUMBER, VARIABLE};
enum errorsT {SERROR, PARENS, NOEXP, DIVZERO};
public:
char *exp_ptr; //Указатель на вырожение
char token[80]; //содержится текущая лексема
typesT tok_type; //Тип лексемы
double vars[NUMVARS];//Хранит значения переменных
//Конструктор
parser::parser()
{
    int i;
    exp_ptr = 0;
    for(i=0; i<NUMVARS; i++)
    {
    vars[i] = 0.0;
    }
}
//Входная точка анализатора
double parser::eval_exp(char *exp)
{
    double result;
    exp_ptr = exp;
    get_token();
    if(!*token)
    {
    serror(NOEXP); //Выроженние отсуцтвует
    return (double) 0;
    }
    eval_exp1(result);
    if(*token) serror(SERROR); //Последняя лексема должна быть нулевой
    return result;
}
//Обработать присваивание
void parser::eval_exp1(double &result)
{
    int slot;
    typesT ttok_type;
    char temp_token[80];
    if(tok_type == VARIABLE)
    {
         //Сохранить старую лексему
         strcpy(temp_token, token);
         ttok_type = tok_type;
         //Вычислить индекс переменной
         slot =  toupper(*token) - 'A';
         get_token();
         if(*token != '=')// Не присваивание
         {
            putback(); // Возвратить текущую лексему
            // Восстановить старую лексему
            strcpy(token, temp_token);
            tok_type = ttok_type;
         }
         else
         {
             get_token(); // Получить следующую часть выражения
             eval_exp2(result);
             vars[slot] = result;
             return;
         }
    }
    eval_exp2(result);
}
//Сложить или вычесть два члена
void parser::eval_exp2(double &result)
{
    register char op;
    double temp;
    eval_exp3(result);
    while((op = *token) == '+' || op == '-')
    {
        get_token();
        eval_exp3(temp);
        switch(op)
        {
            case '-':
            result = result - temp;
            break;
            case '+':
            result = result + temp;
            break;
        }
    }
}
//Перемножить или поделить два сомножителя
void parser::eval_exp3(double &result)
{
  register char op;
  double temp;
  eval_exp4(result);
  while((op = *token) == '*' || op == '/' || op == '%')
  {
      get_token();
      eval_exp4(temp);
      switch(op)
      {
          case '*':
          result = result * temp;
          break;
          case '/':
          if(!temp) serror(DIVZERO);
          else result = result / temp;
          break;
          case '%':
          result = (int) result % (int) temp;
          break;
      }
  }
}
//Обработка степени
void parser::eval_exp4(double &result)
{
    double temp, ex;
    register int t;
    eval_exp5(result);
    if(*token == '^')
    {
        get_token();
        eval_exp4(temp);
        ex = result;
        if(temp == (double) 0)
        {
            result = (double) 1;
            return;
        }
        for(t=(int)temp-1; t>0; --t)
        {
            result = result * ex;
        }
    }
}
//Оценить унарный + или -
void parser::eval_exp5(double &result)
{
    register char op;
    op = 0;
    if((tok_type == OPERATOR) && *token == '+' || *token == '-')
    {
        op = *token;
        get_token();
    }
    eval_exp6(result);
    if(op == '-') result = -result;
}
//Обработка вырожения в скобках
void parser::eval_exp6(double &result)
{
    if((*token == '('))
    {
        get_token();
        eval_exp2(result);
        if(*token != ')')
        {
            serror(PARENS);
        }
        get_token();
    }
    else atom(result);
}
//Получить значение числа или переменной
void parser::atom(double &result)
{
    switch(tok_type)
    {
        case VARIABLE:
        result = find_var(token);
        get_token();
        case NUMBER:
        result = (double) atof(token);
        get_token();
        return;
        default:
        serror(SERROR);
    }
}
//Возвратить лексему во входной поток
void parser::putback()
{
    char *t;
    t = token;
    for(; *t; t++)
    {
        exp_ptr--;
    }
} 
//Сообщить о синтаксической ошибке
void parser::serror(errorsT error)
{
   static char *e[]= {"Syntax error", "Unbalanced Parentheses",
   "No expression Present", "Division by zero"};
   cout << e[error] << endl;
}
//Извлеч следующую лексему
void parser::get_token()
{
    register char *temp;
    tok_type = UNDEFTOK; // неизвестный тип
    temp = token;
    *temp = '\0';
    if(!*exp_ptr) return; //Конец выражения
    while(isspace(*exp_ptr))//Пропустить пробелы
    {
        ++exp_ptr;
    }
    if(strchr("+-*/%^=()", *exp_ptr))
    {
        tok_type = OPERATOR;
        *temp++ = *exp_ptr++;//Перейти к следующему символу
    }
 
    else if(isalpha(*exp_ptr))
    {
    while(!isdelim(*exp_ptr))
    {*temp++ = *exp_ptr++;}
    tok_type = VARIABLE;
    }
 
    else if(isdigit(*exp_ptr))
    {
        while(!isdelim(*exp_ptr)) { *temp++ = *exp_ptr++; }
        tok_type = NUMBER;
    }
    *temp = '\0';
}
//Возвратить true, если с - разделитель
bool parser::isdelim(char c)
{
    if(strchr(" +-*/%^=()", c) || c == 9 || c == '\r' || c == 0)
    { return true; }
    return false;
}
//Возвратить значение переменной
double parser::find_var(char *s)
{
    if(!isalpha(*s))
    {
        serror(SERROR);
        return (double) 0;
    }
    return vars[toupper(*token) - 'A'];
}
};
 
 
};
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
06.05.2008, 18:32
компилятор говорит, что нет у тебя такого метода, чтобы все работало, надо прототип не в реализации конструктора писать, а раздел public в h-файле...
0
0 / 0 / 0
Регистрация: 24.04.2008
Сообщений: 10
06.05.2008, 22:33  [ТС]
WooDooMan666
Большое Спасибо переместил в h/ файл, ошибка исчезла.
Зато появилась какаято-глупая ошибка, немогу из LabeledEdit1->Text передать текст в массив expstr пишет
C++
1
2
3
4
5
6
7
8
9
void __fastcall TForm2::Button1Click(TObject *Sender)
{
void __fastcall TForm2::Button1Click(TObject *Sender)
{
char expstr[80];
parser ob;
expstr[80] = LabeledEdit1->Text;
LabeledEdit1->Text = ob.eval_exp(expstr);
}
Пишет Cannot convert 'AnsiString' to 'char'
Функции StrToChar нету, странно вроде между символом char и строкой string не большая разница
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
06.05.2008, 22:48
попробуй так:
Code
1
strcpy(expstr[80],LabeledEdit1->Text.c_str());
0
0 / 0 / 0
Регистрация: 24.04.2008
Сообщений: 10
08.05.2008, 19:04  [ТС]
Попробовал
Code
1
2
3
4
char expstr[80];
parser ob;
strcpy(expstr[80],LabeledEdit1->Text.c_str());
LabeledEdit1->Text = ob.eval_exp(expstr);
пишет
Cannot convert 'int' to 'char *'
Type mismatch in parameter '__dest'(wanted 'char *', got 'char')
Не совсем ясно что делает .c_str()
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
08.05.2008, 19:06
объяви так:
Code
1
2
3
4
char expstr* = (char*) malloc(LabeledEdit1->Text.Length());
parser ob;
strcpy(expstr, LabeledEdit1->Text.c_str());
LabeledEdit1->Text = ob.eval_exp(expstr);
а так писать нельзя - strcpy(expstr[80],LabeledEdit1->Text.c_str());
надо strcpy(expstr,LabeledEdit1->Text.c_str());
c_str() - преобразует AnsiString в char*
0
0 / 0 / 0
Регистрация: 24.04.2008
Сообщений: 10
09.05.2008, 12:21  [ТС]
Сделал как сказали
C++
1
2
3
4
5
6
7
void __fastcall TForm2::Button1Click(TObject *Sender)
{
char expstr* = (char*) malloc(LabeledEdit1->Text.Length()); //27
parser ob;                                 //28
strcpy(expstr, LabeledEdit1->Text.c_str());             //29
LabeledEdit1->Text = ob.eval_exp(expstr);             //30
}
Выдает след. ошибки:
27 - Declaration syntax error
29 - Cannot convert 'int' to 'char *'
29 - Type mismatch in parameter '__dest' (wanted 'char *', got 'Char')
30 - Cannot convert 'int' to 'char *'
30 - Type mismatch in parameter '__dest' (wanted 'char *', got 'Char')

Ошибки повторились по 2 раза. А * в expstr с переди пишут или с зади или без разницы?
Непонятно что делает ф-я malloc.

Добавлено через 14 часов 58 минут
Написал *expstr заместо expstr* и все заработало!
WooDooMan666 Спасибо за помошь
0
 Аватар для dioxidin
132 / 99 / 11
Регистрация: 21.11.2007
Сообщений: 544
12.05.2008, 10:50
Конечно спереди звезду... (куда и солдатам лепят)
Опечатка была там.
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
12.05.2008, 10:51
ну обшибся я, каюсь...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.05.2008, 10:51
Помогаю со студенческими работами здесь

E2316 '_fastcall TForm1::TForml(TComponent *)' is not a member of 'TForm1'
Не могу понять как исправить ошибку, помогите пожалуйста. Ошибка: Unit1.cpp(12): E2316 '_fastcall TForm1::TForml(TComponent *)' is not a...

Вывод из TForm2 в TForm1
Вот что нужно делаю TForm2 и на нем Edit2 , как сделать чтобы в TForm1 можно было бы работать с edit2 ??? вот первая попытка: ...

fastcall & inline
Здравствуйте, я бы хотел спросить когда нужно использовать эти комманды. Когда использовать inline я примерно знаю: когда функция...

Соглашение вызова fastcall. Assembler
Здравствуйте! Имеется код арифметических операций, нужно применить к нему соглашение вызова fastcall. Помогите, пожалуйста, понятия не имею...

Куда девается 3 параметр при fastcall
Подскажите, пожайлуста, куда девается 3 параметр при fastcall. Не могу его найти не в стеке, ни в , ни в


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru