Форум программистов, компьютерный форум, киберфорум
Perl
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
 Аватар для volodin661
6808 / 2309 / 350
Регистрация: 10.12.2013
Сообщений: 7,967

Perl опять 'мёртв' и в 30-ю годовщину собств. смерти вышел с OO реализацией прям в ядре

15.07.2023, 19:34. Показов 3300. Ответов 35
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Случилось это в июльской версии 5.38.

И это небезызвестный проект Corinna.


По состоянию на текущ. момент реализация полностью не завершена.
Из семи частей готовы три.
  1. Classes (done)
  2. Inheritance (done)
  3. Roles
  4. Convenience attributes
  5. Field initializer blocks (done)
  6. MOP
  7. Method modifiers

Подключается в 5.38 вместе со статусом 'experimental'.


Собственно, чтобы попробовать, 5.38 устанавливать не обязательно,
сгодятся и версии >= 5.14 + Feature::Compat::Class


PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
class Point::2D {
    field $x :param = 0;
    field $y :param = 0;
 
    field $orig_x = $x;
    field $orig_y = $y;
 
    method x () { $x }
    method y () { $y }
 
    method reset () {
        $x = $orig_x;
        $y = $orig_y;
    }
 
    method move ($dx, $dy) {
        $x += $dx;
        $y += $dy;
    }
 
    method description () {
        return "($x, $y)";
    }
}
my $point = Point::2D->new( x => 10, y => 20 );
$point->move( 5, 5 );
say $point->description; # (15, 25)
Добавлено через 8 минут
ссылка на оф.док:
https://perldoc.perl.org/perlclass

собственно ссылка, которой пользовался:
https://ovid.github.io/article... -perl-core
3
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.07.2023, 19:34
Ответы с готовыми решениями:

Найти собств. значение и собств. функции
y''=j(лямбда)*y; y'(0)=o; y'(5)=0;


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
35
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38204 / 21136 / 4310
Регистрация: 12.02.2012
Сообщений: 34,748
Записей в блоге: 14
27.07.2023, 07:24
Студворк — интернет-сервис помощи студентам
Гай, это не совсем так... . ООП-парадигма полезна и не сходит с повестки дня.
0
Заблокирован
27.07.2023, 09:09
Цитата Сообщение от Shamil1 Посмотреть сообщение
Но пишут всё равно на языках с ООП.
Я не знаю, кто этим занимается добровольно, если честно. Может только какие-нибудь олдфаги, который не хотят учиться новому.
Например Rust внедрён уже в ядро Линукс, Майкрософт заявило о том, что будет внедрят его в ядро винды.

Цитата Сообщение от Shamil1 Посмотреть сообщение
Самое интересное начинается, когда в одном приложении сотни тысяч строк кода.
Наговнокодить можно сколько угодно строк, главное, чтобы это было потом можно использовать. На самом деле спроектировать, например, библиотеку в тысяч десять строк, чтобы она была хорошо читаема, продуктивна уже довольно непросто.

