{"id":"https://openalex.org/W2014220905","doi":"https://doi.org/10.1145/1449764.1449799","title":"The visitor pattern as a reusable, generic, type-safe component","display_name":"The visitor pattern as a reusable, generic, type-safe component","publication_year":2008,"publication_date":"2008-10-19","ids":{"openalex":"https://openalex.org/W2014220905","doi":"https://doi.org/10.1145/1449764.1449799","mag":"2014220905"},"language":"en","primary_location":{"id":"doi:10.1145/1449764.1449799","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1449764.1449799","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 23rd ACM SIGPLAN conference on Object-oriented programming systems languages and applications","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://kar.kent.ac.uk/47470/1/local_143543.pdf","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5049714036","display_name":"Bruno C. d. S. Oliveira","orcid":"https://orcid.org/0000-0002-1846-7210"},"institutions":[{"id":"https://openalex.org/I40120149","display_name":"University of Oxford","ror":"https://ror.org/052gg0110","country_code":"GB","type":"education","lineage":["https://openalex.org/I40120149"]}],"countries":["GB"],"is_corresponding":true,"raw_author_name":"Bruno C.d.S. Oliveira","raw_affiliation_strings":["University of Oxford, Oxford, United Kingdom"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Oxford, Oxford, United Kingdom","institution_ids":["https://openalex.org/I40120149"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5074307489","display_name":"Meng Wang","orcid":"https://orcid.org/0000-0001-7780-630X"},"institutions":[{"id":"https://openalex.org/I40120149","display_name":"University of Oxford","ror":"https://ror.org/052gg0110","country_code":"GB","type":"education","lineage":["https://openalex.org/I40120149"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Meng Wang","raw_affiliation_strings":["University of Oxford, Oxford, United Kingdom"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Oxford, Oxford, United Kingdom","institution_ids":["https://openalex.org/I40120149"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5086558126","display_name":"Jeremy Gibbons","orcid":"https://orcid.org/0000-0002-8426-9917"},"institutions":[{"id":"https://openalex.org/I40120149","display_name":"University of Oxford","ror":"https://ror.org/052gg0110","country_code":"GB","type":"education","lineage":["https://openalex.org/I40120149"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Jeremy Gibbons","raw_affiliation_strings":["University of Oxford, Oxford, United Kingdom"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"University of Oxford, Oxford, United Kingdom","institution_ids":["https://openalex.org/I40120149"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5049714036"],"corresponding_institution_ids":["https://openalex.org/I40120149"],"apc_list":null,"apc_paid":null,"fwci":9.3987,"has_fulltext":true,"cited_by_count":44,"citation_normalized_percentile":{"value":0.9763093,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"439","last_page":"456"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","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"}},"topics":[{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","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/T10126","display_name":"Logic, programming, and type systems","score":0.9929999709129333,"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/T11450","display_name":"Model-Driven Software Engineering Techniques","score":0.991599977016449,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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/visitor-pattern","display_name":"Visitor pattern","score":0.9307413101196289},{"id":"https://openalex.org/keywords/hierarchy","display_name":"Hierarchy","score":0.8137880563735962},{"id":"https://openalex.org/keywords/flexibility","display_name":"Flexibility (engineering)","score":0.6792877912521362},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.678658127784729},{"id":"https://openalex.org/keywords/component","display_name":"Component (thermodynamics)","score":0.6033915281295776},{"id":"https://openalex.org/keywords/design-pattern","display_name":"Design pattern","score":0.5595043897628784},{"id":"https://openalex.org/keywords/object","display_name":"Object (grammar)","score":0.5595006346702576},{"id":"https://openalex.org/keywords/object-oriented-programming","display_name":"Object-oriented programming","score":0.4151514768600464},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.36350345611572266},{"id":"https://openalex.org/keywords/human\u2013computer-interaction","display_name":"Human\u2013computer interaction","score":0.3537599742412567},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.30650678277015686},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.1265663504600525}],"concepts":[{"id":"https://openalex.org/C48947383","wikidata":"https://www.wikidata.org/wiki/Q830719","display_name":"Visitor pattern","level":2,"score":0.9307413101196289},{"id":"https://openalex.org/C31170391","wikidata":"https://www.wikidata.org/wiki/Q188619","display_name":"Hierarchy","level":2,"score":0.8137880563735962},{"id":"https://openalex.org/C2780598303","wikidata":"https://www.wikidata.org/wiki/Q65921492","display_name":"Flexibility (engineering)","level":2,"score":0.6792877912521362},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.678658127784729},{"id":"https://openalex.org/C168167062","wikidata":"https://www.wikidata.org/wiki/Q1117970","display_name":"Component (thermodynamics)","level":2,"score":0.6033915281295776},{"id":"https://openalex.org/C14501506","wikidata":"https://www.wikidata.org/wiki/Q5253831","display_name":"Design pattern","level":2,"score":0.5595043897628784},{"id":"https://openalex.org/C2781238097","wikidata":"https://www.wikidata.org/wiki/Q175026","display_name":"Object (grammar)","level":2,"score":0.5595006346702576},{"id":"https://openalex.org/C73752529","wikidata":"https://www.wikidata.org/wiki/Q79872","display_name":"Object-oriented programming","level":2,"score":0.4151514768600464},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.36350345611572266},{"id":"https://openalex.org/C107457646","wikidata":"https://www.wikidata.org/wiki/Q207434","display_name":"Human\u2013computer interaction","level":1,"score":0.3537599742412567},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.30650678277015686},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.1265663504600525},{"id":"https://openalex.org/C97355855","wikidata":"https://www.wikidata.org/wiki/Q11473","display_name":"Thermodynamics","level":1,"score":0.0},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C34447519","wikidata":"https://www.wikidata.org/wiki/Q179522","display_name":"Market economy","level":1,"score":0.0},{"id":"https://openalex.org/C105795698","wikidata":"https://www.wikidata.org/wiki/Q12483","display_name":"Statistics","level":1,"score":0.0},{"id":"https://openalex.org/C162324750","wikidata":"https://www.wikidata.org/wiki/Q8134","display_name":"Economics","level":0,"score":0.0}],"mesh":[],"locations_count":12,"locations":[{"id":"doi:10.1145/1449764.1449799","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1449764.1449799","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 23rd ACM SIGPLAN conference on Object-oriented programming systems languages and applications","raw_type":"proceedings-article"},{"id":"pmh:oai:kar.kent.ac.uk:47470","is_oa":true,"landing_page_url":null,"pdf_url":"https://kar.kent.ac.uk/47470/1/local_143543.pdf","source":{"id":"https://openalex.org/S4377196264","display_name":"Kent Academic Repository (University of Kent)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I20581793","host_organization_name":"University of Kent","host_organization_lineage":["https://openalex.org/I20581793"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"acceptedVersion","is_accepted":true,"is_published":false,"raw_source_name":null,"raw_type":"PeerReviewed"},{"id":"pmh:oai:research.chalmers.se:143543","is_oa":true,"landing_page_url":"https://research.chalmers.se/en/publication/143543","pdf_url":"http://publications.lib.chalmers.se/records/fulltext/local_143543.pdf","source":{"id":"https://openalex.org/S4306402469","display_name":"Chalmers Research (Chalmers University of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I66862912","host_organization_name":"Chalmers University of Technology","host_organization_lineage":["https://openalex.org/I66862912"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":""},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.205.2295","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.205.2295","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.comlab.ox.ac.uk/jeremy.gibbons/publications/visitor.pdf","raw_type":"text"},{"id":"pmh:oai:hub.hku.hk:10722/188480","is_oa":false,"landing_page_url":"http://hdl.handle.net/10722/188480","pdf_url":null,"source":{"id":"https://openalex.org/S4377196271","display_name":"The HKU Scholars Hub (University of Hong Kong)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I889458895","host_organization_name":"University of Hong Kong","host_organization_lineage":["https://openalex.org/I889458895"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Conference_Paper"},{"id":"pmh:oai:ora.ox.ac.uk:uuid:65a95b15-a95e-4551-a20b-66fd0be9cf11","is_oa":false,"landing_page_url":"https://ora.ox.ac.uk/objects/uuid:65a95b15-a95e-4551-a20b-66fd0be9cf11","pdf_url":null,"source":{"id":"https://openalex.org/S4306402636","display_name":"Oxford University Research Archive (ORA) (University of Oxford)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I40120149","host_organization_name":"University of Oxford","host_organization_lineage":["https://openalex.org/I40120149"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Symplectic Elements at Oxford","raw_type":"Conference"},{"id":"pmh:oai:ora.ox.ac.uk:uuid:89735ff8-203c-452f-929a-695e61b09864","is_oa":false,"landing_page_url":"https://ora.ox.ac.uk/objects/uuid:89735ff8-203c-452f-929a-695e61b09864","pdf_url":null,"source":{"id":"https://openalex.org/S4306402636","display_name":"Oxford University Research Archive (ORA) (University of Oxford)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I40120149","host_organization_name":"University of Oxford","host_organization_lineage":["https://openalex.org/I40120149"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Symplectic Elements at Oxford","raw_type":"Journal article"},{"id":"pmh:oai:publications.lib.chalmers.se:143543","is_oa":false,"landing_page_url":"http://publications.lib.chalmers.se/publication/143543-the-visitor-pattern-as-a-reusable-generic-typesafe-component","pdf_url":null,"source":{"id":"https://openalex.org/S4377196470","display_name":"Chalmers Publication Library (Chalmers University of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I66862912","host_organization_name":"Chalmers University of Technology","host_organization_lineage":["https://openalex.org/I66862912"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Text.Article.Conference.PeerReviewed"},{"id":"pmh:oai:publications.lib.chalmers.se:180410","is_oa":false,"landing_page_url":"http://publications.lib.chalmers.se/publication/180410-the-visitor-pattern-as-a-reusable-generic-type-safe-component","pdf_url":null,"source":{"id":"https://openalex.org/S4377196470","display_name":"Chalmers Publication Library (Chalmers University of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I66862912","host_organization_name":"Chalmers University of Technology","host_organization_lineage":["https://openalex.org/I66862912"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Text.Article.Journal.PeerReviewed"},{"id":"pmh:oai:research-information.bris.ac.uk:openaire/a686f6bf-53ca-4973-8beb-ce8198f24558","is_oa":true,"landing_page_url":"https://research-information.bris.ac.uk/en/publications/a686f6bf-53ca-4973-8beb-ce8198f24558","pdf_url":null,"source":{"id":"https://openalex.org/S7407055359","display_name":"Explore Bristol Research","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Oliveira, B, Wang, M & Gibbons, J 2008, The visitor pattern as a reusable, generic, type-safe component. in OOPSLA '08 Proceedings of the 23rd ACM SIGPLAN conference on Object-oriented programming systems languages and applications . Association for Computing Machinery, pp. 439. https://doi.org/10.1145/1449764.1449799","raw_type":"contributionToPeriodical"},{"id":"pmh:oai:research-information.bris.ac.uk:openaire_cris_publications/a686f6bf-53ca-4973-8beb-ce8198f24558","is_oa":true,"landing_page_url":"https://hdl.handle.net/1983/a686f6bf-53ca-4973-8beb-ce8198f24558","pdf_url":null,"source":{"id":"https://openalex.org/S4306400895","display_name":"Bristol Research (University of Bristol)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I36234482","host_organization_name":"University of Bristol","host_organization_lineage":["https://openalex.org/I36234482"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Oliveira, B, Wang, M & Gibbons, J 2008, The visitor pattern as a reusable, generic, type-safe component. in OOPSLA '08 Proceedings of the 23rd ACM SIGPLAN conference on Object-oriented programming systems languages and applications . Association for Computing Machinery, pp. 439. https://doi.org/10.1145/1449764.1449799","raw_type":"contributionToPeriodical"},{"id":"pmh:oai:research.chalmers.se:180410","is_oa":false,"landing_page_url":"https://research.chalmers.se/en/publication/180410","pdf_url":null,"source":{"id":"https://openalex.org/S4306402469","display_name":"Chalmers Research (Chalmers University of Technology)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I66862912","host_organization_name":"Chalmers University of Technology","host_organization_lineage":["https://openalex.org/I66862912"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":""}],"best_oa_location":{"id":"pmh:oai:kar.kent.ac.uk:47470","is_oa":true,"landing_page_url":null,"pdf_url":"https://kar.kent.ac.uk/47470/1/local_143543.pdf","source":{"id":"https://openalex.org/S4377196264","display_name":"Kent Academic Repository (University of Kent)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I20581793","host_organization_name":"University of Kent","host_organization_lineage":["https://openalex.org/I20581793"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"acceptedVersion","is_accepted":true,"is_published":false,"raw_source_name":null,"raw_type":"PeerReviewed"},"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G3176855324","display_name":null,"funder_award_id":"EP/E02128X/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"}],"funders":[{"id":"https://openalex.org/F4320334627","display_name":"Engineering and Physical Sciences Research Council","ror":"https://ror.org/0439y7842"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2014220905.pdf","grobid_xml":"https://content.openalex.org/works/W2014220905.grobid-xml"},"referenced_works_count":53,"referenced_works":["https://openalex.org/W135437107","https://openalex.org/W159715351","https://openalex.org/W1486418440","https://openalex.org/W1513579486","https://openalex.org/W1520318394","https://openalex.org/W1556226926","https://openalex.org/W1556536463","https://openalex.org/W1563480347","https://openalex.org/W1571615440","https://openalex.org/W1586902756","https://openalex.org/W1649645444","https://openalex.org/W1965784613","https://openalex.org/W1985441691","https://openalex.org/W1989554087","https://openalex.org/W1991604845","https://openalex.org/W2002293839","https://openalex.org/W2033185534","https://openalex.org/W2048569219","https://openalex.org/W2051096181","https://openalex.org/W2054373994","https://openalex.org/W2055970549","https://openalex.org/W2089576225","https://openalex.org/W2097964082","https://openalex.org/W2099081229","https://openalex.org/W2111609583","https://openalex.org/W2116244845","https://openalex.org/W2120132421","https://openalex.org/W2120487396","https://openalex.org/W2122692581","https://openalex.org/W2127581079","https://openalex.org/W2130983842","https://openalex.org/W2131905908","https://openalex.org/W2134281169","https://openalex.org/W2143238865","https://openalex.org/W2143566245","https://openalex.org/W2145945984","https://openalex.org/W2149887368","https://openalex.org/W2150101804","https://openalex.org/W2161825580","https://openalex.org/W2164067955","https://openalex.org/W2173780645","https://openalex.org/W2323777246","https://openalex.org/W2521163914","https://openalex.org/W2913811625","https://openalex.org/W3005523836","https://openalex.org/W4244792373","https://openalex.org/W6606522490","https://openalex.org/W6631270632","https://openalex.org/W6633451899","https://openalex.org/W6635242822","https://openalex.org/W6726636036","https://openalex.org/W6759164395","https://openalex.org/W6805912654"],"related_works":["https://openalex.org/W2389484663","https://openalex.org/W100279264","https://openalex.org/W2962094963","https://openalex.org/W3035526107","https://openalex.org/W3210442065","https://openalex.org/W2263713325","https://openalex.org/W2124937005","https://openalex.org/W1915061844","https://openalex.org/W2089747539","https://openalex.org/W2094462237"],"abstract_inverted_index":{"The":[0,22],"VISITOR":[1],"design":[2],"pattern":[3,23,36],"shows":[4],"how":[5],"to":[6,33],"separate":[7],"the":[8,15,35],"structure":[9],"of":[10,17],"an":[11],"object":[12],"hierarchy":[13],"from":[14],"behaviour":[16],"traversals":[18],"over":[19],"that":[20],"hierarchy.":[21],"is":[24],"very":[25,28],"flexible;":[26],"this":[27],"flexibility":[29],"makes":[30],"it":[31],"difficult":[32],"capture":[34],"as":[37],"anything":[38],"more":[39],"formal":[40],"than":[41],"prose,":[42],"pictures":[43],"and":[44],"prototypes.":[45]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":2},{"year":2020,"cited_by_count":1},{"year":2019,"cited_by_count":2},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":1},{"year":2015,"cited_by_count":3},{"year":2014,"cited_by_count":3},{"year":2013,"cited_by_count":7},{"year":2012,"cited_by_count":6}],"updated_date":"2026-05-23T08:51:43.019350","created_date":"2025-10-10T00:00:00"}
