C ++ Частный член переменная участника неизвестна в другой функции
-
26-10-2019 - |
Вопрос
У меня есть вопрос новичка о том, как назначить члена класса (Setter). Я привык к сценариям, и в основном там это делается через (в Python)
def set_mymember(mymember):
self.mymeber = mymember
Мой коллега сказал мне «я», а «это» не нужны в C ++ », это существует, и в этом контексте это не неправильно, но это было бы трудно понять для меня, поэтому он сказал, что мне не нужно. Итак, я впервые попытался в соответствии с его советом:
Определение моего класса: - (он должен создать строку запроса SQL)
class Query
{
public:
Query() { }
~Query() { }
void setoptions( std::string qtext_where="", bool qtext_erl=true, std::vector<std::string> kids=std::vector<std::string>() );
Query build_query( );
void set_db_table( std::string db_table );
void set_db_key( std::string db_key );
void set_m_qtext( std::string m_qtext );
void set_foo( std::string foo );
std::string sql();
std::string get_sql_update();
private:
std::string m_db_table; // Tabellenname
std::string m_db_key; // Tabellen-key
std::string m_qtext_where; // add.optionale where clause
std::string m_qtext; // fertiger SELECT
std::string m_sql_update; // fertiger UPDATE
bool m_erl; // nur erledigte waehlen?
std::vector<std::string> m_kids; // Liste von keys zu selecten
};
И вот один из методов сеттера: я называю их заполненной строкой и вектором, дважды проверьте это в этом коде.
void Query::setoptions( string qtext_where, bool erl, vector<string> kids ) {
m_qtext_where = qtext_where;
m_erl = erl;
m_kids = kids;
}
Но когда мое приложение позже звонит query.build_query()
переменные пустые
Query Query::build_query( ) {
cout << "kids size" << m_kids.size() << endl;
cout << "m_qtext_where " << m_qtext_where << endl;
// Query zur auswahl der zu uebertragenden Datensaetze
string sql_update = "UPDATE " + m_db_table;
string qtext = "SELECT * FROM " + m_db_table;
string qtext_order = " ORDER BY " + m_db_key;
(...)
РЕДАКТИРОВАТЬ: Итак, вот часть кода приложения, который вызывает 1.setoptions, и 2.build_query
// read file line by line into vector of strings
vector<string> text_file;
ifstream ifs( input );
string temp;
while( getline( ifs, temp ) ) {
if (temp.substr(0,1) == "#" ) {
cout << "COMMENT: " << temp << endl;
continue;
}
cout << temp << endl;
text_file.push_back( temp );
}
// check: yes, vector has a size = number of lines
cout << "text_file size " << text_file.size() << endl;
// create Query object
Query query = Query();
// set the members, bool erl = true
query.setoptions( "", erl, text_file );
// call 2nd method
q2 = query.build_query();
Решение
Не могу сказать, что происходит без полного кода, но я подозреваю, что вы возвращаете объект запроса из Query.build_Query, который не является полной копией объекта запроса, если это имеет смысл? Можете ли вы включить полный текст build_query?
Кроме того, я бы сделал метод build_query void, и не пытался назначить новый объект запроса обратно второму объекту запроса (Q2) вообще (если вам не нужно, опять же, не может сказать без полного кода) , что-то вроде этого:
void Query::build_query( ) {
std::cout << "kids size" << m_kids.size() << std::endl;
std::cout << "m_qtext_where " << m_qtext_where << std::endl;
}
main
{
...
Query query = Query();
// set the members, bool erl = true
query.setoptions( "", true, text_file );
// call 2nd method
query.build_query();
}
Кроме того, просто будучи педантичным, но, учитывая, что вы предоставляете ARGS по умолчанию для всех вариантов, я был бы склонен к инициализации их в конструкторе, как это:
Query::Query()
: m_qtext_where("")
, qtext_erl(true)
, kids (std::vector<std::string>()
{}
А затем вместо метода SetOptions иметь сеттеры для каждой отдельной переменной:
void setWhere(std::string qtext_where) {m_qtext_where = qtext_where ;}
void setErl(bool query_erl) { m_erl = query_erl; }
void setKids(std::vector<std::string> kids) { m_kids = kids; }
Как вы звоните только тогда, когда вам нужно ..