Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Это нужно знать, записки диверсанта 
:(
    Опции темы
SneG0K
  Дата 30.4.2008, 23:25 (ссылка)    | (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Max Mara
***


Профиль
Группа: Завсегдатай
Сообщений: 1887
Регистрация: 1.12.2007
Где: Wis Dells

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



И заблуждение №11.
 11)Почему юзать Дельфи, а не что-то другое?

Ответ:Потомушто ДЕЛЬФИ РУЛИТ!!!! smile  smile  smile 

Ссори за  smile 
PM WWW Skype   Вверх
THandle
Дата 4.5.2008, 14:41 (ссылка) |    (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Хранитель Клуба
Group Icon
Награды: 1



Профиль
Группа: Админ
Сообщений: 3639
Регистрация: 31.7.2007
Где: Moscow, Dubai

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



Из записок Ивана:









                                                                                                                                      12 ноября.

   Решил вести дневник. Пусть будущее поколение знает как герои изучали Delphi.

Сегодня ознакомился с интерфейсом. Классная вещь вам скажу. Скачал учебник. Читаю.

                                                                                                                                      16 ноября.

  Прочитал учебник. Теперь мне многое понятно. Надо написать какую-нибудь программку. И я даже знаю какую...

                                                                                                                                      28 ноября.

  Узнал сегодня что со строками можно работать как с массивом. Я был ваще в шоке.
  Стал переделывать все. Чтоб круче было. И возникла одна маленькая проблемка:
  
Код

var 
   s : string; 
   i : integer;
begin  
  for i := 0 to Length(s) - 1 do
    s[i] := 'Э';
end; 


Почему-то код вызывает ошибку:( почему не понимаю. Видимо из за глюков в Delphi. Вообще если так вот посмотреть с проффесианальной точки зрения ошибок очень много.
Абсолютно непонятно чем не понравился мой код этому компелятору? Ведь строка же это массив символов, который наченается с нуля. Последним элементом является длина этого массива вычисляемая очень полезной функцией Length, которую я случайно обнаружил и благодаря опытам установил что она возвращает длину строки.
  Ладно, не будем работать со строками как с массивом, раз они не хотят...


                                                                                                                                     8 декабря.

  Случайно прочитал сегодня где-то в интернете, что строка начинается с 1, а в нулевом элементе хранится её длина. А заканчивается строка её длиной(странно по моему, ну пусть будет так, раз по другому не смогли сделать). Переделал свой код. И правда работает. Как я сам не догадался?

Код

Var
  s : string;
  i : integer;
begin
  for i := 1 to Length(s) do
    s[i] := 'Э';
end; 



                                                                                                                                      11 декабря.

  Обнаружил сегодня интересный класс: Tstringlist. Очень полезная вещь для работы с файлами. 

                                                                                                                                      14 декабря.

  Класс оказался неправильный какой-то. Не работает:(
  Представляете, запустил в цикле добавление всех строк из моего StringList'а в Memo, а получилось так что первый элемент он игнорирует, а потом еще и ошибку выбрасывает:(

Код

var
  List : TStringList;
  i : integer;
begin
  List := TstringList.Create;
  List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
  for i := 1 to List.Count do
    Memo1.Lines.Add(List.Strings[i]);
end; 



Очень подозрительно, согласитесь?
                        
                                                                                                                                      19 декабря.

Да уж. Предыдущий опыт со строками должен был научить меня тому что в Delphi и в программировании вообще(я же теперь еще и Assembler отлично знаю, пишу сайты на PHP и собираюсь браться за C++, чтобы разрабатывать 3Д-игры).
Оказывается что во всех таких классах нумерация элементов идет не как в строках, а с 0, а заканчивается, видите ли, числом Count — 1. Потому что начальное значение Count = 1, а начинается список элементов с 0. Интересно кто такое придумал? Повесить его надо. Не поянтности какие то делают. Ужас полный.

Вот в общем мой код. Прикиньте, работает:
Код


var
  List : TStringList;
  i : integer;
begin
  List := TstringList.Create;
  List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
  for i := 0 to List.Count - 1 do
    Memo1.Lines.Add(List.Strings[i]);
end; 


А вообще в одной хорошей сатейке в интернете, кстати на том же сайте на котором я узнал и про строки, нашел еще то что оказывается у класса TstringList есть такая процедура AddStrings(там было написано что это метод, но что такое метод я не знаю почему-то, хотя учебник прочитал). 

В общем он неслабо упрощает мою задачу:

Код

var
  List : TStringList;
begin
  List := TstringList.Create;
  List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
  Memo1.Lines.AddStrings(List.Strings);
end; 


Добавляет все строчки без проблем вообще. Я со спокойной душой начинаю праздновать новый год.


                                                                                                                                18 января.

Ну вот, отлично отпраздновал новый год. Теперь вот вспомнил что у меня программа недописанная лежит. Решил сесть подумать что дальше делать. Полазил по нету. Удалось установить что к элементам списка строк можно обращаться прямо как массиву, а не через Strings. Объяснено это было тем что Strings объявлено с какой-то там директивой default. Ну да ладно. Пусть объявлено. Главное — работает. Мой прошлый код я модифицировал в вот что:

Код

var
  List : TStringList;
begin
  List := TstringList.Create;
  List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
  Memo1.Lines.AddStrings(List);
end; 



Работает супер.


                                                                                                                               20 января.

Где то прочитал что объекты надо уничтожать деструктором. Переделал свой код:

Код

procedure Button1Click(Sender : Tobject);
var
  List : TStringList;
begin
  List := TstringList.Create;
  List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
  Memo1.Lines.AddStrings(List);
  List.Destroy;
end; 


Почему-то при повторном нажатии на кнопку выскакивает ошибка:( Destroy убираю — всё нормально.
Статья видимо не правильная была.

                                                    
                                                                                                                                  26 января.

Прочитал где-то что нужно освобождать память за объектами не Destroy'м, а неким Free. Попробовал — ошибок нет, хотя результат тот же что и без него. Ну да ладно, пускай будет.

Вот мой новый код:

Код

procedure Button1Click(Sender : Tobject);
var
  List : TStringList;
begin
  List := TstringList.Create;
  List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
  Memo1.Lines.AddStrings(List);
  List.Free;
end; 




                                                                                                                                     29 января.

Сегодня абсолютно случайно обнаружил что у меня в программе можно и не использовать TstringList, так как в сам Memo можно точно так же загружать файл.

Теперь мой код выглядит так:

Код

procedure Button1Click(Sender : Tobject);
begin
  Memo1.Lines.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
end; 


Это сообщение отредактировал(а) THandle - 11.6.2008, 14:54
PM   Вверх
THandle
Дата 4.5.2008, 16:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Хранитель Клуба
Group Icon
Награды: 1



Профиль
Группа: Админ
Сообщений: 3639
Регистрация: 31.7.2007
Где: Moscow, Dubai

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



Естественно в конце, после всего этого дневника Вани последует подробное объяснение чего не так и тд. smile 
PM   Вверх
Wedafl
Дата 24.5.2008, 03:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



На тему конструктора, лично я часто пишу так
Код

var
  SomeClass : TSomeClass;
begin
  SomeClass := nil;
  try
    SomeClas := TSomeClass.Create;
    //что то делаем
  finally
    SomeClass.Free;
  end;
end;

И не понимаю чем это плохо.
PM MAIL ICQ   Вверх
THandle
Дата 26.5.2008, 08:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Хранитель Клуба
Group Icon
Награды: 1



Профиль
Группа: Админ
Сообщений: 3639
Регистрация: 31.7.2007
Где: Moscow, Dubai

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



Wedafl, обработку исключений конструктора лучше оставлять обработчику более высокого уровня, нежели try..finally..end;
PM   Вверх
Bose
Дата 4.6.2008, 17:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


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

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



Вот ещё совет-грабли, - уже раз n-дцать на них наступал. 
Надо к примеру нам подчистить какой-нибудь списочек. 
Пример покажу на TStringList. Предположим что нам нужно удалить пустые строки из файла.

Код

procedure Button1Click(Sender : Tobject);
var
  List : TStringList;
  i:integer;
begin
  List := TstringList.Create;
  try
    List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
    for i:=0 to List.Count-1 do
      if List[i]=EmptyStr then
        List[i].delete;
    // если в файле была хоть одна пустая строка, то дальше мы не пройдём
    List.SaveToFile('C:\\MySuperPuperProgram\MainVirus.txt');
  finally
    List.Free;
  end;
end; 



А вот ещё кстати частая ошибка
Код

procedure Button1Click(Sender : Tobject);
var
  List : TStrings;
  i:integer;
begin
  List := TStrings.Create;
  try
    List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
    for i:=List.Count-1 downto 0 do
      if List[i]=EmptyStr then
        List[i].delete; // а тут всё правильно написано
    List.SaveToFile('C:\\MySuperPuperProgram\MainVirus.txt');
  finally
    List.Free;
  end;
end; 


PM MAIL WWW Skype   Вверх
THandle
  Дата 5.6.2008, 07:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Хранитель Клуба
Group Icon
Награды: 1



Профиль
Группа: Админ
Сообщений: 3639
Регистрация: 31.7.2007
Где: Moscow, Dubai

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



Bose, ну хоть кто-то наконец то что-то предложил smile 

Буду дописывать.  smile И кидайте новые идеи smile 

Это сообщение отредактировал(а) THandle - 5.6.2008, 08:54
PM   Вверх
Bose
Дата 5.6.2008, 14:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


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

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



Этот пример получился слишком замороченный, но у меня не раз возникали такие проблемы:

Предположим, что Иван узнал что формы можно создавать динамически, и даже стал использовать оператор assign. 
Дано:
Все переменные форм объявлены как глобальные(по умолчанию дельфи так и делает).
Код

unit Form1;

interface

uses 
  classes,forms, 
  ... 

type
   TForm1=class(TForm)
       ...
   end;

var
  Form1:TForm;

implementation
....


При создании форм Иван проверяет, не была ли эта форма уже создана. 
Пример
Код

procedure ShowForm1;
begin
  if not assigned(Form1) then
    Form1:=TForm1.Create(Application);
  Form1.ShowModal;
  Form1.Free;
end;


А потом Иван узнал что глобальные переменные - это зло и решил сделать все глобальные переменные локальными:
Код

procedure ShowForm1;
var
  Form1:TForm;
begin
  if not assigned(Form1) then
    Form1:=TForm1.Create(Application);
  Form1.ShowModal;
  Form1.Free;
end;

И стал получать Access Violation, ибо неициализированные локальные переменные, не равны nil, так что условие not assigned(Form1) никогда не срабатывает.

Добавлено @ 14:09
А вот ещё вредный совет, на этот раз ООП-шный:

Код

type
  TMyComponent=class(TComponent)
     destructor Destroy;
  end;


Если мы перегружаем какой-либо метод в наследнике, не в коем случае не используем директиву override  smile 

Это сообщение отредактировал(а) Bose - 5.6.2008, 14:10
PM MAIL WWW Skype   Вверх
THandle
Дата 10.6.2008, 10:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Хранитель Клуба
Group Icon
Награды: 1



Профиль
Группа: Админ
Сообщений: 3639
Регистрация: 31.7.2007
Где: Moscow, Dubai

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



Цитата(Bose @  4.6.2008,  18:13 Найти цитируемый пост)


Код

procedure Button1Click(Sender : Tobject);
var
  List : TStringList;
  i:integer;
begin
  List := TstringList.Create;
  try
    List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
    for i:=0 to List.Count-1 do
      if List[i]=EmptyStr then
        List[i].delete;
    // если в файле была хоть одна пустая строка, то дальше мы не пройдём
    List.SaveToFile('C:\\MySuperPuperProgram\MainVirus.txt');
  finally
    List.Free;
  end;
end; 



А вот ещё кстати частая ошибка
    
Код

procedure Button1Click(Sender : Tobject);
var
  List : TStrings;
  i:integer;
begin
  List := TStrings.Create;
  try
    List.LoadFromFile('C:\\MySuperPuperProgram\MainVirus.txt');
    for i:=List.Count-1 downto 0 do
      if List[i]=EmptyStr then
        List[i].delete; // а тут всё правильно написано
    List.SaveToFile('C:\\MySuperPuperProgram\MainVirus.txt');
  finally
    List.Free;
  end;
end;
 



Это то же самое что и со строками, загоню в один "раздел" их smile 

Про строки я имел ввиду вот это:

Цитата(THandle @  23.4.2008,  21:23 Найти цитируемый пост)
Поэтому стоит быть очень осторожным, когда в таком цикле удаляется часть строки, например:

Эта процедура по идее должна удалять пробелы:

    
Код

procedure delspace(var s:string);
var i:integer;
begin
  for i:=1 to length(s) do
    if s[i]=' ' then delete(s,i,1);
end;



Однако же все пробелы она не удалит как раз по причине единичного расчета значений цикла.

Подробнее об этом я писал тут:

http://forum.vingrad.ru/forum/topic-206543.html



Цитата(Bose @  5.6.2008,  15:05 Найти цитируемый пост)
И стал получать Access Violation, ибо неициализированные локальные переменные, не равны nil, так что условие not assigned(Form1) никогда не срабатывает.


Хороший пример smile 


Цитата(Bose @  5.6.2008,  15:05 Найти цитируемый пост)

Если мы перегружаем какой-либо метод в наследнике, не в коем случае не используем директиву override  smile 


Ага smile  Тоже добавлю.


Вообще постараюсь по-чуть чуть писать, но так как времени не много то быстро не получится smile

А вы пока предлагайте новые идеи. Надо хотя бы не меньше 20 пунктов сделать а пока только 12:


1. Работа со строками в цикле. Почему с 1, а не с 0.
2. Работа со списками. Почему с 0, а не с 1.
3. Почему конструктор надо вызывать не как обычный метод?
4. Почему конструктор надо вызывать до try..finally..end?
5. Почему нельзя уничтожить объект в своем же обработчике?
6. Почему надо вызывать не Destroy, а Free?
7. Почему в цикле for нельзя менять значение переменной-счетчика этого же цикла?
8. Эквивалентны ли записи if b = true then и if b then?
9. Почему в цикле for со строками не надо вводить еще одну переменную в которую будет перед циклом заносится длина строки, и эта переменная будет являться конечным значением цикла?
10. Почему в цикле for 0т 1 до длины некоторой строки и удалении некоторых знаков из этой строки, удаляются не все знаки? То же самое относится и к удалению строк в TStringList.
11. Локальные переменные, которые при not Assigned выкидывают AV.
12. Override в перекрытом методе в наследнике какого-то класса.



Буду постепенно писать.

Всем удачи!!!

PM   Вверх
Bose
Дата 11.6.2008, 12:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


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

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



Корректура:

Цитата(THandle @  4.5.2008,  14:41 Найти цитируемый пост)
 8 декабря.  Случайно прочитал сегодня где-то в интернете, что строка начинается с 1, а в нулевом элементе хранится её длина. А заканчивается строка её длиной(странно по моему, ну пусть будет так, раз по другому не смогли сделать). Переделал свой код. И правда работает. Как я сам не догадался?


THandle, дальше код идёт, и там тоже i с 0 по length-1. Опечатка по ходу =)
PM MAIL WWW Skype   Вверх
THandle
Дата 11.6.2008, 14:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Хранитель Клуба
Group Icon
Награды: 1



Профиль
Группа: Админ
Сообщений: 3639
Регистрация: 31.7.2007
Где: Moscow, Dubai

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



Цитата(Bose @  11.6.2008,  13:59 Найти цитируемый пост)
THandle, дальше код идёт, и там тоже i с 0 по length-1. Опечатка по ходу =) 

Ага smile  Спс smile 
PM   Вверх
THandle
Дата 25.10.2008, 15:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Хранитель Клуба
Group Icon
Награды: 1



Профиль
Группа: Админ
Сообщений: 3639
Регистрация: 31.7.2007
Где: Moscow, Dubai

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



Решил в свободное время возобновить работу над проектом.
Если есть еще предложения - пишите.
PM   Вверх
bems
Дата 27.1.2009, 21:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


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

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



Цитата(THandle @  4.5.2008,  14:41 Найти цитируемый пост)
в нулевом элементе хранится её длина
это ж только про шортстринги!

Добавлено через 8 минут и 8 секунд
Цитата(THandle @  23.4.2008,  20:23 Найти цитируемый пост)
Будет очень много раз вызываться функция length, что сделает программу очень медленной.
На самом деле это не так. Начальное и конечное значение цикла for расчитывается только один раз, при начале его выполнения.

на самом деле, даже если бы конечное значение и ращитывалось на каждой итерации, то ничего страшного все равно бы не случилось. Эта страшилка с длиной строки растет из сей, где для нахождения длины строки люди сканировали ее в поисках нуля. Это делало алгоритм квадратичным. А дельфовая функция length благополучно проверяет поле длины строки по отрицательному смещению от первого символа, поэтому ее можно использовать и в условиях для цикла while без присваивания переменной


--------------------
Обижено школьников: 8
PM MAIL   Вверх
roschinspb
Дата 18.2.2010, 19:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



На тему дэльфовых заблуждений:
Всегда надо делать так:
Код

Query.SQL.Clear;  // Это очень нужная строка
Query.SQL.Add('SELECT');
Queri.SQL.Add('Field1'); // Опс скопипастили из другого запроса. Ошибочка и компилятор не заметил, ибо нефиг
Query.SQL.Add('From');
Query.SQL.Add('Table1');


Ни в коем случае не так:
Код

Query.SQL.Text := 'SELECT'#13#10+
                'Field1'#13#10+
                'From'#13#10+
                'Table1';
 Так получилось слишком коротко, ни кто не заметит, что Вы много работали
PM MAIL WWW   Вверх
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Форум группы: Vingrad Delphi - Voluntary Writers Group | Следующая тема »


 




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


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

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