crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> Время жизни переменных, не понимаю одного момента
Litkevich Yuriy
  опции профиля:
сообщение 2.2.2008, 16:24
Сообщение #1


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Переменные созданные внутри функций живут пока мы невышли из фукции, так вроде.
Видел такую вещь:
int* func (foo foovar)
{
int foodim[8];
...
...
...
return foodim;
}

т.е. функция возвращает указатель на масив, который в ней же создан. Но покинув функцию масив прекратит существование и указатель будет показывать в кучу проги, например, может показывать в неосмысленное место.
Я правильно понимаю, т.е. это косячек програмиста, или как-то это иначе работает применительно просто к C++?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
Andrew Selivanov
  опции профиля:
сообщение 4.2.2008, 11:37
Сообщение #2


Участник
**

Группа: Участник
Сообщений: 249
Регистрация: 9.10.2007
Из: Москва
Пользователь №: 3

Спасибо сказали: 15 раз(а)




Репутация:   6  


Цитата(Tonal @ 4.2.2008, 11:16) *
А вот auto_ptr с массивом использовать не надо - убъёть! :)

Litkevich Yuriy Проще всего переделать код на использование vector<int>.
С ним твоя исходная функция будет выглядеть так:
vector<int> func (foo foovar)
{
  vector<int> foodim;
  ...
  return foodim;
}

А использовать её будешь так:
vector<int> pntr;
int  b;
pntr = func(foovar);
b=pntr[2];

Написано об этом очень хорошо у Страуструпа в самом начале "Язык программирования С++ 3ед." - книжка, которую каждый уважающий себя программист на С++ должен прочитать и понять. :)


Мммм... вариант, но мне кажется, что так будет несколько неудобно обрабатывать ошибку (т.е. нулевое значение при возврате), кроме того ( поправьте если ошибаюсь), из временного внутреннего вектора будет лишнее копирование. Мне кажется, корректней будет так:
int func(int foovar, std::vector<int>& data)
{
    if(shit_happens)
   {
      //неуспешное завершение
      return -1;
    }
    data.push_back(val1);
    data.push_back(val2);
    data.push_back(val3);
    //успешное завершение
    return 0;
}

//использование
std::vector<int> data;
int retval = func(3,data);
if(retval)
{
    //что то не так...
}


Ну и typedef не забыть если это конкретный тип, или сделать сразу шаблончик из функции :)

И еще вариант: можно вернуть итератор...
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме


Тема закрытаНачать новую тему
Теги
Нет тегов для показа


2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 18.1.2025, 13:43