Automatic checking of the usage of the C++ move semantics

Baráth, Áron and Porkoláb, Zoltán: Automatic checking of the usage of the C++ move semantics. Acta cybernetica, (22) 1. pp. 5-20. (2015)

[img] Cikk, tanulmány, mű
actacyb_22_1_2015_2.pdf

Download (240kB)

Abstract

The C++ programming language is a favorable choice when implementing high performance applications, like real-time and embedded programming, large telecommunication systems, financial simulations, as well as a wide range of other speed sensitive programs. While C++ has all the facilities to handle the computer hardware without compromises, the copy based value semantics of assignment is a common source of performance degradation. New language features, like the move semantics were introduced recently to serve an instrument to avoid unnecessary copies. Unfortunately, correct usage of move semantics is not trivial, and unintentional expensive copies of C++ objects - like copying containers instead of using move semantics - may determine the main (worst-case) time characteristics of the programs. In this paper we introduce a new approach of investigating performance bottlenecks for C++ programs, which operates at language source level and targets the move semantics of the C++ programming language. We detect copies occurring in operations marked as move operations, i.e. intended not containing expensive copy actions. Move operations are marked with generalized attributes - a new language feature introduced to C++11 standard. We implemented a tool prototype to detect such copy/move semantic errors in C++ programs. Our prototype is using the open source LLVM/Clang parser infrastructure, therefore highly portable.

Item Type: Article
Journal or Publication Title: Acta cybernetica
Date: 2015
Volume: 22
Number: 1
Page Range: pp. 5-20
ISSN: 0324-721X
Language: angol
DOI: https://doi.org/10.14232/actacyb.22.1.2015.2
Uncontrolled Keywords: Számítógép programozás, Programozási nyelv C++
Additional Information: Bibliogr.: p. 19-20.
Date Deposited: 2016. Oct. 17. 10:36
Last Modified: 2018. Jun. 06. 18:07
URI: http://acta.bibl.u-szeged.hu/id/eprint/36173

Actions (login required)

View Item View Item