Модераторы: Poseidon, Snowy, bems, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Оптимизация кода 
V
    Опции темы
Nutz
Дата 13.10.2009, 10:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Дайте совет по оптимизации, написал 2 варианта кода, какой лучше:

Код

function Tdatamodule_Connection.FindById2(ItemId, Where: Integer): Integer;
var
  OldItemID: Integer;
  B: Boolean;
begin
  Result := -1;
  if ConnectionStatus = csConnected then
  begin
    SelectionStatus := ssByKey;
    try
      OldItemID := Ffield_item_id.AsInteger;
      B := False;
      case Where of

        W_ITEMS:
          B := cmp_TableByKey_.FindKey([ItemId]) and
            (Ffield_group_id.AsInteger <> 0) and (Ffield_flags.AsLargeInt <> 1);

        W_SECTIONS:
          B := cmp_TableByKey_.FindKey([ItemId]) and
            (Ffield_group_id.AsInteger = 0) and (Ffield_flags.AsLargeInt <> 1);

        W_ITEMS_AND_SECTIONS:
          B := cmp_TableByKey_.FindKey([ItemId]) and
            (Ffield_flags.AsLargeInt <> 1);

        else
          raise Exception.CreateResFmt(@const_msg_InvalidWhereParam, [Where]);
      end;
      Result := Integer(B);
      WhereStatus := Where;
      if Result = 0 then
        cmp_TableByKey_.FindKey([OldItemID]);
    except
      on E: Exception do
        LastMsgError := E.Message;
    end;
  end
  else
    LastMsgError := LoadResString(@const_msg_ConnectionNotExists);
end;


или

Код

function Tdatamodule_Connection.FindById2(ItemId, Where: Integer): Integer;
var
  OldItemID: Integer;
  B: Boolean;
begin
  Result := -1;
  if ConnectionStatus = csConnected then
    try
      SelectionStatus := ssByKey;
      OldItemID := Ffield_item_id.AsInteger;
      B := cmp_TableByKey_.FindKey([ItemId]) and (Ffield_flags.AsLargeInt <> 1);
      case Where of

        W_ITEMS:
          B := B and (Ffield_group_id.AsInteger <> 0);

        W_SECTIONS:
          B := B and (Ffield_group_id.AsInteger = 0);

        W_ITEMS_AND_SECTIONS:;

        else
          raise Exception.CreateResFmt(@const_msg_InvalidWhereParam, [Where]);
      end;
      Result := Integer(B);
      WhereStatus := Where;
      if Result = 0 then
        cmp_TableByKey_.FindKey([OldItemID]);
    except
      on E: Exception do
        LastMsgError := E.Message;
    end
  else
    LastMsgError := LoadResString(@const_msg_ConnectionNotExists);
end;
 
PM MAIL   Вверх
Aeore
Дата 13.10.2009, 22:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Во первых не ясно что это такое. Во вторых мне второй вариант больше нравится.
PM MAIL ICQ   Вверх
~FoX~
Дата 14.10.2009, 10:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


НЕ рыжий!!!
****


Профиль
Группа: Участник Клуба
Сообщений: 2819
Регистрация: 8.10.2003
Где: Зеленоград

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



ИМХО второй красивше только два совета
1. В if ConnectionStatus = csConnected then, поставь все таки begin
2. Я бы проверял не if Result = 0 then, а if B = false then

Хотя это конечно придирки...


--------------------
user posted image
…множественность никогда не следует полагать без необходимости…
PM MAIL WWW ICQ Jabber   Вверх
v258
Дата 14.10.2009, 11:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Цитата(~FoX~ @  14.10.2009,  10:47 Найти цитируемый пост)
if B = false then

Я бы написал так:
Код

  if not B then

но это уже совсем придирка  smile 

А по сути вопроса - маловато комментариев, имхо 

Это сообщение отредактировал(а) v258 - 14.10.2009, 11:11
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Общие вопросы"
SnowyMetalFan
bemsPoseidon
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader.

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


 




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


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

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