{"id":"https://openalex.org/W4307731848","doi":"https://doi.org/10.1145/3563301","title":"Wildcards need witness protection","display_name":"Wildcards need witness protection","publication_year":2022,"publication_date":"2022-10-31","ids":{"openalex":"https://openalex.org/W4307731848","doi":"https://doi.org/10.1145/3563301"},"language":"en","primary_location":{"id":"doi:10.1145/3563301","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3563301","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3563301","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3563301","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5055961747","display_name":"Kevin Bierhoff","orcid":null},"institutions":[{"id":"https://openalex.org/I1291425158","display_name":"Google (United States)","ror":"https://ror.org/00njsd438","country_code":"US","type":"company","lineage":["https://openalex.org/I1291425158","https://openalex.org/I4210128969"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Kevin Bierhoff","raw_affiliation_strings":["Google, USA"],"raw_orcid":"https://orcid.org/0000-0002-6563-5360","affiliations":[{"raw_affiliation_string":"Google, USA","institution_ids":["https://openalex.org/I1291425158"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5055961747"],"corresponding_institution_ids":["https://openalex.org/I1291425158"],"apc_list":null,"apc_paid":null,"fwci":0.1385,"has_fulltext":true,"cited_by_count":1,"citation_normalized_percentile":{"value":0.55692694,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":94},"biblio":{"volume":"6","issue":"OOPSLA2","first_page":"373","last_page":"394"},"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.9997000098228455,"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.9997000098228455,"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.9962999820709229,"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"}},{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9878000020980835,"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/soundness","display_name":"Soundness","score":0.8265736103057861},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7552675008773804},{"id":"https://openalex.org/keywords/subtyping","display_name":"Subtyping","score":0.7403802871704102},{"id":"https://openalex.org/keywords/witness","display_name":"Witness","score":0.709380030632019},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6947609186172485},{"id":"https://openalex.org/keywords/type-safety","display_name":"Type safety","score":0.6430401802062988},{"id":"https://openalex.org/keywords/java","display_name":"Java","score":0.6403123736381531},{"id":"https://openalex.org/keywords/false-positive-paradox","display_name":"False positive paradox","score":0.5545319318771362},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.5315012335777283},{"id":"https://openalex.org/keywords/mathematical-proof","display_name":"Mathematical proof","score":0.4867546558380127},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.4368383586406708},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.4293053150177002},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.416687935590744},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.24999096989631653},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.21885272860527039},{"id":"https://openalex.org/keywords/computer-security","display_name":"Computer security","score":0.14097797870635986},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.12497419118881226}],"concepts":[{"id":"https://openalex.org/C39920170","wikidata":"https://www.wikidata.org/wiki/Q693083","display_name":"Soundness","level":2,"score":0.8265736103057861},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7552675008773804},{"id":"https://openalex.org/C83852419","wikidata":"https://www.wikidata.org/wiki/Q2713292","display_name":"Subtyping","level":2,"score":0.7403802871704102},{"id":"https://openalex.org/C2776900844","wikidata":"https://www.wikidata.org/wiki/Q8028383","display_name":"Witness","level":2,"score":0.709380030632019},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6947609186172485},{"id":"https://openalex.org/C44779574","wikidata":"https://www.wikidata.org/wiki/Q736866","display_name":"Type safety","level":2,"score":0.6430401802062988},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.6403123736381531},{"id":"https://openalex.org/C64869954","wikidata":"https://www.wikidata.org/wiki/Q1859747","display_name":"False positive paradox","level":2,"score":0.5545319318771362},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.5315012335777283},{"id":"https://openalex.org/C108710211","wikidata":"https://www.wikidata.org/wiki/Q11538","display_name":"Mathematical proof","level":2,"score":0.4867546558380127},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.4368383586406708},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.4293053150177002},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.416687935590744},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.24999096989631653},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.21885272860527039},{"id":"https://openalex.org/C38652104","wikidata":"https://www.wikidata.org/wiki/Q3510521","display_name":"Computer security","level":1,"score":0.14097797870635986},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.12497419118881226},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3563301","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3563301","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3563301","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1145/3563301","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3563301","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3563301","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","id":"https://metadata.un.org/sdg/16","score":0.7200000286102295}],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4307731848.pdf","grobid_xml":"https://content.openalex.org/works/W4307731848.grobid-xml"},"referenced_works_count":16,"referenced_works":["https://openalex.org/W1557561422","https://openalex.org/W1558128491","https://openalex.org/W2033348393","https://openalex.org/W2033485121","https://openalex.org/W2065141544","https://openalex.org/W2067901725","https://openalex.org/W2080648611","https://openalex.org/W2106355420","https://openalex.org/W2125044336","https://openalex.org/W2128769069","https://openalex.org/W2533631495","https://openalex.org/W3010821527","https://openalex.org/W4241904514","https://openalex.org/W4244046502","https://openalex.org/W4302984605","https://openalex.org/W6966995401"],"related_works":["https://openalex.org/W2593125519","https://openalex.org/W2098515467","https://openalex.org/W1837104076","https://openalex.org/W2023127104","https://openalex.org/W2418777044","https://openalex.org/W3154627631","https://openalex.org/W2949178056","https://openalex.org/W2754865860","https://openalex.org/W3177942140","https://openalex.org/W822411571"],"abstract_inverted_index":{"In":[0],"this":[1,32,66,70],"paper,":[2],"we":[3],"show":[4,64],"that":[5,35,40,65,111,119],"the":[6,21],"unsoundness":[7,113],"discovered":[8],"by":[9],"Amin":[10],"and":[11,76,101,118],"Tate":[12],"(2016)":[13],"in":[14,20,37,94],"Java\u2019s":[15],"wildcards":[16],"is":[17,34,68],"avoidable,":[18],"even":[19],"absence":[22],"of":[23,31,98],"a":[24,73,82,95],"nullness-aware":[25],"type":[26,38,61],"system.":[27],"The":[28],"key":[29],"insight":[30],"paper":[33,71],"soundness":[36],"systems":[39],"implicitly":[41],"introduce":[42],"existential":[43],"types":[44,56],"through":[45],"subtyping":[46],"hinges":[47],"on":[48,86],"still":[49],"making":[50],"sure":[51],"there":[52],"are":[53],"suitable":[54],"witness":[55],"when":[57],"introducing":[58],"existentially":[59],"quantified":[60],"variables.":[62],"To":[63],"approach":[67,88,121],"viable,":[69],"formalizes":[72],"core":[74],"calculus":[75],"proves":[77],"it":[78,124],"sound.":[79],"We":[80],"used":[81],"static":[83],"analysis":[84],"based":[85],"our":[87,120],"to":[89],"look":[90],"for":[91],"potential":[92],"issues":[93],"vast":[96],"corpus":[97],"Java":[99],"code":[100],"found":[102],"none":[103],"(with":[104],"1":[105],"false":[106,128],"positive).":[107],"This":[108],"confirms":[109],"both":[110],"Java's":[112],"has":[114],"minimal":[115,127],"practical":[116],"consequence,":[117],"can":[122],"avoid":[123],"entirely":[125],"with":[126],"positives.":[129]},"counts_by_year":[{"year":2023,"cited_by_count":1}],"updated_date":"2026-05-05T08:41:31.759640","created_date":"2025-10-10T00:00:00"}
