{"id":"https://openalex.org/W2084390603","doi":"https://doi.org/10.1145/1094811.1094813","title":"Associated types and constraint propagation for mainstream object-oriented generics","display_name":"Associated types and constraint propagation for mainstream object-oriented generics","publication_year":2005,"publication_date":"2005-10-12","ids":{"openalex":"https://openalex.org/W2084390603","doi":"https://doi.org/10.1145/1094811.1094813","mag":"2084390603"},"language":"en","primary_location":{"id":"doi:10.1145/1094811.1094813","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1094811.1094813","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th annual ACM SIGPLAN conference on Object-oriented programming, systems, languages, and applications","raw_type":"proceedings-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/A5047665290","display_name":"Jaakko J\u00e4rvi","orcid":"https://orcid.org/0000-0002-3418-7366"},"institutions":[{"id":"https://openalex.org/I91045830","display_name":"Texas A&M University","ror":"https://ror.org/01f5ytq51","country_code":"US","type":"education","lineage":["https://openalex.org/I91045830"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Jaakko J\u00e4rvi","raw_affiliation_strings":["Texas A&amp;M University, College Station, TX","Texas A&M University, College Station. TX#TAB#"],"affiliations":[{"raw_affiliation_string":"Texas A&amp;M University, College Station, TX","institution_ids":["https://openalex.org/I91045830"]},{"raw_affiliation_string":"Texas A&M University, College Station. TX#TAB#","institution_ids":["https://openalex.org/I91045830"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5013769127","display_name":"Jeremiah Willcock","orcid":null},"institutions":[{"id":"https://openalex.org/I4210119109","display_name":"Indiana University Bloomington","ror":"https://ror.org/02k40bc56","country_code":"US","type":"education","lineage":["https://openalex.org/I4210119109","https://openalex.org/I592451"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Jeremiah Willcock","raw_affiliation_strings":["Indiana University, Bloomington, IN"],"affiliations":[{"raw_affiliation_string":"Indiana University, Bloomington, IN","institution_ids":["https://openalex.org/I4210119109"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5074260102","display_name":"Andrew Lumsdaine","orcid":"https://orcid.org/0000-0002-9153-6622"},"institutions":[{"id":"https://openalex.org/I4210119109","display_name":"Indiana University Bloomington","ror":"https://ror.org/02k40bc56","country_code":"US","type":"education","lineage":["https://openalex.org/I4210119109","https://openalex.org/I592451"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Andrew Lumsdaine","raw_affiliation_strings":["Indiana University, Bloomington, IN"],"affiliations":[{"raw_affiliation_string":"Indiana University, Bloomington, IN","institution_ids":["https://openalex.org/I4210119109"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5047665290"],"corresponding_institution_ids":["https://openalex.org/I91045830"],"apc_list":null,"apc_paid":null,"fwci":6.3937,"has_fulltext":false,"cited_by_count":31,"citation_normalized_percentile":{"value":0.96368157,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"1","last_page":"19"},"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.9998000264167786,"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.9998000264167786,"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/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9944000244140625,"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/T10260","display_name":"Software Engineering Research","score":0.982699990272522,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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/subtyping","display_name":"Subtyping","score":0.8339890241622925},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7331340312957764},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.7261368632316589},{"id":"https://openalex.org/keywords/object-oriented-programming","display_name":"Object-oriented programming","score":0.5902870893478394},{"id":"https://openalex.org/keywords/java","display_name":"Java","score":0.5245770812034607},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.5035995841026306},{"id":"https://openalex.org/keywords/formalism","display_name":"Formalism (music)","score":0.46169671416282654},{"id":"https://openalex.org/keywords/mainstream","display_name":"Mainstream","score":0.4512951076030731},{"id":"https://openalex.org/keywords/generic-programming","display_name":"Generic programming","score":0.43480297923088074},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.4299294948577881},{"id":"https://openalex.org/keywords/fifth-generation-programming-language","display_name":"Fifth-generation programming language","score":0.42482930421829224},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.31131911277770996},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.22316384315490723},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.210931658744812}],"concepts":[{"id":"https://openalex.org/C83852419","wikidata":"https://www.wikidata.org/wiki/Q2713292","display_name":"Subtyping","level":2,"score":0.8339890241622925},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7331340312957764},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7261368632316589},{"id":"https://openalex.org/C73752529","wikidata":"https://www.wikidata.org/wiki/Q79872","display_name":"Object-oriented programming","level":2,"score":0.5902870893478394},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.5245770812034607},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.5035995841026306},{"id":"https://openalex.org/C73301696","wikidata":"https://www.wikidata.org/wiki/Q5469984","display_name":"Formalism (music)","level":3,"score":0.46169671416282654},{"id":"https://openalex.org/C2777617010","wikidata":"https://www.wikidata.org/wiki/Q18957","display_name":"Mainstream","level":2,"score":0.4512951076030731},{"id":"https://openalex.org/C7051814","wikidata":"https://www.wikidata.org/wiki/Q1051282","display_name":"Generic programming","level":2,"score":0.43480297923088074},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.4299294948577881},{"id":"https://openalex.org/C199305712","wikidata":"https://www.wikidata.org/wiki/Q3205914","display_name":"Fifth-generation programming language","level":3,"score":0.42482930421829224},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.31131911277770996},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.22316384315490723},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.210931658744812},{"id":"https://openalex.org/C558565934","wikidata":"https://www.wikidata.org/wiki/Q2743","display_name":"Musical","level":2,"score":0.0},{"id":"https://openalex.org/C153349607","wikidata":"https://www.wikidata.org/wiki/Q36649","display_name":"Visual arts","level":1,"score":0.0},{"id":"https://openalex.org/C27206212","wikidata":"https://www.wikidata.org/wiki/Q34178","display_name":"Theology","level":1,"score":0.0},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C142362112","wikidata":"https://www.wikidata.org/wiki/Q735","display_name":"Art","level":0,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/1094811.1094813","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1094811.1094813","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 20th annual ACM SIGPLAN conference on Object-oriented programming, systems, languages, and applications","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.212.9819","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.212.9819","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.tamu.edu/academics/tr/tamu-cs-tr-2004-12-3/","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.218.674","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.218.674","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://parasol.tamu.edu/~jarvi/papers/oopsla05.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":35,"referenced_works":["https://openalex.org/W85530423","https://openalex.org/W176939601","https://openalex.org/W281292206","https://openalex.org/W1482171176","https://openalex.org/W1513612082","https://openalex.org/W1517904659","https://openalex.org/W1525643703","https://openalex.org/W1561299197","https://openalex.org/W1562955084","https://openalex.org/W1564310313","https://openalex.org/W1569578717","https://openalex.org/W1572663059","https://openalex.org/W1577182889","https://openalex.org/W1594279870","https://openalex.org/W1598339794","https://openalex.org/W1601726608","https://openalex.org/W1602755719","https://openalex.org/W1829244603","https://openalex.org/W1972445726","https://openalex.org/W2033348393","https://openalex.org/W2056821525","https://openalex.org/W2059895047","https://openalex.org/W2069037543","https://openalex.org/W2107214848","https://openalex.org/W2116616150","https://openalex.org/W2153657280","https://openalex.org/W2168938117","https://openalex.org/W2172232818","https://openalex.org/W2475431187","https://openalex.org/W2561675875","https://openalex.org/W2602645338","https://openalex.org/W2913972837","https://openalex.org/W2914964273","https://openalex.org/W4285719527","https://openalex.org/W4386688170"],"related_works":["https://openalex.org/W3027723509","https://openalex.org/W2733168542","https://openalex.org/W2563592207","https://openalex.org/W1510917942","https://openalex.org/W1507723317","https://openalex.org/W2552165488","https://openalex.org/W4298104918","https://openalex.org/W1810290248","https://openalex.org/W1595983599","https://openalex.org/W4318211903"],"abstract_inverted_index":{"Support":[0],"for":[1,65,79],"object-oriented":[2,94,172],"programming":[3,16],"has":[4,17,54],"become":[5],"an":[6],"integral":[7],"part":[8],"of":[9,43,51,60,69,86,109,145,152],"mainstream":[10,171],"languages,":[11],"and":[12,31,62,96,102,111,130,158],"more":[13],"recently":[14],"generic":[15,52,87],"gained":[18],"widespread":[19],"acceptance":[20],"as":[21,178],"well.":[22],"A":[23],"natural":[24],"question":[25],"is":[26,167],"how":[27],"these":[28,140],"two":[29],"paradigms,":[30],"their":[32,131,163],"underlying":[33],"language":[34],"mechanisms,":[35],"should":[36],"interact.":[37],"One":[38],"particular":[39],"design":[40],"option,":[41],"that":[42],"using":[44,77],"subtyping":[45,78,97],"to":[46,98,121,156,169],"constrain":[47],"the":[48,58,84,143,153],"type":[49,107,119,136],"parameters":[50,120,129],"functions,":[53],"been":[55,74],"chosen":[56],"in":[57,76,83,133,142],"generics":[59],"Java":[61],"those":[63,128],"planned":[64],"a":[66,150,160],"future":[67],"revision":[68],"C#.Certain":[70],"shortcomings":[71],"have":[72],"previously":[73],"identified":[75],"constraining":[80],"parametric":[81],"polymorphism":[82],"context":[85,144],"programming.To":[88],"address":[89],"these,":[90],"we":[91],"propose":[92],"extending":[93],"interfaces":[95,110],"include":[99],"associated":[100],"types":[101,105],"constraint":[103],"propagation.Associated":[104],"are":[106],"members":[108],"classes.":[112],"Constraint":[113],"propagation":[114],"allows":[115],"certain":[116],"constraints":[117,126],"on":[118,127],"be":[122],"inferred":[123],"from":[124],"other":[125,170],"use":[132],"base":[134],"class":[135],"expressions.The":[137],"paper":[138],"demonstrates":[139],"extensions":[141],"C#":[146],"(with":[147],"generics),":[148],"describes":[149],"translation":[151],"extended":[154],"features":[155],"C#,":[157],"presents":[159],"formalism":[161,166],"proving":[162],"safety.":[164],"The":[165],"applicable":[168],"languages":[173],"supporting":[174],"F-bounded":[175],"polymorphism,":[176],"such":[177],"Java.":[179]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":2},{"year":2015,"cited_by_count":2},{"year":2014,"cited_by_count":1},{"year":2012,"cited_by_count":1}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
