Форум программистов, компьютерный форум CyberForum.ru

C++

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 21, средняя оценка - 4.62
TheAthlete
152 / 152 / 13
Регистрация: 31.08.2010
Сообщений: 535
#1

неявное преобразование в C++ - C++

22.07.2011, 11:42. Просмотров 2570. Ответов 4
Метки нет (Все метки)

Здравствуйте!
При работе с проектом на Qt, компилятор выдал ошибку: "undefined reference to vtable". Порывшись в интернете, нашел статью, где рассказывается, что это все происходит из-за мета-объектного компилятора MOC. Для того, чтобы компилятор не выдавал эту ошибку, необходимо почистить проект и пересобрать. Я все сделал, заработало.

Но в комментарии к статье было высказано мнение, что можно использовать ключевое слово explicit. Почитал, что данное ключевое слово позволяет предотвратить неявное преобразование, осуществляемых конструктором в объект данного класса.

Подскажите, что же делает ключевое слово explicit и что такое неявное преобрезование, применительно к классам. С преобразованием встроенных типов и явным преобразованием типов с помощью ключевых слов static_cast, dynamic_cast, const_cast и reinterpret_cast разобрался, а с данным вопросом не могу разобраться.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.07.2011, 11:42     неявное преобразование в C++
Посмотрите здесь:

Неявное преобразование типов - C++
если я правильно понял, то explicit работает таким образом: class abc { int x; public: abc(int x_):x(x_){} ~abc(){} };

Неявное преобразование типов? - C++
есть класс Vector затем с его помощью создается класс Matrix (матрица - массив векторов) дошла очередь до операции умножения матрицы...

Неявное преобразование переменных - C++
Добрый вечер! Хочу попросить помощи в разъяснении следующей ситуации: есть код: #include <iostream> using namespace std; ...