Добавлено через 2 минуты
Цитата Сообщение от Catstail Посмотреть сообщение
Гай, это не совсем так... . ООП-парадигма полезна и не сходит с повестки дня.
Может и полезна, только не всегда и не везде, а местами.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38204 / 21136 / 4310
Регистрация: 12.02.2012
Сообщений: 34,748
Записей в блоге: 14
27.07.2023, 09:32
Цитата Сообщение от Гай Посмотреть сообщение
Может и полезна, только не всегда и не везде, а местами.
- а с этим никто и не спорит. "Серебряных пуль" не бывает. Но ООП-парадигма жива и таковой и останется.
1
Заблокирован
27.07.2023, 11:22
Цитата Сообщение от Catstail Посмотреть сообщение
- а с этим никто и не спорит. "Серебряных пуль" не бывает. Но ООП-парадигма жива и таковой и останется.
А насчёт того, что Go - это ООП язык, то это, конечно, весёлое заявление.
Так можно всё ООП языком назвать. Тут даже писали, что чистый С - это ООП.
На самом деле разница велика. В Расте, например, трейты и там есть штуки аля ООП, но нет наследования и прочей ерунды. Методы отделены от самих трейтов. Итог - всё довольно чётко и прозрачно.
Я столкнулся с ужасом в видео ООП в Gtk, перенесённом на Rust. Кучи классов, которые наследуют один другой, а в расте это вылилось в кучу трейтов, которые расширяют один другой. Ищешь что тебе нужно и не можешь найти - заходишь в документацию по трейту, а там ещё 50 родственных трейтов у него - где там там то, что тебе нужно. Не говоря уже о том, чтобы лейбл передать виджету нужно что-то такое - &Some("string"). Это просто ужас. FLTK кстати на С++ написан изначально, но он то ли лучше продуман, то ли лучше портирован на раст и, наверно, меньше Gtk, но там с эти всё куда лучше.
0
Модератор
Эксперт функциональных языков программирования
3138 / 2286 / 469
Регистрация: 26.03.2015
Сообщений: 8,890
27.07.2023, 22:41
Цитата Сообщение от Гай Посмотреть сообщение
Я не знаю, кто этим занимается добровольно, если честно.
Большинство программистов этим занимается. Топ-5 самых популярных языков - все поддерживают ООП. Правда и ФП они тоже все поддерживают (в той или иной степени).

Цитата Сообщение от Гай Посмотреть сообщение
Наговнокодить можно сколько угодно строк, главное, чтобы это было потом можно использовать.
Не знаю, о чём Вы пишите, а я писал о нормальном, хорошо читаемом коде.

Цитата Сообщение от Catstail Посмотреть сообщение
Гай, это не совсем так... . ООП-парадигма полезна и не сходит с повестки дня.
Если вспомнить, то, что некоторые участники форума называют "определением ООП от Алана Кея", то и erlang вполне себе поддерживает ООП (обмен сообщениями).
1
Заблокирован
27.07.2023, 23:04
Цитата Сообщение от Shamil1 Посмотреть сообщение
Топ-5 самых популярных языков - все поддерживают ООП.
Ну это так себе аргумент. Ольга Бузова куда популярнее Баха, только это не значит, что Бузова лучше.
Кстати, как определяется популярность языков? Я вот сейчас набрал поисковике и зашел на несколько сайтов и везде результаты отличаются.
Цитата Сообщение от Shamil1 Посмотреть сообщение
Не знаю, о чём Вы пишите, а я писал о нормальном, хорошо читаемом коде.
Нормальный и читаемый код и ООП это фактически оксюморон. Даже адепты ООП давно признали, что ООп надо менять и вносить туда больше из функционального программирования. Например неизменяемость данных.
Давайте пробежимся по высказываниям людей, которые что-то в этом точно понимают.

Edsger W. Dijkstra (1989)
“TUG LINES,” Issue 32, August 1989
“Object oriented programs are offered as alternatives to correct ones” and “Object-oriented programming is an exceptionally bad idea which could only have originated in California.”

Alan Kay (1997)
The Computer Revolution hasn’t happened yet
“I invented the term object-oriented, and I can tell you I did not have C++ in mind.” and “Java and C++ make you think that the new ideas are like the old ones. Java is the most distressing thing to happen to computing since MS-DOS.” (proof)

Paul Graham (2003)
The Hundred-Year Language
“Object-oriented programming offers a sustainable way to write spaghetti code.”

Richard Mansfield (2005)
Has OOP Failed?
“With OOP-inflected programming languages, computer software becomes more verbose, less readable, less descriptive, and harder to modify and maintain.”

Eric Raymond (2005)
The Art of UNIX Programming
“The OO design concept initially proved valuable in the design of graphics systems, graphical user interfaces, and certain kinds of simulation. To the surprise and gradual disillusionment of many, it has proven difficult to demonstrate significant benefits of OO outside those areas.”

Oscar Nierstrasz (2010)
Ten Things I Hate About Object-Oriented Programming
“OOP is about taming complexity through modeling, but we have not mastered this yet, possibly because we have difficulty distinguishing real and accidental complexity.”

