Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Vlad1slav
21 / 21 / 5
Регистрация: 16.09.2009
Сообщений: 111
#1

Возврат константной ссылки из функции - C++

30.05.2015, 18:01. Просмотров 928. Ответов 5
Метки нет (Все метки)

Можно ли из функции возвращать константную ссылку?
Есть след. классы:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class A { /*чтото тяжёлое, сотни байт, например массив, или матрица*/ }
 
class B {
  public:
  A f1() { 
    const A& a = f2();
    /*Какие-то вычисления. Просто "return f2();", чтобы без лишних копирований, сделать не удасться.*/
    return a;
  }
  private:
  virtual const A& f2() { 
    A a; 
    return a; 
  }
}
Если f1 и f2 будут возвращать класс A без ссылок, то копирующий конструктор будет вызываться дважды.
Если же f2() будет возвращать константную ссылку, как в примере выше, копирующий конструктор вызывается только при вызове "return a;" в f1(), как и нужно, но при этом, компилятор студии кидает ворнинги C4172.
В общем, можно ли использовать константные ссылки при возврате из метода того же класса, нет ли каких-то подводных камней?
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.05.2015, 18:01
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Возврат константной ссылки из функции (C++):

Возврат ссылки из функции - C++
Изучаю С++, знаю С. Вот такой простенький вопросик есть. В чем вообще разница: class Str { public: Str func() {return...

Создание ссылки и возврат из функции - C++
Есть вот такая функция, возвращает максимальный элемент. template <typename Type> inline const Type max_(const Type& a, const Type& b) ...

Изменение константной ссылки в обычную или указатель - C++
Добрый день, вопрос в названии темы. Как из константной ссылки получить обычную или указатель , чтго бы можно было изменять объект?

Какой должен быть итератор для константной ссылки на вектор? - C++
Есть вектор, он передается в функцию так: #include <iostream> #include <vector> using namespace std; void func(vector<int> arg)...

Как из константной функции вызвать неконстантную? - C++
Здравствуйте. Появилась необходимость сделать такой вот трюк. Например: class B { public: void f(); }; class A { B b;

Возврат ссылки - C++
Задача которая считывает массив и определяет минимальный, макисмальный, первый отрицательный элемент, и их индексы. По заданию надо ее...

5
Croessmah
Ушел
Эксперт CЭксперт С++
13553 / 7704 / 872
Регистрация: 27.09.2012
Сообщений: 19,006
Записей в блоге: 3
Завершенные тесты: 1
30.05.2015, 18:08 #2
Цитата Сообщение от Vlad1slav Посмотреть сообщение
нет ли каких-то подводных камней?
после выхода из f2 локальный объект a будет уничтожен и ссылка станет не валидна.
0
castaway
Эксперт С++
4887 / 3022 / 370
Регистрация: 10.11.2010
Сообщений: 11,080
Записей в блоге: 10
Завершенные тесты: 1
30.05.2015, 18:09 #3
Цитата Сообщение от Vlad1slav Посмотреть сообщение
но при этом, компилятор студии кидает ворнинги C4172.
Как он выглядит?

Цитата Сообщение от Vlad1slav Посмотреть сообщение
В общем, можно ли использовать константные ссылки при возврате из метода того же класса, нет ли каких-то подводных камней?
Можно. Про камни не в курсе.
0
Vlad1slav
21 / 21 / 5
Регистрация: 16.09.2009
Сообщений: 111
30.05.2015, 18:24  [ТС] #4
Croessmah, блин, присмотрелся внимательней, ивправду невалидна, но не совсем так, как вы сказали... После выхода из f2 ссылка осталась валидной, и в f1(), в коде написанном выше, на 8 строке объект ещё существовал, по крайней мере в дебагере отображался корректно, а уже при выходе из f1(), когда вызывался оператор= для класса A, ему параметром прищёл невалидный объект...

castaway, https://msdn.microsoft.com/ru-ru/library/d0ws2xs1.aspx компилятор ругается, что пытаюсь вернуть ссылку на временный объект из функции...

Решил переписать класс B след. образом, хотя как по мне, это слегка кривовато...:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
class B {
  public:
  A f1() {
    A a;
    f2(a);
    /*Какие-то вычисления.*/
    return a;
  }
  private:
  virtual void f2(A & a) {
    /*вычисления над a...*/
    return;
  }
}
0
castaway
Эксперт С++
4887 / 3022 / 370
Регистрация: 10.11.2010
Сообщений: 11,080
Записей в блоге: 10
Завершенные тесты: 1
30.05.2015, 18:27 #5
Цитата Сообщение от Vlad1slav Посмотреть сообщение
Можно ли из функции возвращать константную ссылку?
В целом ответ - можно.
Не заметил что речь идёт о локальном объекте.
0
Croessmah
Ушел
Эксперт CЭксперт С++
13553 / 7704 / 872
Регистрация: 27.09.2012
Сообщений: 19,006
Записей в блоге: 3
Завершенные тесты: 1
30.05.2015, 18:33 #6
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от Vlad1slav Посмотреть сообщение
Croessmah, блин, присмотрелся внимательней, ивправду невалидна, но не совсем так, как вы сказали... После выхода из f2 ссылка осталась валидной, и в f1(), в коде написанном выше, на 8 строке объект ещё существовал, по крайней мере в дебагере отображался корректно
просто Луна так решила в этот раз. Для примера:
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
#include <iostream>
#include <iomanip>
 
class A {
public:
    A() { std::cout << "ctor A" << std::hex << this << std::endl ; }
    A(const A&) { std::cout << "cctor A" << std::hex << this << std::endl ; }
    ~A() { std::cout << "dtor A" << std::hex << this << std::endl ; }
} ;
 
class B {
  public:
  A f1() {
    std::cout << "before f2()" << std::endl ;
    const A& a = f2();
    std::cout << "after f2()" << std::endl ;
    /*Какие-то вычисления. Просто "return f2();", чтобы без лишних копирований, сделать не удасться.*/
    return a;
  }
  private:
  virtual const A& f2() {
    std::cout << "f2() create object a" << std::endl ;
    A a;
    std::cout << "f2() return reference for object a" << std::endl ;
    return a;
  }
} ;
 
 
int main()
{
    B b ;
    b.f1() ;
}
http://ideone.com/fB2mX9
Вывод:
before f2()
f2() create object a
ctor A0xbfbea1ff
f2() return reference for object a
dtor A0xbfbea1ff
after f2()
cctor A0xbfbea1fe
dtor A0xbfbea1fe
1
30.05.2015, 18:33
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.05.2015, 18:33
Привет! Вот еще темы с ответами:

Возврат ссылки - C++
int &amp; function(int); Понятно для чего передают аргументы в функцию как указатели или ссылки.Но зачем функция возвращает ссылку? Чтобы...

Вызов не константной функции, изменяющей свойства класса, из константой . Возможно? - C++
Сразу к делу: #include &lt;QCoreApplication&gt; class Base { public: Base(); virtual int DoSomething(const int&amp; var)...

Возврат ссылки на функцию. - C++
Здравствуйте, можете пожалуйста объяснить чем отличается когда функция создается просто каким то типом, и когда она создается ссылкой на...

Возврат ссылки на локальную переменную - C++
Привет, есть такой код: int*&amp; change(void) { int* x(new int(50)); return x; } int main(void) {


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

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