Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Vlad1slav
21 / 21 / 7
Регистрация: 16.09.2009
Сообщений: 111
#1

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

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

Можно ли из функции возвращать константную ссылку?
Есть след. классы:
http://www.cyberforum.ru/cpp-beginners/thread118900.html
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++):

Создание ссылки и возврат из функции
Есть вот такая функция, возвращает максимальный элемент. template <typename...

Возврат ссылки на указатель из функции
#include <iostream> int*& getPtrRef(int*& ref) { int*& cpy = ref; ...

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

Изменение константной ссылки в обычную или указатель
Добрый день, вопрос в названии темы. Как из константной ссылки получить...

Какой должен быть итератор для константной ссылки на вектор?
Есть вектор, он передается в функцию так: #include <iostream> #include...

5
Croessmah
++Ͻ
14146 / 8071 / 1512
Регистрация: 27.09.2012
Сообщений: 19,907
Записей в блоге: 3
Завершенные тесты: 1
30.05.2015, 18:08 #2
Цитата Сообщение от Vlad1slav Посмотреть сообщение
нет ли каких-то подводных камней?
после выхода из f2 локальный объект a будет уничтожен и ссылка станет не валидна.
0
castaway
Эксперт С++
4926 / 3033 / 453
Регистрация: 10.11.2010
Сообщений: 11,089
Записей в блоге: 10
Завершенные тесты: 1
30.05.2015, 18:09 #3
Цитата Сообщение от Vlad1slav Посмотреть сообщение
но при этом, компилятор студии кидает ворнинги C4172.
Как он выглядит?

Цитата Сообщение от Vlad1slav Посмотреть сообщение
В общем, можно ли использовать константные ссылки при возврате из метода того же класса, нет ли каких-то подводных камней?
Можно. Про камни не в курсе.
0
Vlad1slav
21 / 21 / 7
Регистрация: 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
Эксперт С++
4926 / 3033 / 453
Регистрация: 10.11.2010
Сообщений: 11,089
Записей в блоге: 10
Завершенные тесты: 1
30.05.2015, 18:27 #5
Цитата Сообщение от Vlad1slav Посмотреть сообщение
Можно ли из функции возвращать константную ссылку?
В целом ответ - можно.
Не заметил что речь идёт о локальном объекте.
0
Croessmah
++Ͻ
14146 / 8071 / 1512
Регистрация: 27.09.2012
Сообщений: 19,907
Записей в блоге: 3
Завершенные тесты: 1
30.05.2015, 18:33 #6
Лучший ответ Сообщение было отмечено Vlad1slav как решение

Решение

Цитата Сообщение от 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
Привет! Вот еще темы с решениями:

Как из константной функции вызвать неконстантную?
Здравствуйте. Появилась необходимость сделать такой вот трюк. Например: class...

Вызов константной функции для неконстантного объекта класса
Доброго дня! Имея класс с двумя перегруженными на основании константности...

Возврат ссылки
Задача которая считывает массив и определяет минимальный, макисмальный, первый...

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


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

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

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