{"id":"https://openalex.org/W4321446125","doi":"https://doi.org/10.1145/3572848.3577481","title":"Fast and Scalable Channels in Kotlin Coroutines","display_name":"Fast and Scalable Channels in Kotlin Coroutines","publication_year":2023,"publication_date":"2023-02-21","ids":{"openalex":"https://openalex.org/W4321446125","doi":"https://doi.org/10.1145/3572848.3577481"},"language":"en","primary_location":{"id":"doi:10.1145/3572848.3577481","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3572848.3577481","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 28th ACM SIGPLAN Annual Symposium on Principles and Practice of Parallel Programming","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/A5047006729","display_name":"Nikita Koval","orcid":"https://orcid.org/0000-0002-1260-4616"},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Nikita Koval","raw_affiliation_strings":["JetBrains, The Netherlands"],"affiliations":[{"raw_affiliation_string":"JetBrains, The Netherlands","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5083822059","display_name":"Dan Alistarh","orcid":"https://orcid.org/0000-0003-3650-940X"},"institutions":[{"id":"https://openalex.org/I157556583","display_name":"Institute of Science and Technology Austria","ror":"https://ror.org/03gnh5541","country_code":"AT","type":"education","lineage":["https://openalex.org/I157556583"]}],"countries":["AT"],"is_corresponding":false,"raw_author_name":"Dan Alistarh","raw_affiliation_strings":["IST Austria, Austria"],"affiliations":[{"raw_affiliation_string":"IST Austria, Austria","institution_ids":["https://openalex.org/I157556583"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5033128880","display_name":"Roman Elizarov","orcid":null},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Roman Elizarov","raw_affiliation_strings":["JetBrains, The Netherlands"],"affiliations":[{"raw_affiliation_string":"JetBrains, The Netherlands","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5047006729"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":2.4075,"has_fulltext":false,"cited_by_count":12,"citation_normalized_percentile":{"value":0.89078063,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":91,"max":99},"biblio":{"volume":null,"issue":null,"first_page":"107","last_page":"118"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10772","display_name":"Distributed systems and fault tolerance","score":1.0,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/T10772","display_name":"Distributed systems and fault tolerance","score":1.0,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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.9987999796867371,"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/T12288","display_name":"Optimization and Search Problems","score":0.9911999702453613,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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.876761794090271},{"id":"https://openalex.org/keywords/rendezvous","display_name":"Rendezvous","score":0.7829554080963135},{"id":"https://openalex.org/keywords/queue","display_name":"Queue","score":0.6079261898994446},{"id":"https://openalex.org/keywords/asynchronous-communication","display_name":"Asynchronous communication","score":0.5965414643287659},{"id":"https://openalex.org/keywords/channel","display_name":"Channel (broadcasting)","score":0.5652994513511658},{"id":"https://openalex.org/keywords/scalability","display_name":"Scalability","score":0.5646642446517944},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.46791818737983704},{"id":"https://openalex.org/keywords/synchronization","display_name":"Synchronization (alternating current)","score":0.4594164490699768},{"id":"https://openalex.org/keywords/message-passing","display_name":"Message passing","score":0.44287368655204773},{"id":"https://openalex.org/keywords/computer-network","display_name":"Computer network","score":0.4427816867828369},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.42188510298728943},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.35946449637413025},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.13807862997055054}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.876761794090271},{"id":"https://openalex.org/C2779968344","wikidata":"https://www.wikidata.org/wiki/Q3932925","display_name":"Rendezvous","level":3,"score":0.7829554080963135},{"id":"https://openalex.org/C160403385","wikidata":"https://www.wikidata.org/wiki/Q220543","display_name":"Queue","level":2,"score":0.6079261898994446},{"id":"https://openalex.org/C151319957","wikidata":"https://www.wikidata.org/wiki/Q752739","display_name":"Asynchronous communication","level":2,"score":0.5965414643287659},{"id":"https://openalex.org/C127162648","wikidata":"https://www.wikidata.org/wiki/Q16858953","display_name":"Channel (broadcasting)","level":2,"score":0.5652994513511658},{"id":"https://openalex.org/C48044578","wikidata":"https://www.wikidata.org/wiki/Q727490","display_name":"Scalability","level":2,"score":0.5646642446517944},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.46791818737983704},{"id":"https://openalex.org/C2778562939","wikidata":"https://www.wikidata.org/wiki/Q1298791","display_name":"Synchronization (alternating current)","level":3,"score":0.4594164490699768},{"id":"https://openalex.org/C854659","wikidata":"https://www.wikidata.org/wiki/Q1859284","display_name":"Message passing","level":2,"score":0.44287368655204773},{"id":"https://openalex.org/C31258907","wikidata":"https://www.wikidata.org/wiki/Q1301371","display_name":"Computer network","level":1,"score":0.4427816867828369},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.42188510298728943},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.35946449637413025},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.13807862997055054},{"id":"https://openalex.org/C29829512","wikidata":"https://www.wikidata.org/wiki/Q40218","display_name":"Spacecraft","level":2,"score":0.0},{"id":"https://openalex.org/C127413603","wikidata":"https://www.wikidata.org/wiki/Q11023","display_name":"Engineering","level":0,"score":0.0},{"id":"https://openalex.org/C146978453","wikidata":"https://www.wikidata.org/wiki/Q3798668","display_name":"Aerospace engineering","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3572848.3577481","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3572848.3577481","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 28th ACM SIGPLAN Annual Symposium on Principles and Practice of Parallel Programming","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":13,"referenced_works":["https://openalex.org/W1540179969","https://openalex.org/W1550037295","https://openalex.org/W1586740033","https://openalex.org/W1972107637","https://openalex.org/W1981393723","https://openalex.org/W1991869998","https://openalex.org/W2100357382","https://openalex.org/W2132220514","https://openalex.org/W2166263713","https://openalex.org/W2600922771","https://openalex.org/W2968116716","https://openalex.org/W3015821333","https://openalex.org/W4211008702"],"related_works":["https://openalex.org/W2057371520","https://openalex.org/W2807763113","https://openalex.org/W2542862126","https://openalex.org/W2030068303","https://openalex.org/W4299484523","https://openalex.org/W2953266086","https://openalex.org/W2123785131","https://openalex.org/W2135714282","https://openalex.org/W1690000972","https://openalex.org/W1595373702"],"abstract_inverted_index":{"Asynchronous":[0],"programming":[1,13,39],"has":[2],"gained":[3],"significant":[4],"popularity":[5],"over":[6],"the":[7,29,34,59,91,112],"last":[8],"decade:":[9],"support":[10],"for":[11,80],"this":[12,43],"pattern":[14],"is":[15,58,66,117,121],"available":[16],"in":[17,28],"many":[18],"popular":[19],"languages":[20],"via":[21,40],"libraries":[22],"and":[23,76,108],"native":[24],"language":[25],"implementations,":[26],"typically":[27],"form":[30],"of":[31,38,70],"coroutines":[32],"or":[33],"async/await":[35],"construct.":[36],"Instead":[37],"shared":[41],"memory,":[42],"concept":[44],"assumes":[45],"implicit":[46],"synchronization":[47],"through":[48],"message":[49,92],"passing.":[50],"The":[51],"key":[52],"data":[53],"structure":[54],"enabling":[55],"such":[56],"communication":[57],"rendezvous":[60,64,85],"channel.":[61,126],"Roughly,":[62],"a":[63,67,84,100,124],"channel":[65],"blocking":[68],"queue":[69],"size":[71],"zero,":[72],"so":[73,103],"both":[74],"send(e)":[75],"receive()":[77],"operations":[78],"wait":[79],"each":[81],"other,":[82],"performing":[83],"when":[86],"they":[87],"meet.":[88],"To":[89],"optimize":[90],"passing":[93],"pattern,":[94],"channels":[95],"are":[96],"usually":[97],"equipped":[98],"with":[99],"fixed-size":[101],"buffer,":[102],"sends":[104],"do":[105],"not":[106],"suspend":[107],"put":[109],"elements":[110],"into":[111],"buffer":[113],"until":[114],"its":[115],"capacity":[116],"exceeded.":[118],"This":[119],"primitive":[120],"known":[122],"as":[123],"buffered":[125]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":4},{"year":2023,"cited_by_count":7}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