Неявное преобразование типов - C++
Здравствуйте, определен класс: template<typename T> class Polynomial { public: explicit...

Неявное преобразование типа - C++
Привет. Решаю задачу, не могу решить проблему. Есть класс 'time' и производный от него класс 'interval'. 1 - содержит поля h, m, s,...

Объясните неявное преобразование в этом случае - C++
scoped_ptr p = new Object();То есть "p" неявно преобразовывается в указатель, но как не понятно. Это я встретил просматривая вот это. В...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
oxotnik
1589 / 1066 / 33
Регистрация: 21.08.2008
Сообщений: 4,545
Записей в блоге: 1
22.07.2011, 11:47     неявное преобразование в C++ #2
Простыми словами, это нужно что бы явно указывался родитель объекта.
Т.е.
Код
QSomeObject *someObject = new QSomeObject(someParentObject);
silent_1991
Эксперт С++
4961 / 3037 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
22.07.2011, 12:01     неявное преобразование в C++ #3
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
#include <iostream>
 
// Конструктор класса Foo1 не помечен как explicit, а значит везде, где
// возможно, компилятор вместоприсваивания объекту этого класса целого числа
// будет создавать временную копию и присваивать объекту её. Т.е. f1 = 10 (f1 -
// объект класса Foo1) эквивалентно f1 = Foo1 (10).
class Foo1
{
public:
    Foo1(int foo = 0):
    m_foo(foo)
    {
    }
 
    int get_foo() const
    {
        return m_foo;
    }
 
private:
    int m_foo;
};
 
// Здесь конструктор помечен как explicit, т.е. никаких временных копий при
// присваивании объекту целого числа создаваться не будет, и вообще не будет
// сделано никаких телодвижений, а компилятор просто выдаст ошибко о
// невозможности преобразования
class Foo2
{
public:
    explicit Foo2(int foo = 0):
    m_foo(foo)
    {
    }
 
    int get_foo() const
    {
        return m_foo;
    }
 
private:
    int m_foo;
};
 
int main()
{
    Foo1 f1 = 10; // Эквивалентно Foo1 f1 = Foo1 (10);
    // Foo2 f2 = 10; // Не скомпилируется
 
    std::cout << f1.get_foo() << std::endl;
    // std::cout << f2.get_foo() << std::endl;
 
    f1 = 5; // Эквивалентно f1 = Foo1 (5);
    //f2 = 2;
 
    std::cout << f1.get_foo() << std::endl;
    // std::cout << f2.get_foo() << std::endl;
 
    return 0;
}
Kastaneda
Форумчанин
Эксперт С++
4514 / 2856 / 228
Регистрация: 12.12.2009
Сообщений: 7,251
Записей в блоге: 1
Завершенные тесты: 1
22.07.2011, 12:04     неявное преобразование в C++ #4
Про QT ни чего сказать не могу, ибо не знаю.

По поводу explicit
Цитата Сообщение от TheAthlete Посмотреть сообщение
Почитал, что данное ключевое слово позволяет предотвратить неявное преобразование, осуществляемых конструктором в объект данного класса.
Да, совершенно верно, что это значит в практическом смысле:

C++
1
2
3
4
5
6
7
8
9
10
11
class A{
 public: 
     int a;
     A(int aa):a(aa){};
 };
 
int main(){
    A ob=5;//здесь int = 5 будет преобразовано в A(5)
    std::cout<<ob.a<<std::endl;
    return 0;
}
а так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
class A{
 public: 
     int a;
     explicit A(int aa):a(aa){};
 };
 
int main(){
    A ob=5;//здесь имеем ошибку компиляции, ибо преобразование запрещено explicit 
//теперь нужно явно указывать вызов конструктора
       A ob(5); //так правильно
    std::cout<<ob.a<<std::endl;
    return 0;
}
Добавлено через 32 секунды
опять опоздал...
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.07.2011, 13:38     неявное преобразование в C++
Еще ссылки по теме:

Неявное преобразование типа данных через структуры - C++
Помню что вроде был в С/С++ такой прием, который позволял посмотреть на содержимое переменной одного типа с точки зрения другого типа....

Продемонстровать неявное преобразование типов: из целого в вещественный и обратно - C++
Помогите решить задачи по С++, никак не могу, вся надежда только на вас. 1. Даны вещественные и целые числа. Наглядно продемонстрируйте...

Неявное восходящее преобразование при защищенном/закрытом наследовании - C++
Здравствуйте. Читаю книгу Стивена Прата по C++. Попался непонятный момент: в одной таблице (в таблице 14.1 в 6-й рус. редакции на стр....

Как в VS2008 отключить неявное преобразование встроенных типов? - Visual C++
как отключить неявное преобразование встроенных типов, чтобы компилятор выдавал ошибку, а не предупреждение на это: int varINT; ...


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

Или воспользуйтесь поиском по форуму:
TheAthlete
152 / 152 / 13
Регистрация: 31.08.2010
Сообщений: 535
22.07.2011, 13:38  [ТС]     неявное преобразование в C++ #5
Всем спасибо за комментарии. Разобрался.
Тоже написал простой пример, который описывает данную ситуацию:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
#include <string>
 
class test {
  public:
    explicit test(const std::string &book = "") : tbook(book) {}
    bool same_isbn(const test &rhs) const { return isbn == rhs.isbn; }
  private:
    std::string tbook;
    std::string isbn;
};
 
int main() {
  std::string null_book = "9-999-99999-9";
  test item;
  item.same_isbn(test(null_book));
  return 0;
}
В данном примере, функция same_isbn ожидает в качестве аргумента объект класса test. Если не указать ключевое слово explicit, то можно будет использовать следующую конструкцию:

C++
1
item.same_isbn(null_book);
В данном случае, чтобы создать новый объект класса test из строки null_book, компилятор использует конструктор класса test, который получает объект класса string. Этот вновь созданный (временный) объект класса test и передается функции same_isbn().

Если указать ключевое слово explicit. То данная конструкция вызовет ошибку компиляции. Для этого необходимо явно указать объект класса test:

C++
1
item.same_isbn(test(null_book));
Объявление конструктора явным запрещает только неявное его применение. Для явного создания временного объекта применим любой конструктор
Yandex
Объявления
22.07.2011, 13:38     неявное преобразование в C++
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru