The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

Релиз компилятора Free Pascal 2.2.0

11.09.2007 13:43

После двух лет разработки анонсирован новый релиз Free Pascal 2.2.0, открытого, кроссплатформенного компилятора языка Паскаль, совместимого с Borland Pascal 7, Delphi и Metrowerks Pascal. Из новшеств можно отметить:

  • Поддержка архитектур PowerPC/64 и ARM;
  • Поддержка платформ Mac OS X/Intel, Nintendo Game Boy Advance, Nintendo Game Boy DS, Windows CE (Windows Mobile) и 64-Windows;
  • Расширены возможности отладчика;

При тестировании сборка кода в FPC производилась примерно в 7 раз быстрее, чем в GCC, при этом сгенерированный в FPC 2.0.4 (в FPC 2.2 в этом плане проведены оптимизации) код выполнялся на 30% медленнее, но занимал меньше памяти. При сравнении с интерпретируемыми языками, код FPC был в 50 раз быстрее Ruby, разница с PHP и Java граздо менее заметна, но код на FPC потребляет в 14 раз меньше памяти по сравнению с PHP и в 17 - с Java.

  1. Главная ссылка к новости (http://www.osnews.com/story.ph...)
  2. Обзор новшеств во Free Pascal 2.2.0
  3. Cross-Platform Development with Free Pascal 2.2.0 - хороший обзор FPC 2.2
Лицензия: CC BY 3.0
Короткая ссылка: https://opennet.ru/11974-pascal
Ключевые слова: pascal
При перепечатке указание ссылки на opennet.ru обязательно


Обсуждение (100) Ajax | 1 уровень | Линейный | +/- | Раскрыть всё | RSS
  • 1.1, roof (?), 15:07, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    А кто-то, кроме школьников и студентов нетехнических вузов пишет на паскале консольные проги?
     
     
  • 2.32, ЩекнИтрч (?), 09:47, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Я пишу. Очень изощренные конвертеры :)
    Компактно.
     

  • 1.2, Аноним (-), 15:09, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    roof ты че - я так себе представил на мгновение ока как литераторы на паскале пишут так мне смешно становиться.
     
  • 1.3, Hard (??), 15:19, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    > А кто-то, кроме школьников и студентов нетехнических вузов пишет на паскале консольные проги?

    Я пишу секурные демоны на FPC, и кстати не школьник и не студент.

     
     
  • 2.5, fresco (??), 15:56, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    жжош!!
    Надо быть оч. большим фанатом этошо языка, что б на нем работать. IMHO, конечно...
     
     
  • 3.16, Av (??), 20:17, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Паскаль лишен указателей, кои, как все мы знаем, являются в руках не опытных программистов злом.
     
     
  • 4.19, Cupone (?), 20:57, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    A tu na Pascal pisal?
    V Pascal est ykazateli, ix mogno ispolzovat to4no takje kak v C.
    A po skorosti Pascal ne xoge C, napishi prostuy programy na C a ya na Pascal
    i sravnim skorost.
     
  • 4.20, Painbringer (?), 21:06, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    ты паскаль то видел вообще? поддерживаются указатели как на данные так и на функции. (сам пишу на ц++ ибо работа, но к паскалю остались теплые чувства).
     
  • 4.22, bum (??), 23:00, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Ахренеть. Большей тупости я еще не читал. Указатели в Паскале есть еще со времен его рождения. Стеки, связанные списки, деревья, кольца и пр. в нем строятся элементарно.

    Кстати очень хороший и удобный язык. Сейчас пишу на C++, но имхо Паскаль вы зря хаете, возможностей у него ничуть не меньше (тем более во Free Pascal добавлено очень много по сравнению с исходнім язіком). Возможно он не такой гибкий, но зато в нем труднее допускать ошибки, он прост, логичен и понятен. Ну и скорость компиляции у Паскаля и C++ не сравнимы. Очень жаль, что последнее время он отошел на задний план.

     
  • 4.42, Дмитрий Ю. Карпов (?), 12:07, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Люди, вы все офигели. Указатели в Паскале есть, но они совсем не такие, как в Си: в Паскале указатель котролируется по типу и может указывать только на рабочую переменную (т.е. невозможно переполнение буфера), а в Си указатель можно заставить указывать на что угодно.
     
     
  • 5.61, vst (??), 17:11, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    В Паскале есть и нетипизированные указатели, и указатели на функции, так что не надо. Вот что мне не нравится в нем, так это контроль типов во время исполнения, потому и компиляция быстрее, а выполнение - медленнее.
     
     
  • 6.68, Apollon (?), 21:03, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    так из-за контроля типов и ошибок меньше, хотя для "профи2 можно и отключать контроль ошибок run-time
     

  • 1.4, Hard (??), 15:34, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    > При сравнении с интерпретируемыми языками, код FPC был в 50 раз быстрее Ruby, в 14 раз быстрее PHP и в 17 - Java

    Меня всегда удивляли "религиозные Фаны" этих языков, хотите увидеть в процентном выражении сколько это (в 1 раз = 100%) - FPC 2.0.4 на 5000 % быстрее Ruby, на 1400 % быстрее PHP и 1700% быстрее Java.
    А если хорошо довести Lazarus, то FPC однозначно превзойдет по скорости разработки любые дот-нэты и пр. прочие кофейники.
    PS где вы перченые мачо, оплюйте меня поскорей, а то вдруг Вас уволят :)

     
     
  • 2.7, Аноним (-), 16:03, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    А как вообще ЭТО можно сравнивать с интерпретируемыми языками?
    И вообще со сравнения компиляторов переходить на сравнивание языков?
     
  • 2.15, ого (?), 20:00, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    а меня всегда удивляли такие вот ЕСЛИ которые кроме как А ЕСЛИ ... ТО всем капец
     
  • 2.40, TomB (?), 11:43, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    В 50 раз больше - это на 4900% больше, а не на 5000%.
     

  • 1.6, Ghost (??), 16:02, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Hard, точнов в глаз. Pascal ничем не хуже C, и кроме того на нем вполне реально также и проги под иксы и под винды писать. IMHO, roof просто лучше доки к нему читай
     
     
  • 2.8, Аноним (-), 16:05, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Хуже, как язык.
     
     
  • 3.10, gvf (?), 17:21, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Чем хуже?? -- чем язык! :)
    Hard, поддерживаю. Ну вот не нравится мне С с его хедерами и связанной с этим путаницей.
    Просто С старше, и кода на нем написано ОГРОМНОЕ количество. Лазарус как среда разработки - вполне ОК. Не хватает более мощного отладчика (ну, с учетом анонса - посморим).
     
     
  • 4.58, Тушкан (?), 15:15, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Чем хуже?? -- чем язык! :)

    за одно только with X do (особенно вложенные) автора следует порвать лошадьми.

     
  • 4.95, XAnder (ok), 15:10, 15/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Просто С старше, и кода на нем написано ОГРОМНОЕ количество.

    Небольшая поправка. Си не старше Паскаля. Паскаль разработан Никлаусом Виртом в 1970-71 годах. А над Си трудились Ритчи и Томпсон в 1969-73 годах, причём более-менее законченный вид (и название) язык обрёл только в 1972 году не без влияния Паскаля.

     
  • 2.13, sauron (??), 18:02, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Попробуйте на нем написать чтонибудь низкоуровневое. Упаритесь.
     
     
  • 3.23, bum (??), 23:04, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Почему? Ну назовите, что такое можно написать на С, что нельзя написать на Паскале?
     
     
  • 4.33, fresco (??), 09:49, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    ФС. Объем кода будет в 3-4 раза больше (ибо синтаксис избыточный), производительность ваще в жопе окажется. В принципе, конечно, можно. И ОСи на обероне делают. Но это, имхо, фанатизьм. Шурупы тоже можно молотком заколачивать. Только зачем -- если есть отвертка?
     
     
  • 5.41, kde (??), 11:52, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Уж лутче шуруп заколотить молотком, чем гвоздь завинтить отверткой.
    Хотя каждому инструменту свое назначение.
     
  • 2.43, Дмитрий Ю. Карпов (?), 12:12, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Лично яразочаровался в Паскале после того, как увидел, что в аргументах подпрограммы/процедуры/функции требуется точно указать тип массива, так что не получается сделать подпрограмму, обрабатывающую массивы разных размеров. Кроме того, я не нашёл возможности создавать во время выполнения массивы нужного мне размера - размер массива определяется на момент компиляния.
     
     
  • 3.49, ABorland (?), 14:10, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    "Я не нашел" - это ключевое слово

    То, что Ты не нашел, еще не означает, что в языке этого нет.
    Срочно курить документацию.

     
  • 3.52, serg1224 (?), 14:45, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    +1
    срочно И КРАЙНЕ ВНИМАТЕЛЬНО изучаем работу с указателями, типизированными и неочень :-)
     
  • 3.60, bum (??), 16:05, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Мля. В современном Паскале уже давно существуют динамические массивы. Впервые они появились в одной из версий Delphi и соостветственно полностью перешли во Free Pascal. А передача массивов разной длины в качестве параметра функции в Паскале существует еще с незапамятных времен, курим документацию по ключевым словам "параметры массивы".
     
     
  • 4.74, serg1224 (?), 01:45, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Мля. В современном Паскале уже давно существуют динамические массивы

    В библиотеках на Паскале. Или уже встроенные средства языка появились?!

    > и соостветственно полностью перешли во Free

    Ой ли... полностью?

    >Pascal. А передача массивов разной длины в качестве параметра функции в
    >Паскале существует еще с незапамятных времен...

    Многие еще живы :-) не так уж и давно это было.

     
     
  • 5.83, WhiteWind (??), 21:36, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >В библиотеках на Паскале. Или уже встроенные средства языка появились?!

    Да, появились.

    >Ой ли... полностью?

    Да, ой ли.
    Да, полностью.

     

  • 1.9, Nice (?), 17:19, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    На нем как будто с инструктором на учебной машине едешь.
    В аварию попасть можно но шансов меньше.
    имхо
     
     
  • 2.31, DeadMustdie (??), 09:30, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >На нем как будто с инструктором на учебной машине едешь.
    >В аварию попасть можно но шансов меньше.

    Весьма точное сравнение. Ибо прокатиться с ветерком тоже никак,
    и передачи переключать инструктор слишком рано заставляет. ;)

     
     
  • 3.53, serg1224 (?), 14:47, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Ибо прокатиться с ветерком тоже никак,
    >и передачи переключать инструктор слишком рано заставляет. ;)

    А некоторые никуда не торопятся :-)

    PS
    ... и не забываем про скорость разработки...

     

  • 1.11, yerenkow (?), 17:34, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Маленькая поправка - не Nintendo Game Boy DS, а Nintendo DS

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

    Или сравнивается время цикла миллионного сложения чисел?

     
  • 1.12, guest (??), 17:53, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Прочухайтесь, детки: даже автор паскаля признаёт, что язык имеет массу недостатков - поэтому, собственно, он и занялся всякими модулами и прочими оберонами...
    Так что не пригоден он к промышленному использованию, а для обучения питон его превосходит на порядки.
     
     
  • 2.24, bum (??), 23:06, 11/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Прочухайтесь, детки: даже автор паскаля признаёт, что язык имеет массу недостатков -
    >поэтому, собственно, он и занялся всякими модулами и прочими оберонами...
    >Так что не пригоден он к промышленному использованию, а для обучения питон
    >его превосходит на порядки.

    Оригинальный Pascal и современный Free Pascal - это две большие разницы. Многие решения из Модулы вернулись и были реализованы в разных диалектах Паскаля. Когда последний раз книжку по Паскалю в руки брал?

     
  • 2.55, serg1224 (?), 14:50, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    > даже автор паскаля признаёт, что язык имеет массу недостатков - поэтому, собственно, он и занялся всякими модулами и прочими оберонами...

    А у кого нет недостатков? Может у Assembler? :-)

    Тут как в пазлах: нужно фигурки соответствующими сторонами соединять.

     

  • 1.14, Аноним (-), 18:20, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    однако детка, даже автор С++ признает кучу его недостатков...
     
     
  • 2.50, DeadMustdie (??), 14:24, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >однако детка, даже автор С++ признает кучу его недостатков...

    Просто не все согласны с основным принципом дизайна C++.
    "Make hard things possible, even if it makes simple things complicated".

     

  • 1.17, S.D.e.R.F (?), 20:28, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    На всех форумах только и пишут что паскаль-отстой...
    А реально куча прог пишется на Delphi/Kylix/Pascal. Даже десктопы на linux-XPDE кажется завется
     
  • 1.18, atx (?), 20:39, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Согласен с S.D.e.R.F Паскаль не так уж и плох... на нём вполне реально писать прикладные программы... как под консоль, так и под иксы/эксплорер...

    "...низкоуровневое там страдает..."
    а что вы под ним ребята понимаете-то - под низкоуровневом... ?
    драйвера писать на Паскале можно - видел это/делал это - и не чуть не хуже чем на си... паскаль+асма - вот вам и полноценное низкоуровневое...

    к томуже Дельфи/Куликс/Лазарус - куды приятние чем ВизуалСи/Эклипс/КДевеелоп =) ИМХО...

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

     
  • 1.21, WhiteWind (ok), 22:34, 11/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Известный многим QIP написан на Delphi, DownloadMaster, лидирующий менеджер закачек написан (скорее всего) на Delphi, TotalCommander написан на Delphi.
    Я пишу на Delphi программы для регистрации и обработки цифровых сигналов, раньше писал на TurboPascal драйвер для АЦП, сейчас клепаю демки на OpenGL кроссплатформенные на FreePascal.

    А если серьёзно, то не надо устраивать ещё один холивар, т.к. язык это дело привычки, а на вкус и цвет все фломастеры разные.

     
     
  • 2.34, fresco (??), 09:54, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    > А если серьёзно, то не надо устраивать ещё один холивар, т.к. язык это дело привычки, а на вкус и цвет все фломастеры разные.

    Вот это правильно сказано. Исключительно дело привычки. Нормальный кодер на чем угодно может качественные продукты делать -- хоть на php, хоть на асме.

     
     
  • 3.90, Тушкан (?), 14:22, 14/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Нормальный кодер на чем угодно
    >может качественные продукты делать -- хоть на php, хоть на асме.

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


     
     
  • 4.97, kruk (?), 05:08, 17/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >>Нормальный кодер на чем угодно
    >>может качественные продукты делать -- хоть на php, хоть на асме.
    >
    >Это опасное заблуждение новичков. Программист действительно может выучить множество языков, но, как
    >и с человечемкими разговорными языками, думать он всегда будет только на
    >одном, а на всех других языках у него всегда будет более
    >или менее различимый акцент.

    У вас в голове устаревшие теории насчёт человеческих языков и, похоже, изумительно извращённое понимание программирования.

     

  • 1.25, Аноним (-), 00:25, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    C более лаконичен, поэтому мне он нравится больше, чем Pascal :)
    <offtopic>Кто что скажет про Objective-C?</offtopic>
     
  • 1.28, Pablitos (??), 01:47, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Ребята,
    паскаль это такой же язык как и все С и С++. Он очень подходит для обучения детей програмированию. И открою вам секрет... Единтственная разница С и и паскаля в том что в паскале жесткая типизация. вот и все. В остальном одно и тоже. И Слава Богу что паскаль есть :) А то б поколения работали на бейсике
     
  • 1.29, Аноним (-), 07:41, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Опять флуд подняли, борьба детей в песочнице Есть задача, а есть инструмент реш... большой текст свёрнут, показать
     
     
  • 2.30, Anonymous (?), 07:59, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Nemnogo fluda, pardon.
    Da, vse zavisit ot algoritma, no na raznyh jazykah realizacija
    vygljadit po-raznomu. Pisal ja na assemblere proceduru vyvoda prjamoj
    linii na CGA i Hercules adapter. Potom napisal to zhe na C. V poslednem
    sluchae poluchilos kompaktnee, no v pervom - ponjatnee. Assemblernyj
    variant rabotal s takim svistom, chto strochnyj transformator v monitore
    pischal :). C - variant - procentov na 20 medlennee.
     

  • 1.35, high (?), 10:20, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Гы, а еслиб ОО писали на Lazarus, он был бы на 1700 % быстрее?
    Жаба - тормоз, как не крути и не хвали...
     
     
  • 2.36, WhiteWind (??), 10:27, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    OOo не на Яве написан...
     

  • 1.37, Аноним (-), 10:54, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    > Возможно он не такой гибкий, но зато в нем труднее допускать ошибки, он прост, логичен и понятен

    Вот за это мачо его и не любят. Ведь можно понадевелопить, а потом месяцами отлаживать и искать глюки (причем некоторые оставив на завтрак) и соотв. получать за зря зарплатку... Кальян, ИМХО конечно)))

    > OOo не на Яве написан...

    А на чем, если оно так тттормозит, ПМК за 1,5 сек везде, а меню вылетает за 2 сек... А жирные документы открывает((((

     
     
  • 2.62, vst (??), 17:36, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    > > Возможно он не такой гибкий, но зато в нем труднее допускать ошибки, он прост, логичен и понятен
    > Вот за это мачо его и не любят. Ведь можно понадевелопить, а потом месяцами отлаживать и искать глюки (причем некоторые оставив на завтрак) и соотв. получать за зря зарплатку... Кальян, ИМХО конечно)))

    Так можно на чем угодно девелопить, и на паскале - тоже. Просто иногда хочется писать прогу, а не бороться с системой контроля типов.

     
     
  • 3.69, Apollon (?), 21:10, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    а зачем бороться с системой контроля типов? я ни разу не встречал ситуации когда она непролазо мешала, а помогает она очень, а для всяких извращений есть record с вариативной частью, там можно такого наворотить, всякие С-шники обзавидуются :))
     
  • 3.84, WhiteWind (??), 21:40, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Так можно на чем угодно девелопить, и на паскале - тоже. Просто
    >иногда хочется писать прогу, а не бороться с системой контроля типов.

    И вообще, в C не менее строгая система контроля типов. К примеру, void* преобразуется в char* только явно. А в паскале контроль за типом указателей отключабелен.

    Или вы говорите, что в C менее строгая система контроля типов только потому, что он int в bool неявно преобразовывает?

     
     
  • 4.89, Тушкан (?), 14:18, 14/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Или вы говорите, что в C менее строгая система контроля типов только
    >потому, что он int в bool неявно преобразовывает?

    Дело не в том, что она менее строгая. Дело в том, что она более разумная. Компилятор делает то, что он может сделать безопасно и не делает того, что опасно.

     
     
  • 5.94, WhiteWind (ok), 22:23, 14/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Дело не в том, что она менее строгая. Дело в том, что
    >она более разумная. Компилятор делает то, что он может сделать безопасно
    >и не делает того, что опасно.

    char* s = malloc(256);
    Это опасно?
    Почему мне приходится писать
    char* s = (char*)malloc(256); ?

     
     
  • 6.99, DeadMustdie (??), 10:13, 17/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >char* s = malloc(256);
    >Это опасно?
    >Почему мне приходится писать
    >char* s = (char*)malloc(256); ?

    В данном конкретном случае - нет. Но вот пример позатейливее:

    struct S1 {
    ...
    };
    struct S2 {
    ...
    };
    struct S1* s1 = malloc(sizeof(struct S2));

    Пример дурацкий, но демонстрирует типовую ошибку - неверно указанный
    объем выделяемой памяти. Соответственно, необходимость явно указать
    тип результата полезна, так как в значительной степени страхует от
    этой ошибки.

     
     
  • 7.100, WhiteWind (ok), 18:10, 17/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Пример дурацкий, но демонстрирует типовую ошибку - неверно указанный
    >объем выделяемой памяти. Соответственно, необходимость явно указать
    >тип результата полезна, так как в значительной степени страхует от
    >этой ошибки.

    "Не плодите лишних сущностей без необходимости" (c) - Не помню, кто.
    В паскале есть специальная функция для выделения памяти под типизированные указатели - New()

    var
      P: ^TStruct;
    ...
    P:=GetMemory(SizeOf(TStruct));
    равносильно
    New(P);

     
     
  • 8.101, XAnder (ok), 08:53, 18/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Бритва Оккама Это высказывание очень любили и Альберт Эйнштейн, и автор Паскаля... текст свёрнут, показать
     
  • 2.63, WhiteWind (??), 17:39, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Не знаю. но он без явы запускается, и лишь некоторые его возможности не работают без явы
     

  • 1.38, Аноним (-), 11:08, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    В СБРФ и пр. все прикладные АБС написаны на Delphi (в основном на Delphi 5)
    ИМХО, если бы СИ/С++/Кофе/Какао/Змеи был так хорош, то почему именно на Delphi?
    Да потому, что девелопится быстро (быстрее всяких дотнетов, накидал компонентов обвязал и порядок)))) и без опасных глюков и багов (как обычно принято в С++), а главное дешево! (Среда разработки довольно дешева по сравнению с VS и учить девелоперов надо меньше, и Sample-code навалом)
    По этой причине такие канторы на Linux в ближайшее время не перейдут, если только перченые девелоперы не одумаются и не начнут активно развивать Lazarus, чтобы проект на Delph можно было легко пересобрать под Linux с помощью Lazarus.
    (Kilyx умер)
    Или полная победа добра не нужна и вендекапец отменен, а?
     
  • 1.39, Аноним (-), 11:34, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    1 Есть хорошая программа R Software Editor 1 3 11 есть статья в журнале Chip, ... большой текст свёрнут, показать
     
     
  • 2.56, Тушкан (?), 15:05, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Ахренеть! На Дельфи уже пишут текстовые редакторы! До чего дошла наука!

    >пол года получить офисный пакет круче чем у M$ (правда для

    Сначала борланд пусть сделает нормальную поддержку юникода в своей поделке. А то в 21м веке нифига интерфейс нормальный не сделать без сторонниз библиотек. Да что там юникод: если дельфи не падает при компиляции программ это уже супер.

    >Lazarus надо срочно доводить, а то он глючен, а Rtl довольно жирна.

    Вот как раз ситуация с Lazarus и говорит, что никому это не надо

     

  • 1.44, Аноним (-), 12:18, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Паскаль детям нельзя давать. Давно пора исключить его из школьной программы. По себе знаю и от других слышал: Паскать учит плохому стилю программирования, а т.к. это первый язык - сравнить не в чем, вот и переучиваться трудно на тот же С или Python.

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

     
     
  • 2.65, thedix (??), 17:53, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Чему же такому плохому он учит?
    Паскаль очень даже неплохой язык, например, типизация в нем в тему, что особенно полезно для начинающих.
    Реализовывать базовые алгоритмы на нем самое то. Без всяких там свистелок/перделок графических.
    Не вижу особой проблемы заинтересованным читателям осилить Си и Питон.
    Если они действительно заинтересованы.
    Кто-то увидит Паскаль и скажет: "Да, это он, мой любимый язык!"
    Кто-то перепробует десяток языков и остановится на Си++.
    Но ведь не все идут программить. Кто-то познакомится с Паскалем в школе и благополучно пойдет работать водителем, вспоминая учителя информатики по матушке. :)
     

  • 1.45, hard (?), 13:14, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    > Паскаль детям нельзя давать

    Не давать Turbo Pascal, надо давать FPC.
    Вот BASIC точно надо исключить ибо проприетарщина врага.

    > С или Python.

    C был разработан для Unix в те времена, когда каждый байт был на вес золота. Он не преследует простоту о однозначность/понятность. И что, можно сделать вывод, что begin и end; вместо {  } - это дурной стиль программирования? А если ты допрограммировался до слепоты, то эти {  }  тебе будет ой как сложно увидать на экране. а void вместо procedure - дурно пахет, правда? Зато человеку понятно.
    С++ как логическое развитие объектного подхода, получил все уродства С.
    PS Fpc позволяет объектно работать, даже без применения классов, можно вызывать перегруженные и одноименные функции указав ее как поле класс, а за класс брать имя модуля. А с С/С++ с эти какой гимор... Все должно быть уникально. Но Fpc также может работать со строгими именами функций, используя alias.
    Короче, товарищи перченые мачо, не х. не знаете, что такое Fpc, то и нех. пердеть в лужу. Fpc уже давно стал круче С, и скоро доберется до С++, а ваши отговорки только лишь от неумения программировать на этом эффективном языке.

    > Python

    зеленый змий.)))) см на сколько % он тормознутее))))

     
  • 1.46, hard (?), 13:29, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Вот к примеру Wine, бинарноков ~10 МБ. (сорцев на ~50 МБ)
    Компилить сорцы на Pentium III 1 GHz сколько времени? Минут 5-10? Или больше?
    А если ставить бинарный (платформа-зависимый) пакет? Секунд 30?
    А если бы такой проект был написан на Fpc, то эти же 50 МБ скомпилились бы за этиже 30 сек. Отсюда можно сделать вывод, что FPC дает шанс создавать универсальные, установочные пакеты, которые быстро ставятся и работают на любых платформах.
    Необходимо лишь разработать стандарты и спецификации.
     
     
  • 2.51, Тушкан (?), 14:36, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Вообще то мне, как админу, пофигу сколько оно там компилится. Мне главное, чтобы работало быстро и эффективно. Смысл использовать паскаль как замену С будет тогда, когда его компилятор научится генерировать БОЛЕЕ эффективный код чем С т.е. никогда. Паскаль нужно использовать для того, для чего его и создавали - для обучения студентов.
     
     
  • 3.67, ДяДя (?), 19:25, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Ага.
    Вы лучше сравните Паскаль и Яву.
    А ведь яву сейчас во все дырки втыкают и серверных приложений много развелось.
     
     
  • 4.72, Apollon (?), 21:22, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Особенно когда попытаешься поработать с программами мониторинга серверов производства Intel, при всяких траблах быстрее сбегать в серверную и там поглядеть, чем добиться хоть какой-нибудь информации от программы.
     
  • 2.57, Mr.Close (?), 15:12, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Буду спорить сразу со многими.
    Pascal как раз более пригоден и для обучения и для промышленного использования.
    1. Не дает волю природной лени программеров явно объявлять переменные. Защищает от многих других вольных упрощений, свойственных "крутым программерам". Приучает к дисциплине, без чего серьезные разработки вести просто нельзя.
    2. Строго следит за качеством кода, снижая неожиданные ошибки (в т.ч. с переопределением и некорректным применением переменных).

    Те недостатки, которые ставятся в упрек Паскалю очень четко говорят о вредных привычках тех, кто на них указывает. Паскаль более строг, значит код более надежен. От серьезных разработчиков жалоб заметно меньше, они и на C и на любом другом языке пишут аккуратно. Потому и проблем со строгостью к качеству кода у них не возникает. А разные "трюки" - суть плохой стиль программирования и риск для проекта. Посмотрите спрос на программистов у нас и в USA. Туда нужны Delphi, у нас - С. У нас полет мысли, у них - предсказуемый результат.

    Возможности вполне сопоставимы. Враг - мода на C (плохого о последнем ничего не скажу, не ждите, вопросы не в языку, а к программистам). C, его среды разработки и компиляторы развивают многие, а Паскаль присутствует только у Борланда. Отсюда и разница в развитии сред разработки и в популярности, увы. А дальше цепная реакция: меньше программеров - меньше спрос - меньше развитие языка и т.д.

     

  • 1.47, Ne01eX (??), 13:33, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    1. Я все понимаю, но вот давайте не будет мешать Delphi и FPC.
    2. Я еще писать сидя на горшке не научился, а указатели уже были.

    Новость зачетная. А холивар вы, красноглазые, зря устроили.

     
     
  • 2.48, hard (?), 14:02, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Такова природа человека, лень, гордыня, страх...
    Если есть что-то угрожающее спокойному баблосшибанию, то они стараются сразу оплевать, опорочить, быть, мол, для школьников/студентов и тд.

    Вдруг придет хороший делфятник, и заменит собой 5-10 программистов на С++)))
    А ведь за насиженное место страшно.
    Важен ведь результат, прибыть, а не множественное наследований или краткость кода)))

     
     
  • 3.54, Тушкан (?), 14:47, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Абсолютно верно: сначала мы боялись, что нас выживут программисты на Прологе - языке будущего, потому на Паскале - языке будущего, потом на Яве - языке будущего, потом на Аде - мегаязыке будущего, созданном для американского ВПК (т.е. всё по-взрослому), теперь вот Дельфи и .Net - снова боимся... 20 лет страха...
    На самом деле Дельфи, Ява и т.д. - это просто способ оптимизации расходов на персонал. Т.е. чтобы получить веб страничку или программу для выписки накладных больше не нужен высококвалифицированный спец, сойдёт и лоботряс-первокурсник. По настоящему высококвалифицированный спец в этом угрозы для себя не видит, наоборот ему достаются самые интересные задачи. И оплачиваются они соответствующим образом.
     
     
  • 4.59, Mr.Close (?), 15:54, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    А теперь вопрос "по делу". На FPc сейчас можно реально писать модули для Apache? Кто-нибудь практикует? А то со смертью Kylix и уходом Delphi в .NET едва зарождавшаяся приятная возможность канула в лету. Теперь опять выбор между интерпретатором PHP и C. Ни тот ни другой вариант не устраивает по разным причинам. Вот вариант Borland D/K был реально удобнее, только не все интерфейсы адаптировать успели.
     
     
  • 5.64, WhiteWind (??), 17:47, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >А то со смертью Kylix и уходом Delphi в .NET

    Delphi не ушла в .NET. Она идёт по двум направлениям сразу.

    И хватит уже! Фломастеры - РАЗНЫЕ! И по вкусу, и по толщине стержня.
    А возможности одинаковые.

     
  • 5.70, Apollon (?), 21:18, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    есть Pascal Server Page, стоит поискать и почитать, если интересно.
    до массового разлития Явы по сайтам была идея (и реализация) подобной технологии с использованием Оберона, называлась Juice, тоже можно почитать.
     

  • 1.66, Аноним (66), 19:05, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Сейчас выдвину крамольную мысль: паскаль и C не отличаются ничем кроме синтаксиса. Ну тоесть вообще ничем. Все разговоры про недоступность "низкоуровневого" программирования не имеют под собой никаких оснований. Скорость выполнения на 90% определяется программистом (алгоритмом) а не компилятором.
    По поводу типизации: считаю, что в больших проектах строгая типизация это большой плюс. Практика показывает что минутная экономия оборачивается месяцами вылавливания багов, и хорошо если эта программа выполняется не где-нибудь за 5000 км. от офиса. Сам в работе использую и С и FPC.
     
     
  • 2.71, Apollon (?), 21:20, 12/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    +100
    поддерживаю!! отличия только в синтаксисе !! С-шникам лень писать  begin ... end, вот они и придумали свои любимые { } :))
     
  • 2.78, Тушкан (?), 12:18, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >и C не отличаются ничем кроме синтаксиса

    правда ? посмотри хотябы на убогий цикл for в паскале. как на нём написать цикл по двум переменным for (int i = 0, j = 0; i < 100; i += (++j)++) ? по переменным не типа int ? И так везде, куда не сунешься.


    >По поводу типизации: считаю, что в больших проектах строгая типизация это большой плюс.

    Если вы набираете в команду недоучек-студентов, не понимаете, что делаете, не смотрите на warningи компилятора, тогда да. Но эту мысль можно развить так: нужно всегда пользоваться ложкой, потому как вилкой можно ненароком выколоть себе глаз. Что вы за программисты такие, если даже сами себе не доверяете и хотите чтобы вас контролировали даже там, где это не нужно?

    Но даже, если смотреть на простые begin end, то сколько вы тратите своей программистской жизни на набивание этих бесполезных слов. Короче, от паскаля, такое же ощущение, как от случайно попавших на простынь песчинок, мешающих спать: программировать на нём можно, но только страшно раздражаясь по мелочам.

     
     
  • 3.85, WhiteWind (??), 21:47, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >правда ? посмотри хотябы на убогий цикл for в паскале. как на
    >нём написать цикл по двум переменным for (int i = 0,
    >j = 0; i < 100; i += (++j)++) ? по
    >переменным не типа int ? И так везде, куда не сунешься.

    Цикл можно делать по всем перечисляемым типам. А цикл for изначально предназначен для последовательного перебора по одному параметру. Для всего остального есть while. А это ваше нецелевое использование for лишь ухудшает читабельность кода.

    >Но даже, если смотреть на простые begin end, то сколько вы тратите
    >своей программистской жизни на набивание этих бесполезных слов. Короче, от паскаля,
    >такое же ощущение, как от случайно попавших на простынь песчинок, мешающих
    >спать: программировать на нём можно, но только страшно раздражаясь по мелочам.

    Меня, например, очень раздражает необходимость зажимать shift для набора этих ваших {}, я их медленнее, чем begin end набираю.

     
     
  • 4.88, Тушкан (?), 14:13, 14/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Для всего остального есть while

    Ну да. Можно извратиться и while, если по нормальному не получается. Кто ж спорит то. Это и есть идеология паскаля - загонять программиста в рамки. Т.е. если на С вы можете писать и так и этак, выбирая вариант, который ВЫ, считаете правильным, то в паскале вы ВЫНУЖДЕНЫ выбирать вариант, который кто-то выбрал за вас, посчитав правильным. При это всегда обосновывается тем, что "так правильно". Т.е. не инструмент для человека, а человек для инструмента. Благодаря такому подходу, программирование уже почти превратилось из искусства в банальное ремесло.

    >Цикл можно делать по всем перечисляемым типам.

    Ух ты. С тех пор, как я в последний раз имел дело с этим недоязыком, произошёл определённый прогресс. Наверно благодаря Борланду, который в свой дельфи тащит все сишные фишки.

    >я их медленнее, чем begin end набираю.

    Ну, потому на Паскале и программируете :-)  

     
     
  • 5.91, Тушкан (?), 14:35, 14/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Ещё такое вопрос. Не в плане наезда на пасквилянтов, а просто из чистого детского любопытства: шаблоны классов в пасакале уже появились ?

     
     
  • 6.93, WhiteWind (ok), 22:16, 14/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Ещё такое вопрос. Не в плане наезда на пасквилянтов, а просто из
    >чистого детского любопытства: шаблоны классов в пасакале уже появились ?

    Нет, не появились.

     
  • 6.96, XAnder (ok), 15:42, 15/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Ещё такое вопрос. Не в плане наезда на пасквилянтов, а просто из
    >чистого детского любопытства: шаблоны классов в пасакале уже появились ?

    Так, тоже чисто для справки, не в плане наезда. Классов в Си вообще нет, и в Паскале тоже. Это не ОО языки. Turbo/Object/etc Pascal - это уже другие языки, к развитию которых автор Паскаля не имеет никакого отношения. То же можно сказать и о C++ и Objective-C по отношению к оригинальному языку Си.

    P. S.: Сам я с одинаковым уважением отношусь и к Си, и к Паскалю, хотя уже и не припомню, когда в последний раз что-то писал на Паскале или каком-нибудь паскалеподобном языке.

     
     
  • 7.98, DeadMustdie (??), 10:09, 17/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Так, тоже чисто для справки, не в плане наезда. Классов в Си
    >вообще нет, и в Паскале тоже. Это не ОО языки. Turbo/Object/etc
    >Pascal - это уже другие языки, к развитию которых автор Паскаля
    >не имеет никакого отношения.

    Выше по тексту налицо явное смешивание в термине "C" как самого C,
    так и C++. "Голый" C лично я весьма редко использую, исключительно
    для написания кода под ОС, на которые трудно найти либо хлопотно
    установить компилятор C++ - типа OpenVMS.

    >То же можно сказать и о C++ и Objective-C по отношению
    >к оригинальному языку Си.

    Действительно, автор Паскаля не имеет отношения к языкам C++ и
    Objective-C :). А вот комитеты по развитию стандарта C++ и C
    процентов на 40 состоят из одних и тех же людей.

    >P. S.: Сам я с одинаковым уважением отношусь и к Си, и
    >к Паскалю, хотя уже и не припомню, когда в последний раз
    >что-то писал на Паскале или каком-нибудь паскалеподобном языке.

    +1

     
  • 5.92, serg1224 (?), 21:50, 14/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    > ... программирование уже почти превратилось из искусства в банальное ремесло

    К слову сказать, некоторый "авангардист" - "специалист" от искусства - такого понапишет, что кроме него самомго никто код разобрать не может, да и читать противно! А ему нравится, прям душа поёт :-) "Ну и пусть себе летит железяка ржавая" (c)

    Свободой нужно, конечно, учиться владеть.

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

     

  • 1.73, S.D.e.R.F (?), 21:38, 12/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Кстати в яве многое позамствовано из паскаля,например идея байт-кода
     
     
  • 2.75, Pablitos (??), 02:28, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Ребята,
    не спорте о том о чем спорить не нужно! Паскаль - это идеальный язык для обучения программистов на начальном уровне. Хотя бы из-за этого этот язык имеет право на существование.

    А все ньюансы (которых есть бесконечное множиство) - это ньюансы... Таких ньюансов есть много. Примеры лень приводить. от fortran-а до ruby. это целая пропасть языков! Просто каждый выбирает ПОТОМ то, что ему удобнее.

     
     
  • 3.76, hard (?), 08:21, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Да ты Гуру!)))
    Вот скажи, на чем написано ППО в банках? А в Администрации? А на почте?
    Они лучше будут на венде сидеть, ради того, чтобы ничего не переделывать, тем более на С или кофе. (что выльется в сбои и большие затраты)
    FPC вполне хорош, что за вирус такой: "Паскаль для обучения"? TP7 – для обучения.
    FPC - не для обучения, он предназначен, а для использования Delphi программ на любых платформах.

    И ПОТОМ можно не выбирать, он вполне подойдет для любых целей, от ядра ОС, до огромной гуайной программы. Или тебе тоже страшно за свое насиженное место?

     
     
  • 4.80, serg1224 (?), 15:03, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >TP7 – для обучения.

    1. Устарел в сравнении с реализацией языка в Delphi.
    2. Коммерческий продукт! При всей моей любви к Borland ...

     

  • 1.77, Аноним (-), 11:08, 13/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Нравится вам или нет, но FPC/Lazarus - это единственный способ пересадить делферов на Linux, а делфер в небольшой компании - вещь просто необходимая.
    Пустой Халивар(((
     
     
  • 2.79, Тушкан (?), 12:23, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Не надо делферов пересаживать на линукс. Пусть будет заповедник свободный от идиотов. Ведь в след за ними прибегут маркетологи борланда - и тогда точно случится то, о чём так мечтает Мелкософт.
     
     
  • 3.81, k22 (?), 15:24, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Сам Free Pascal на си написан, однако.
     
     
  • 4.82, thedix (??), 20:13, 13/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Ошибаетесь, он сам себя компилит.
     

  • 1.86, Аноним (-), 09:04, 14/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    кстати, в статье написано, что:

    "Compared to interpreted languages, one sees that FPC code executes 50 times faster than e.g. Ruby. The difference with PHP and Java is smaller, but these use 14 (PHP) to 17 (Java) times more memory than FPC programs."

    пусть у меня английский и хромает на обе ноги, но в статье написано, что Free Pascal быстрее Ruby и в 14(17) раз ест меньше памяти, чем PHP(JAVA).

     
     
  • 2.87, DeadMustdie (??), 09:33, 14/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >кстати, в статье написано, что:
    >
    >"Compared to interpreted languages, one sees that FPC code executes 50 times
    >faster than e.g. Ruby. The difference with PHP and Java is
    >smaller, but these use 14 (PHP) to 17 (Java) times more
    >memory than FPC programs."
    >
    >пусть у меня английский и хромает на обе ноги, но в статье
    >написано, что Free Pascal быстрее Ruby и в 14(17) раз ест
    >меньше памяти, чем PHP(JAVA).

    Да уж... ляп в новости преизрядный.
    Мне сразу странным показалось, потому как при беге в мешках (сиречь в тестах) Java на современных, JIT-компилирующих виртуальных машинах нисколько не медленнее C++. Просто жрет много памяти и вдобавок в самый неподходящий момент принимается собирать мусор.

     
     
  • 3.106, the_root (?), 07:25, 09/04/2008 [^] [^^] [^^^] [ответить]  
  • +/
    Давайте не трогать Java.

    Я джавист. Пробовал си/паскаль
    Просто если у меня стоит задача гонять по сетке сущности, то я не заметил чтоб такие механизмы как Reflection были у си или паскаля.
    А вот модуль ядра для линукс на Java не соберешь:)

    Паскаль для одного, си для другого, Java - для третьего.


     

     Добавить комментарий
    Имя:
    E-Mail:
    Текст:



    Партнёры:
    PostgresPro
    Inferno Solutions
    Hosting by Hoster.ru
    Хостинг:

    Закладки на сайте
    Проследить за страницей
    Created 1996-2024 by Maxim Chirkov
    Добавить, Поддержать, Вебмастеру