{"id":"https://openalex.org/W2155266165","doi":"https://doi.org/10.1145/1462166.1462168","title":"Expressive and modular predicate dispatch for Java","display_name":"Expressive and modular predicate dispatch for Java","publication_year":2009,"publication_date":"2009-02-01","ids":{"openalex":"https://openalex.org/W2155266165","doi":"https://doi.org/10.1145/1462166.1462168","mag":"2155266165"},"language":"en","primary_location":{"id":"doi:10.1145/1462166.1462168","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1462166.1462168","pdf_url":null,"source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Programming Languages and Systems","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5014067492","display_name":"Todd Millstein","orcid":"https://orcid.org/0000-0002-2031-1514"},"institutions":[{"id":"https://openalex.org/I161318765","display_name":"University of California, Los Angeles","ror":"https://ror.org/046rm7j60","country_code":"US","type":"education","lineage":["https://openalex.org/I161318765"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Todd Millstein","raw_affiliation_strings":["University of California, Los Angeles, Los Angeles, CA"],"affiliations":[{"raw_affiliation_string":"University of California, Los Angeles, Los Angeles, CA","institution_ids":["https://openalex.org/I161318765"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5044829987","display_name":"Christopher Frost","orcid":null},"institutions":[{"id":"https://openalex.org/I161318765","display_name":"University of California, Los Angeles","ror":"https://ror.org/046rm7j60","country_code":"US","type":"education","lineage":["https://openalex.org/I161318765"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Christopher Frost","raw_affiliation_strings":["University of California, Los Angeles, Los Angeles, CA"],"affiliations":[{"raw_affiliation_string":"University of California, Los Angeles, Los Angeles, CA","institution_ids":["https://openalex.org/I161318765"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5047300799","display_name":"Jason Ryder","orcid":null},"institutions":[{"id":"https://openalex.org/I161318765","display_name":"University of California, Los Angeles","ror":"https://ror.org/046rm7j60","country_code":"US","type":"education","lineage":["https://openalex.org/I161318765"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Jason Ryder","raw_affiliation_strings":["University of California, Los Angeles, Los Angeles, CA"],"affiliations":[{"raw_affiliation_string":"University of California, Los Angeles, Los Angeles, CA","institution_ids":["https://openalex.org/I161318765"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5001491028","display_name":"Alessandro Warth","orcid":null},"institutions":[{"id":"https://openalex.org/I161318765","display_name":"University of California, Los Angeles","ror":"https://ror.org/046rm7j60","country_code":"US","type":"education","lineage":["https://openalex.org/I161318765"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Alessandro Warth","raw_affiliation_strings":["University of California, Los Angeles, Los Angeles, CA"],"affiliations":[{"raw_affiliation_string":"University of California, Los Angeles, Los Angeles, CA","institution_ids":["https://openalex.org/I161318765"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5014067492"],"corresponding_institution_ids":["https://openalex.org/I161318765"],"apc_list":null,"apc_paid":null,"fwci":8.5809,"has_fulltext":false,"cited_by_count":30,"citation_normalized_percentile":{"value":0.97751987,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":99},"biblio":{"volume":"31","issue":"2","first_page":"1","last_page":"54"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9998999834060669,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9998999834060669,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9988999962806702,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9979000091552734,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.869986355304718},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7420631647109985},{"id":"https://openalex.org/keywords/predicate","display_name":"Predicate (mathematical logic)","score":0.6938703060150146},{"id":"https://openalex.org/keywords/java","display_name":"Java","score":0.5672028064727783},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.5019779205322266}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.869986355304718},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7420631647109985},{"id":"https://openalex.org/C140146324","wikidata":"https://www.wikidata.org/wiki/Q1144319","display_name":"Predicate (mathematical logic)","level":2,"score":0.6938703060150146},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.5672028064727783},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.5019779205322266}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/1462166.1462168","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1462166.1462168","pdf_url":null,"source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Programming Languages and Systems","raw_type":"journal-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.212.4268","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.212.4268","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.frostnet.net/chris/research/jpred-toplas.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.380.6103","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.380.6103","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.ucla.edu/~todd/research/toplas08.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","id":"https://metadata.un.org/sdg/16","score":0.6600000262260437}],"awards":[{"id":"https://openalex.org/G6665158888","display_name":null,"funder_award_id":"CCF-0427202CCF-0545850","funder_id":"https://openalex.org/F4320337387","funder_display_name":"Division of Computing and Communication Foundations"}],"funders":[{"id":"https://openalex.org/F4320337387","display_name":"Division of Computing and Communication Foundations","ror":"https://ror.org/01mng8331"}],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":74,"referenced_works":["https://openalex.org/W25798763","https://openalex.org/W194677851","https://openalex.org/W1490156001","https://openalex.org/W1500987966","https://openalex.org/W1505718642","https://openalex.org/W1506833497","https://openalex.org/W1515278398","https://openalex.org/W1516285664","https://openalex.org/W1533109738","https://openalex.org/W1540330938","https://openalex.org/W1546727036","https://openalex.org/W1569747335","https://openalex.org/W1573426382","https://openalex.org/W1580631325","https://openalex.org/W1586902756","https://openalex.org/W1588812554","https://openalex.org/W1606121052","https://openalex.org/W1634428131","https://openalex.org/W1644882639","https://openalex.org/W1649645444","https://openalex.org/W1701387142","https://openalex.org/W1783388813","https://openalex.org/W1804899404","https://openalex.org/W1812582761","https://openalex.org/W1829244603","https://openalex.org/W1965014786","https://openalex.org/W1971903460","https://openalex.org/W1980939032","https://openalex.org/W1989258377","https://openalex.org/W1994181029","https://openalex.org/W2002301065","https://openalex.org/W2017743728","https://openalex.org/W2033348393","https://openalex.org/W2035731741","https://openalex.org/W2055477538","https://openalex.org/W2055970549","https://openalex.org/W2075994573","https://openalex.org/W2080674003","https://openalex.org/W2082514774","https://openalex.org/W2084686108","https://openalex.org/W2095219277","https://openalex.org/W2098884586","https://openalex.org/W2103927221","https://openalex.org/W2104301310","https://openalex.org/W2104532741","https://openalex.org/W2111151482","https://openalex.org/W2113547509","https://openalex.org/W2116793756","https://openalex.org/W2126022651","https://openalex.org/W2126234902","https://openalex.org/W2133786491","https://openalex.org/W2138363365","https://openalex.org/W2139576973","https://openalex.org/W2143238865","https://openalex.org/W2144015080","https://openalex.org/W2148009787","https://openalex.org/W2148620466","https://openalex.org/W2162525339","https://openalex.org/W2164778826","https://openalex.org/W2171351846","https://openalex.org/W2180690638","https://openalex.org/W2278011425","https://openalex.org/W2914317223","https://openalex.org/W3034080026","https://openalex.org/W3174107850","https://openalex.org/W4205241946","https://openalex.org/W4210597212","https://openalex.org/W4235702462","https://openalex.org/W4237566830","https://openalex.org/W4243443630","https://openalex.org/W4249022551","https://openalex.org/W4256390154","https://openalex.org/W4285719527","https://openalex.org/W6605396954"],"related_works":["https://openalex.org/W2748952813","https://openalex.org/W2390279801","https://openalex.org/W2358668433","https://openalex.org/W2376932109","https://openalex.org/W2001405890","https://openalex.org/W2382290278","https://openalex.org/W2350741829","https://openalex.org/W2378076731","https://openalex.org/W2130043461","https://openalex.org/W2530322880"],"abstract_inverted_index":{"Predicate":[0,50],"dispatch":[1,51,77,107,120,135,161],"is":[2,182],"an":[3,206],"object-oriented":[4],"(OO)":[5],"language":[6,89,202,214],"mechanism":[7],"for":[8,144,166],"determining":[9],"the":[10,31,35,46,84,138,200,213,233,242],"method":[11,24,36,47],"implementation":[12,25],"to":[13,97,111,125,141,208],"be":[14,38,122,142],"invoked":[15],"upon":[16],"a":[17,27,94,126,177],"message":[18],"send.":[19],"With":[20],"predicate":[21,28,76,100,106,119,134,160],"dispatch,":[22,61,65,67],"each":[23],"includes":[26],"guard":[29],"specifying":[30],"conditions":[32],"under":[33],"which":[34,220],"should":[37],"invoked,":[39],"and":[40,54,68,146,153,215],"logical":[41],"implication":[42],"of":[43,59,87,236,244],"predicates":[44],"determines":[45],"overriding":[48],"relation.":[49],"naturally":[52,123],"unifies":[53],"generalizes":[55],"several":[56,80,186,245],"common":[57],"forms":[58],"dynamic":[60],"including":[62,238],"traditional":[63,127],"OO":[64,128],"multimethod":[66],"functional-style":[69],"pattern":[70],"matching.":[71],"Unfortunately,":[72],"prior":[73,103,131,157],"languages":[74,104,132,158],"supporting":[75,99],"have":[78,108,136,162,222],"had":[79],"deficiencies":[81],"that":[82,190,211,231],"limit":[83],"practical":[85,234],"utility":[86,235],"this":[88],"feature.":[90],"We":[91],"describe":[92],"JPred,":[93,237],"backward-compatible":[95],"extension":[96,207],"Java":[98,210],"dispatch.":[101],"While":[102,130,156],"with":[105,133,159],"been":[109],"extensions":[110],"toy":[112],"or":[113],"nonmainstream":[114],"languages,":[115],"we":[116,204,221,226],"show":[117],"how":[118],"can":[121],"added":[124],"language.":[129],"required":[137],"whole":[139],"program":[140],"available":[143],"typechecking":[145,152],"compilation,":[147],"JPred":[148,170,201],"retains":[149],"Java's":[150],"modular":[151,217],"compilation":[154],"strategies.":[155],"included":[163],"special-purpose":[164],"algorithms":[165],"reasoning":[167],"about":[168],"predicates,":[169],"employs":[171],"general-purpose,":[172],"off-the-shelf":[173],"decision":[174],"procedures.":[175],"As":[176],"result,":[178],"JPred's":[179],"type":[180,218],"system":[181],"more":[183],"flexible,":[184],"allowing":[185],"useful":[187],"programming":[188],"idioms":[189],"are":[191],"spuriously":[192],"rejected":[193],"by":[194],"those":[195],"other":[196],"languages.":[197],"After":[198],"describing":[199],"informally,":[203],"present":[205],"Featherweight":[209],"formalizes":[212],"its":[216,239],"system,":[219],"proven":[223],"sound.":[224],"Finally,":[225],"discuss":[227],"two":[228],"case":[229],"studies":[230],"illustrate":[232],"use":[240],"in":[241],"detection":[243],"errors.":[246]},"counts_by_year":[{"year":2016,"cited_by_count":1},{"year":2015,"cited_by_count":3},{"year":2014,"cited_by_count":3},{"year":2013,"cited_by_count":4},{"year":2012,"cited_by_count":8}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
