{"id":"https://openalex.org/W3010821527","doi":"https://doi.org/10.1145/3428243","title":"A type-and-effect system for object initialization","display_name":"A type-and-effect system for object initialization","publication_year":2020,"publication_date":"2020-11-13","ids":{"openalex":"https://openalex.org/W3010821527","doi":"https://doi.org/10.1145/3428243","mag":"3010821527"},"language":"en","primary_location":{"id":"doi:10.1145/3428243","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3428243","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3428243","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/3428243","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5067905121","display_name":"Fengyun Liu","orcid":"https://orcid.org/0000-0002-2066-8492"},"institutions":[{"id":"https://openalex.org/I5124864","display_name":"\u00c9cole Polytechnique F\u00e9d\u00e9rale de Lausanne","ror":"https://ror.org/02s376052","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I5124864"]}],"countries":["CH"],"is_corresponding":true,"raw_author_name":"Fengyun Liu","raw_affiliation_strings":["EPFL, Switzerland"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"EPFL, Switzerland","institution_ids":["https://openalex.org/I5124864"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5039616179","display_name":"Ond\u0159ej Lhot\u00e1k","orcid":"https://orcid.org/0000-0001-9066-1889"},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Ond\u0159ej Lhot\u00e1k","raw_affiliation_strings":["University of Waterloo, Canada"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Waterloo, Canada","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5089315679","display_name":"Aggelos Biboudis","orcid":null},"institutions":[{"id":"https://openalex.org/I5124864","display_name":"\u00c9cole Polytechnique F\u00e9d\u00e9rale de Lausanne","ror":"https://ror.org/02s376052","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I5124864"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Aggelos Biboudis","raw_affiliation_strings":["EPFL, Switzerland"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"EPFL, Switzerland","institution_ids":["https://openalex.org/I5124864"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5030151158","display_name":"Paolo G. Giarrusso","orcid":null},"institutions":[{"id":"https://openalex.org/I98358874","display_name":"Delft University of Technology","ror":"https://ror.org/02e2c7k09","country_code":"NL","type":"education","lineage":["https://openalex.org/I98358874"]}],"countries":["NL"],"is_corresponding":false,"raw_author_name":"Paolo G. Giarrusso","raw_affiliation_strings":["Delft University of Technology, Netherlands"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Delft University of Technology, Netherlands","institution_ids":["https://openalex.org/I98358874"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5085410724","display_name":"Martin Odersky","orcid":"https://orcid.org/0009-0005-3923-8993"},"institutions":[{"id":"https://openalex.org/I5124864","display_name":"\u00c9cole Polytechnique F\u00e9d\u00e9rale de Lausanne","ror":"https://ror.org/02s376052","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I5124864"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Martin Odersky","raw_affiliation_strings":["EPFL, Switzerland"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"EPFL, Switzerland","institution_ids":["https://openalex.org/I5124864"]}]}],"institutions":[],"countries_distinct_count":3,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5067905121"],"corresponding_institution_ids":["https://openalex.org/I5124864"],"apc_list":null,"apc_paid":null,"fwci":0.9521,"has_fulltext":true,"cited_by_count":8,"citation_normalized_percentile":{"value":0.80563303,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":"4","issue":"OOPSLA","first_page":"1","last_page":"28"},"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.9994000196456909,"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.9994000196456909,"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/T11424","display_name":"Security and Verification in Computing","score":0.9983999729156494,"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.9932000041007996,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/initialization","display_name":"Initialization","score":0.9699417352676392},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8231318593025208},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.6822678446769714},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6369258165359497},{"id":"https://openalex.org/keywords/java","display_name":"Java","score":0.5976626873016357},{"id":"https://openalex.org/keywords/scala","display_name":"Scala","score":0.525242805480957},{"id":"https://openalex.org/keywords/object","display_name":"Object (grammar)","score":0.4507928490638733},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3875393569469452},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.35123154520988464},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.2989690899848938}],"concepts":[{"id":"https://openalex.org/C114466953","wikidata":"https://www.wikidata.org/wiki/Q6034165","display_name":"Initialization","level":2,"score":0.9699417352676392},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8231318593025208},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.6822678446769714},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6369258165359497},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.5976626873016357},{"id":"https://openalex.org/C109701466","wikidata":"https://www.wikidata.org/wiki/Q460584","display_name":"Scala","level":3,"score":0.525242805480957},{"id":"https://openalex.org/C2781238097","wikidata":"https://www.wikidata.org/wiki/Q175026","display_name":"Object (grammar)","level":2,"score":0.4507928490638733},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3875393569469452},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.35123154520988464},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.2989690899848938}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1145/3428243","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3428243","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3428243","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"},{"id":"pmh:oai:infoscience.epfl.ch:273643","is_oa":true,"landing_page_url":"http://infoscience.epfl.ch/record/273643","pdf_url":null,"source":{"id":"https://openalex.org/S4306400487","display_name":"Infoscience (Ecole Polytechnique F\u00e9d\u00e9rale de Lausanne)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by-nc-nd","license_id":"https://openalex.org/licenses/cc-by-nc-nd","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"report"},{"id":"pmh:oai:infoscience.epfl.ch:288523","is_oa":true,"landing_page_url":"https://infoscience.epfl.ch/handle/20.500.14299/181296","pdf_url":null,"source":{"id":"https://openalex.org/S4306400487","display_name":"Infoscience (Ecole Polytechnique F\u00e9d\u00e9rale de Lausanne)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by-nc-nd","license_id":"https://openalex.org/licenses/cc-by-nc-nd","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"WoS","raw_type":"research article"},{"id":"pmh:oai:tudelft.nl:uuid:82553189-b777-4753-ab85-a2e80ad7ba2c","is_oa":true,"landing_page_url":"http://resolver.tudelft.nl/uuid:82553189-b777-4753-ab85-a2e80ad7ba2c","pdf_url":null,"source":{"id":"https://openalex.org/S4306400906","display_name":"Research Repository (Delft University of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I98358874","host_organization_name":"Delft University of Technology","host_organization_lineage":["https://openalex.org/I98358874"],"host_organization_lineage_names":[],"type":"repository"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"journal article"}],"best_oa_location":{"id":"doi:10.1145/3428243","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3428243","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3428243","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":[{"score":0.5400000214576721,"id":"https://metadata.un.org/sdg/17","display_name":"Partnerships for the goals"}],"awards":[{"id":"https://openalex.org/G5291884993","display_name":null,"funder_award_id":"200021_166154","funder_id":"https://openalex.org/F4320320924","funder_display_name":"Schweizerischer Nationalfonds zur F\u00f6rderung der Wissenschaftlichen Forschung"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320320924","display_name":"Schweizerischer Nationalfonds zur F\u00f6rderung der Wissenschaftlichen Forschung","ror":"https://ror.org/00yjd3n13"},{"id":"https://openalex.org/F4320334593","display_name":"Natural Sciences and Engineering Research Council of Canada","ror":"https://ror.org/01h531d29"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W3010821527.pdf","grobid_xml":"https://content.openalex.org/works/W3010821527.grobid-xml"},"referenced_works_count":18,"referenced_works":["https://openalex.org/W117718117","https://openalex.org/W172676560","https://openalex.org/W1553894716","https://openalex.org/W1557561422","https://openalex.org/W1610722504","https://openalex.org/W2006872422","https://openalex.org/W2044590882","https://openalex.org/W2046137117","https://openalex.org/W2065266923","https://openalex.org/W2067901725","https://openalex.org/W2069454232","https://openalex.org/W2112059836","https://openalex.org/W2125044336","https://openalex.org/W2128769069","https://openalex.org/W2296012152","https://openalex.org/W2505720433","https://openalex.org/W2560908054","https://openalex.org/W3014861752"],"related_works":["https://openalex.org/W4248962295","https://openalex.org/W2911968761","https://openalex.org/W2890121425","https://openalex.org/W2204875185","https://openalex.org/W205696660","https://openalex.org/W2526343417","https://openalex.org/W3204184292","https://openalex.org/W4232952072","https://openalex.org/W3040669356","https://openalex.org/W4211064201"],"abstract_inverted_index":{"Every":[0],"newly":[1],"created":[2],"object":[3,28,50],"goes":[4],"through":[5],"several":[6,193],"initialization":[7,31,46,70,95,111,124,147,173,178,183],"states:":[8],"starting":[9],"from":[10],"a":[11,77,165],"state":[12],"where":[13],"all":[14,19],"fields":[15,56],"are":[16,22],"uninitialized":[17],"until":[18],"of":[20,48,63,69,131],"them":[21,106],"assigned.":[23],"Any":[24],"operation":[25],"on":[26,86,192],"the":[27,37,45,49,73,140,186],"during":[29],"its":[30],"process,":[32],"which":[33,148],"usually":[34],"happens":[35],"in":[36,72,185],"constructor":[38],"via":[39,157],"this":[40,64,87,160],",":[41],"has":[42,120],"to":[43,80],"observe":[44],"states":[47,71],"for":[51,128],"correctness,":[52],"i.e.":[53],"only":[54],"initialized":[55],"may":[57],"be":[58,126],"used.":[59],"Checking":[60],"safe":[61,123],"usage":[62],"statically,":[65],"without":[66],"manual":[67],"annotation":[68],"source":[74],"code,":[75],"is":[76],"challenge,":[78],"due":[79],"aliasing":[81],"and":[82,152,190],"virtual":[83],"method":[84],"calls":[85],".":[88],"Mainstream":[89],"languages":[90],"either":[91],"do":[92],"not":[93,108],"check":[94],"errors,":[96],"such":[97,113],"as":[98,114],"Java,":[99],"C++,":[100],"Scala,":[101],"or":[102],"they":[103],"defend":[104],"against":[105],"by":[107,134,142],"supporting":[109],"useful":[110],"patterns,":[112],"Swift.":[115],"In":[116],"parallel,":[117],"past":[118],"research":[119],"shown":[121],"that":[122,169],"can":[125,170],"achieved":[127],"varying":[129],"degrees":[130],"expressiveness":[132],"but":[133],"sacrificing":[135],"syntactic":[136],"simplicity.":[137],"We":[138,180],"approach":[139],"problem":[141],"upholding":[143],"local":[144],"reasoning":[145],"about":[146],"avoids":[149],"whole-program":[150],"analysis,":[151],"we":[153,162],"achieve":[154],"typestate":[155],"polymorphism":[156],"subtyping.":[158],"On":[159],"basis,":[161],"put":[163],"forward":[164],"novel":[166],"type-and-effect":[167],"system":[168],"effectively":[171],"ensure":[172],"safety":[174],"while":[175],"allowing":[176],"flexible":[177],"patterns.":[179],"implement":[181],"an":[182],"checker":[184],"Scala":[187],"3":[188],"compiler":[189],"evaluate":[191],"real-world":[194],"projects.":[195]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":4},{"year":2021,"cited_by_count":2}],"updated_date":"2026-05-21T06:26:12.895304","created_date":"2025-10-10T00:00:00"}