Rich Hickey (2010)
SE Radio, Episode 158
“I think that large objected-oriented programs struggle with increasing complexity as you build this large object graph of mutable objects. You know, trying to understand and keep in your mind what will happen when you call a method and what will the side effects be.”

Eric Allman (2011)
Programming Isn’t Fun Any More
“I used to be enamored of object-oriented programming. I’m now finding myself leaning toward believing that it is a plot designed to destroy joy. The methodology looks clean and elegant at first, but when you actually get into real programs they rapidly turn into horrid messes.”

Joe Armstrong (2011)
Why OO Sucks
“Objects bind functions and data structures together in indivisible units. I think this is a fundamental error since functions and data structures belong in totally different worlds.”

Lawrence Krubner (2014)
Object Oriented Programming is an expensive disaster which must end
“We now know that OOP is an experiment that failed. It is time to move on. It is time that we, as a community, admit that this idea has failed us, and we must give up on it.”

Asaf Shelly (2015)
Flaws of Object Oriented Modeling
“Reading an object oriented code you can’t see the big picture and it is often impossible to review all the small functions that call the one function that you modified.”
1
Модератор
Эксперт функциональных языков программирования
3138 / 2286 / 469
Регистрация: 26.03.2015
Сообщений: 8,890
28.07.2023, 01:06
Цитата Сообщение от Гай Посмотреть сообщение
Ну это так себе аргумент. Ольга Бузова куда популярнее Баха, только это не значит, что Бузова лучше.
Мы и не говорим о том, что лучше. Бах, может, и лучше, но попса не "приказала долго жить".

Цитата Сообщение от Гай Посмотреть сообщение
Нормальный и читаемый код и ООП это фактически оксюморон.
Чтобы об этом рассуждать, нужно сначала дать формальное определение ООП коду.
Есть факт, что на C# можно написать нормальный, хорошо читаемый код большого (огромного) объёма. Возможно, Вы скажите, что это не ООП код. Но в рамках данной дискуссии это не принципиально.
0
 Аватар для volodin661
6808 / 2309 / 350
Регистрация: 10.12.2013
Сообщений: 7,967
28.07.2023, 13:30  [ТС]
Выстрелил бы Бах в ногу Ольги Бузовой ?
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38204 / 21136 / 4310
Регистрация: 12.02.2012
Сообщений: 34,748
Записей в блоге: 14
28.07.2023, 16:25
Гай, я поставил плюс за собранные высказывания классиков. При всем уважению к ним, их основной тезис можно выразить одной фразой: "ООП имеет недостатки и не является "серебряной пулей" программирования". Но с этим разумные люди не спорят. Ни одна из парадигм программирования не является панацеей. Проблемы разработки ПО последние 50 лет мало меняются - это переход "количества в качество" при возрастании сложности и объема. Если "убить" ООП лучше не станет. А высказывания "экстремистского" толка (типа: "От ООП пора отказаться") - безответственны и не могут быть справедливыми "по построению". Это немного напоминает марксизм...

Если спор имеет тенденцию к продолжению, могу перенести тему в "Священные войны".
1
 Аватар для volodin661
6808 / 2309 / 350
Регистрация: 10.12.2013
Сообщений: 7,967
28.07.2023, 17:09  [ТС]
Catstail,
не-не,
никаких священных вобл,
тема изначально про Perl,
оставьте здесь.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38204 / 21136 / 4310
Регистрация: 12.02.2012
Сообщений: 34,748
Записей в блоге: 14
28.07.2023, 17:09
volodin661, ок
0
Заблокирован
28.07.2023, 17:19
Цитата Сообщение от Catstail Посмотреть сообщение
При всем уважению к ним, их основной тезис можно выразить одной фразой: "ООП имеет недостатки и не является "серебряной пулей" программирования".
Они ещё говорят, что ООП сделало код плохо читаемым и сложно поддерживаемым. Не говоря у же о других проблемах.
И я сними согласен в этом.
Цитата Сообщение от Catstail Посмотреть сообщение
А высказывания "экстремистского" толка (типа: "От ООП пора отказаться")
Думаю они не призывают совсем отказаться, а предлагают его совать везде, а использовать только когда очень надо.


