Acme-CPANModules-MultipleDispatch
view release on metacpan or search on metacpan
NAME
Acme::CPANModules::MultipleDispatch - List of modules to do smart
matching
VERSION
This document describes version 0.001 of
Acme::CPANModules::MultipleDispatch (from Perl distribution
Acme-CPANModules-MultipleDispatch), released on 2024-07-01.
DESCRIPTION
About multiple dispatch
Multiple dispatch is a technique where you can define /multiple/
functions (or methods) of the same name but with different signatures
(e.g. different type of arguments, different number of arguments) and
the runtime will choose (/dispatch/) the correct function by matching
the signature of the caller to that of the defined functions.
This technique has several benefits, mostly simplifying user code
particularly when dealing with different types/arguments, because you
are deferring the checks to the runtime. For example, if you create a
function to concat two strings:
function combine(Str a, Str b) {
a + b;
}
and later wants to support some other types, instead of peppering the
original function with "if" statements, you can just supply additional
functions with the same name but with different arguments you want to
support:
function combine(Num a, Num b) {
a.as_str() + b.as_str();
}
function combine(File a, File b) {
a.open().read() + b.open().read();
}
Some languages, particularly strongly-typed ones, support multiple
dispatch: Julia, C#, Common Lisp, Groovy. Raku (Perl 6) also supports
multiple dispatch.
Perl 5 does not. But some modules will allow you to fake it.
Modules
Multi::Dispatch. By DCONWAY.
Dios. Also by DCONWAY. An object system which supports multiple
dispatch.
Class::Multimethods. Older module by DCONWAY.
Keywords
multi dispatch, multisub, multimethod.
ACME::CPANMODULES ENTRIES
Multi::Dispatch
Author: DCONWAY <https://metacpan.org/author/DCONWAY>
Dios
Author: DCONWAY <https://metacpan.org/author/DCONWAY>
Class::Multimethods
Author: DCONWAY <https://metacpan.org/author/DCONWAY>
FAQ
What is an Acme::CPANModules::* module?
An Acme::CPANModules::* module, like this module, contains just a list
of module names that share a common characteristics. It is a way to
categorize modules and document CPAN. See Acme::CPANModules for more
details.
What are ways to use this Acme::CPANModules module?
Aside from reading this Acme::CPANModules module's POD documentation,
you can install all the listed modules (entries) using cpanm-cpanmodules
script (from App::cpanm::cpanmodules distribution):
( run in 0.504 second using v1.01-cache-2.11-cpan-39bf76dae61 )