F#
Designmönsterimplementering i F #
Sök…
Datadriven programmering i F #
Tack vare typinferens och partiell tillämpning i F#
datadriven programmering kortfattad och läsbar.
Låt oss föreställa oss att vi säljer bilförsäkring. Innan vi försöker sälja den till en kund försöker vi avgöra om kunden är en giltig potentiell kund för vårt företag genom att kontrollera kundens kön och ålder.
En enkel kundmodell:
type Sex =
| Male
| Female
type Customer =
{
Name : string
Born : System.DateTime
Sex : Sex
}
Därefter vill vi definiera en uteslutningslista (tabell) så att om en kund matchar någon rad i uteslutningslistan kan kunden inte köpa vår bilförsäkring.
// If any row in this list matches the Customer, the customer isn't eligible for the car insurance.
let exclusionList =
let __ _ = true
let olderThan x y = x < y
let youngerThan x y = x > y
[|
// Description Age Sex
"Not allowed for senior citizens" , olderThan 65 , __
"Not allowed for children" , youngerThan 16 , __
"Not allowed for young males" , youngerThan 25 , (=) Male
|]
På grund av typinferens och partiell tillämpning är uteslutningslistan flexibel men ändå lätt att förstå.
Slutligen definierar vi en funktion som använder uteslutningslistan (en tabell) för att dela upp kunderna i två hinkar: potentiella och nekade kunder.
// Splits customers into two buckets: potential customers and denied customers.
// The denied customer bucket also includes the reason for denying them the car insurance
let splitCustomers (today : System.DateTime) (cs : Customer []) : Customer []*(string*Customer) [] =
let potential = ResizeArray<_> 16 // ResizeArray is an alias for System.Collections.Generic.List
let denied = ResizeArray<_> 16
for c in cs do
let age = today.Year - c.Born.Year
let sex = c.Sex
match exclusionList |> Array.tryFind (fun (_, testAge, testSex) -> testAge age && testSex sex) with
| Some (description, _, _) -> denied.Add (description, c)
| None -> potential.Add c
potential.ToArray (), denied.ToArray ()
För att samla in, låt oss definiera några kunder och se om de är potentiella kunder för vår bilförsäkring bland dem:
let customers =
let c n s y m d: Customer = { Name = n; Born = System.DateTime (y, m, d); Sex = s }
[|
// Name Sex Born
c "Clint Eastwood Jr." Male 1930 05 31
c "Bill Gates" Male 1955 10 28
c "Melina Gates" Female 1964 08 15
c "Justin Drew Bieber" Male 1994 03 01
c "Sophie Turner" Female 1996 02 21
c "Isaac Hempstead Wright" Male 1999 04 09
|]
[<EntryPoint>]
let main argv =
let potential, denied = splitCustomers (System.DateTime (2014, 06, 01)) customers
printfn "Potential Customers (%d)\n%A" potential.Length potential
printfn "Denied Customers (%d)\n%A" denied.Length denied
0
Detta skriver ut:
Potential Customers (3)
[|{Name = "Bill Gates";
Born = 1955-10-28 00:00:00;
Sex = Male;}; {Name = "Melina Gates";
Born = 1964-08-15 00:00:00;
Sex = Female;}; {Name = "Sophie Turner";
Born = 1996-02-21 00:00:00;
Sex = Female;}|]
Denied Customers (3)
[|("Not allowed for senior citizens", {Name = "Clint Eastwood Jr.";
Born = 1930-05-31 00:00:00;
Sex = Male;});
("Not allowed for young males", {Name = "Justin Drew Bieber";
Born = 1994-03-01 00:00:00;
Sex = Male;});
("Not allowed for children", {Name = "Isaac Hempstead Wright";
Born = 1999-04-09 00:00:00;
Sex = Male;})|]