Цитата Сообщение от Catstail Посмотреть сообщение
Если спор имеет тенденцию к продолжению, могу перенести тему в "Священные войны".
А смысл? Мы просто беседуем. Никаких войн нет.

Цитата Сообщение от Shamil1 Посмотреть сообщение
Чтобы об этом рассуждать, нужно сначала дать формальное определение ООП коду.
Ну вы что обсуждали со мной до этого?

Цитата Сообщение от Shamil1 Посмотреть сообщение
Мы и не говорим о том, что лучше.
А о чём мы говорим тогда?

Цитата Сообщение от volodin661 Посмотреть сообщение
Выстрелил бы Бах в ногу Ольги Бузовой ?
Думаю не только в ногу
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38204 / 21136 / 4310
Регистрация: 12.02.2012
Сообщений: 34,748
Записей в блоге: 14
28.07.2023, 17:50
Цитата Сообщение от Гай Посмотреть сообщение
Думаю они не призывают совсем отказаться, а предлагают его совать везде, а использовать только когда очень надо.
- о чём я и говорю. По-моему, тема вполне исчерпана.
0
Невнимательный
 Аватар для ft4l
3131 / 1326 / 360
Регистрация: 08.02.2013
Сообщений: 7,744
Записей в блоге: 2
28.07.2023, 18:41
Цитата Сообщение от volodin661 Посмотреть сообщение
>= 5.14 + Feature::Compat::Class
Таки не пойму, есть описание блоков ADJUST{} + параметры могут добавляться,
которые , как понял,
в любом количестве становятся частью конструктора.... сама new(){} не определяется...

деструкторы как-то можно создавать , как обычными sub DESTROY(){} ?
или treadsafe фишки со всякими CLONE(){} , CLONE_SKIP(){}
0
Модератор
Эксперт функциональных языков программирования
3138 / 2286 / 469
Регистрация: 26.03.2015
Сообщений: 8,890
28.07.2023, 20:58
Цитата Сообщение от Гай Посмотреть сообщение
А о чём мы говорим тогда?
Если кратко, то Вы сказали, что "Модель ООП сдохла давно уже.". А я ответил, что не сдохла, аргументировав это тем, что "Топ-5 самых популярных языков - все поддерживают ООП. "


Цитата Сообщение от Catstail Посмотреть сообщение
По-моему, тема вполне исчерпана.
Согласен.
1
Заблокирован
07.09.2023, 10:39
Shamil1, ну так я выше сказал, что популярность ни о чем не говорит. Часто эти языки сами написаны на непопулярных языках. И их библиотеки тоже.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Ответ Создать тему
Новые блоги и статьи
[golang] Двоичная куча, min-heap
alhaos 20.05.2026
Двоичная куча Двоичная куча — структура данных, которая всегда держит самый важный элемент наготове. Представьте очередь к хилеру в игре, и очередь из игроков в приоритете те у кого меньше. . .
[golang] Breadth-First Search
alhaos 19.05.2026
BFS (Breadth-First Search) — это базовый алгоритм обхода графа в ширину, который поуровнево исследует все связанные вершины. Он начинает с выбранной точки и проверяет всех соседей, прежде чем. . .
[golang] Алгоритм «Хак Госпера»
alhaos 17.05.2026
Алгоритм «Хак Госпера» Хак Госпера (Gosper's Hack) — алгоритм нахождения следующего по величине числа с тем же количеством установленных бит. Придуман Биллом Госпером в 1970-х, опубликован в. . .
Рисование бинарного древа до 6-го колена на js, svg.
russiannick 17.05.2026
<svg width="335" height="240" viewBox="0 0 335 240" fill="#e5e1bb"> <style> <!]> </ style> <g id="bush"> </ g> </ svg> function fn(){ let rost;/ / высота древа let xx=165,yy=210,w=256;
FSharp: interface of module
DevAlt 16.05.2026
Интерфейс модуля F# позволяет управлять доступностью членов, содержащихся в реализации модуля. По-умолчанию все члены модуля доступны: module Foo let x = 10 let boo () = printfn "boo" . . .
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции. <!DOCTYPE html> <html lang="ru"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible". . .
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru