Модераторы: skyboy, MoLeX, Aliance, ksnk
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как правильно писать фанкции? 
:(
    Опции темы
diktator
Дата 27.5.2010, 05:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 81
Регистрация: 27.5.2010

Репутация: нет
Всего: нет



Здравствуйте, подскажите как правильно писать функции. А именно интересуют 2 вопроса по return.

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

Код

function getContent($url)
{

// если урл не существует
$contents=file_get_contents($url); 
return $contents;
}

getContent();



2 вопрос стоит ли так делать вывод, тоже с точки зрения правильности.

Код

function getId($i)
{

while($i<10) {

if($i==6) {
return $contents;
}

$i++;

}

}

getId(3);



PM MAIL   Вверх
ksnk
Дата 27.5.2010, 08:45 (ссылка) |    (голосов:3) Загрузка ... Загрузка ... Быстрая цитата Цитата


прохожий
****


Профиль
Группа: Комодератор
Сообщений: 6855
Регистрация: 13.4.2007
Где: СПб

Репутация: 96
Всего: 386



функции - это кирпичи из которых строится программа. Кирпичи бывают разные - огнеупорные, облицовочные, теплоизоляцтонные... в каждом конкретном случае, поведение и структура кирпича соответствует решаемой строителем задаче...

Можно возвращать пустую строку, можно вызывать null, можно вызываать исключение, можно ничего не делать и тогда сам php скажет, что случилась ошибка и файл ненайден. Зависит от используемой в приложении логики работы...


--------------------
Человеку свойственно ошибаться, программисту свойственно ошибаться профессионально ! user posted image
PM MAIL WWW Skype   Вверх
diktator
Дата 27.5.2010, 15:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 81
Регистрация: 27.5.2010

Репутация: нет
Всего: нет



ksnk, я имею ввиду как будет правильнее с точки зрения оформления кода чтобы дальше проблемы не возникли, к примеру если до конца не известно что будет нужно. 
PM MAIL   Вверх
Novich
Дата 27.5.2010, 19:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 21
Регистрация: 16.4.2004

Репутация: нет
Всего: нет



Каждый программист сам решает как все это оформлять, исходя из текущей задачи. 

Например, если ваша функция возвращает только положительные числовые значения, то в качестве кодов ошибок можно выбрать цифры с минусом. Функция вернула -1, значит произошла такая-то ошибка, вернула -2 - значит другая. Если функция возвращает текстовое значение, значит можно возвращать null, если произошла ошибка. А можно вообще возвращать массив, одно из значений которого будет код статуса - $result['status'], а другое - сам результат $result['result'].

Чтобы не забыть над функцией пишите комментарий, что делает функция, что должно передаваться в параметрах, в каких форматах, какие ограничения, в каком формате возвращается значение, какие могут быть ошибки, как проверять результат на наличие ошибок. Посмотрите примеры как пишут функции профи.

Это сообщение отредактировал(а) Novich - 27.5.2010, 19:57
PM   Вверх
IgorIV
Дата 27.5.2010, 20:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 642
Регистрация: 7.9.2009

Репутация: 2
Всего: 8



А я поодержу ТС в вопросе smile
Разовьем пример.
Вариант первый 
Код

function getContent($url)
{
     $contents=file_get_contents($url); 
     return $contents;
}
$file = '/tmp/text';
if (file_exists($file))
{
    echo getContent($temp);



Вариант второй

Код

function getContent($url)
{
    if (file_exists($file))
    { 
        $contents=file_get_contents($url); 
        return $contents;  
    } 
}
$file = '/tmp/text';

echo getContent($file);


Какой вариант вы бы выбрали сами?
PM MAIL   Вверх
ksnk
Дата 27.5.2010, 21:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прохожий
****


Профиль
Группа: Комодератор
Сообщений: 6855
Регистрация: 13.4.2007
Где: СПб

Репутация: 96
Всего: 386



Вот такой вариант - однозначно лучше...
Код

file_get_content($fn);

Мне совершенно непонятно, ради какой красоты понадобится может оборачивать стандартную функцию в отдельную обертку. Но если хочется, можно вот так
Код

function getContent($fn){
  return file_get_content($fn);
}


сли почитать инструкцию, то окажется, что если файл не найден, функция выдаст FALSE и такая проверка даст нам заодно и проверку на существование(читабельность) файла.
Код

$res=getContent('myfile.txt');
if($res!==FALSE){
   // $res - содержимое файла...
}




--------------------
Человеку свойственно ошибаться, программисту свойственно ошибаться профессионально ! user posted image
PM MAIL WWW Skype   Вверх
MoLeX
Дата 28.5.2010, 05:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Местный пингвин
****


Профиль
Группа: Модератор
Сообщений: 4076
Регистрация: 17.5.2007

Репутация: 46
Всего: 140



diktatorIgorIV

да без разницы. но для того что бы сторонний программист знал что вернет ему ваша чудо функция, надо писать комментарии.
Код

/**
 * Моя супер функция для таких то действий
 * @param integer $value значение
 * @return boolean
 */ 
function MySuperFunction( $value )
{
   return ($value > 10)?TRUE:FALSE;
}



--------------------
Amazing  smile 
PM MAIL WWW ICQ   Вверх
IgorIV
Дата 28.5.2010, 18:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 642
Регистрация: 7.9.2009

Репутация: 2
Всего: 8



ksnk, просто неудачный пример smile Развил, так сказать, идею, а оно ишь как оказалось smile
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "PHP"
Aliance
IZ@TOP
skyboy
SamDark
MoLeX

Новичкам:

  • PHP редакторы собираются и обсуждаются здесь
  • Электронные книги по PHP, документацию можно найти здесь
  • Интерпретатор PHP, полную документацию можно скачать на PHP.NET

Важно:

  • Не брезгуйте пользоваться тегами [code=php]КОД[/code] для повышения читабельности текста/кода.
  • Перед созданием новой темы воспользуйтесь поиском и загляните в FAQ
  • Действия модераторов можно обсудить здесь

Внимание:

  • Темы "ищу скрипт", "подскажите скрипт" и т.п. будут переноситься в форум "Web-технологии"
  • Темы с именами: "Срочно", "помогите", "не знаю как делать" будут УДАЛЯТЬСЯ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, IZ@TOP, skyboy, SamDark, MoLeX, awers.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0792 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.