C ++ 14 - C++14 - Wikipedia

C ++ 14 ning versiyasidir ISO / IEC 14882 standarti dasturlash tili uchun C ++. Bu kichik bo'lishi kerak kengaytma ustida C ++ 11, asosan xatolarni tuzatish va kichik yaxshilanishlarni o'z ichiga oladi. Uning tasdiqlanishi 2014 yil 18 avgustda e'lon qilindi.[1] C ++ 14 2014 yil 15 dekabrda chiqarilgan.[2]

Ilgari C ++ standart tahrirlari sezilarli darajada kechiktirilganligi sababli, ba'zida uning tasdiqlanishigacha "C ++ 1y" nomi ishlatilgan, xuddi shunga o'xshash C ++ 11 standarti "C ++ 0x" deb nomlanganligi kabi 2010 yilgacha (garchi aslida u 2010 yilga va nihoyat 2011 yilga tushib ketgan bo'lsa ham).

Yangi til xususiyatlari

Bu C ++ 14 ning asosiy tiliga qo'shilgan xususiyatlar.

Funktsiyani qaytarish turini kamaytirish

C ++ 11 ga ruxsat berilgan lambda funktsiyalari return operatoriga berilgan ifoda turiga qarab qaytish turini chiqarish. C ++ 14 ushbu funktsiyani barcha funktsiyalarga taqdim etadi. Shuningdek, u ushbu imkoniyatlarni lambda funktsiyalariga kengaytiradi va formada bo'lmagan funktsiyalar uchun qaytish turini kamaytirishga imkon beradi ifoda qaytarish;.[3]

Qaytish turini chiqarishni boshlash uchun funktsiya bilan e'lon qilinishi kerak avtomatik qaytish turi sifatida, lekin C ++ 11 da orqaga qaytarish turi ko'rsatgichisiz:

avtomatik DeduceReturnType();   // Belgilanadigan qaytish turi.

Agar funktsiyani amalga oshirishda bir nechta qaytariladigan iboralar ishlatilsa, ularning barchasi bir xil turni chiqarishi kerak.[4]

Qaytish turlarini chiqaradigan funktsiyalar oldinga e'lon qilinishi mumkin, ammo ular aniqlanmaguncha ulardan foydalanish mumkin emas. Ularning ta'riflari ularni ishlatadigan tarjima bo'linmasi uchun mavjud bo'lishi kerak.

Rekursiya ushbu turdagi funktsiya bilan ishlatilishi mumkin, ammo rekursiv chaqiruv funktsiya ta'rifidagi kamida bitta qaytish bayonotidan keyin sodir bo'lishi kerak:[4]

avtomatik To'g'ri(int men){  agar (men == 1)    qaytish men;             // qaytish turi int sifatida chiqarilgan  qaytish To'g'ri(men-1)+men;  // hozir uni chaqirish uchun ok}avtomatik Noto'g'ri(int men){  agar (men != 1)    qaytish Noto'g'ri(men-1)+men;  // Tez orada buni chaqiramiz. Oldindan qaytarib berish to'g'risidagi bayonot yo'q.  qaytish men;               // qaytish turi int sifatida chiqarilgan}

Deklaratsiya bo'yicha muqobil turdagi chegirma[5]

C ++ 11 da ikkita turdagi deduksiya qo'shildi. avtomatik berilgan ifoda asosida tegishli tipdagi o'zgaruvchini yaratish usuli edi. decltype berilgan ifoda turini hisoblash usuli edi. Biroq, decltype va avtomatik turlarini har xil usulda chiqarib oling. Jumladan, avtomatik yordamida har doim mos yozuvlar bo'lmagan turini chiqaradi std :: yemirilish, esa avtomatik && har doim mos yozuvlar turini chiqaradi. Biroq, decltype iboraning qiymat toifasiga va u chiqaradigan ifoda xususiyatiga asoslanib, mos yozuvlar yoki mos yozuvlar turlarini chiqarishga o'tish mumkin:[3]

int   men;int&& f();avtomatik          x3a = men;     // decltype (x3a) intdecltype(men)   x3d = men;     // decltype (x3d) intavtomatik          x4a = (men);   // decltype (x4a) intdecltype((men)) x4d = (men);   // decltype (x4d) int &avtomatik          x5a = f();   // decltype (x5a) intdecltype(f()) x5d = f();   // decltype (x5d) int &&

C ++ 14 ga qo'shimchalar decltype (avtomatik) sintaksis. Bu imkon beradi avtomatik dan foydalanish to'g'risidagi deklaratsiyalar decltype berilgan ifoda bo'yicha qoidalar.

The decltype (avtomatik) sintaksis bilan ham foydalanish mumkin qaytish turi chegirmasi yordamida decltype (avtomatik) o'rniga sintaksis avtomatik funktsiyani qaytarish turini ajratish uchun.[4]

Rahat konstexpr cheklovlari

C ++ 11 constexpr tomonidan e'lon qilingan funktsiya tushunchasini kiritdi; kompilyatsiya vaqtida bajarilishi mumkin bo'lgan funktsiya. Ularning qaytish qiymatlari doimiy iboralarni talab qiladigan operatsiyalar tomonidan iste'mol qilinishi mumkin, masalan, tamsayı shablon argumenti. Biroq, C ++ 11 constexpr funktsiyalari faqat qaytarilgan bitta ifodani o'z ichiga olishi mumkin (shuningdek) statik_assertlar va oz sonli boshqa deklaratsiyalar).

C ++ 14 ushbu cheklovlarni yumshatadi. Constexpr tomonidan e'lon qilingan funktsiyalar endi quyidagilarni o'z ichiga olishi mumkin:[3]

  • Har qanday deklaratsiya bundan mustasno:
    • statik yoki thread_local o'zgaruvchilar.
    • Initsializatorlarsiz o'zgaruvchan deklaratsiyalar.
  • Shartli dallanmalar agar va almashtirish.
  • Har qanday pastadirli bayonot, shu jumladan intervalgacha asoslangan uchun.
  • Ob'ektning umri doimiy ifoda funktsiyasi doirasida boshlangan bo'lsa, uning qiymatini o'zgartiradigan iboralar. Bunga har qanday boshqa raqamga qo'ng'iroqlar kiradikonst constexpr- statik bo'lmagan a'zoning funktsiyalari.

bordi bayonotlarni C ++ 14 konstruksiyada e'lon qilingan funktsiyalarda taqiqlangan.

Bundan tashqari, C ++ 11 e'lon qilingan barcha statik bo'lmagan a'zo funktsiyalarini ta'kidladi constexpr ham yashirin ravishda e'lon qilindi konst, munosabat bilan bu. O'shandan beri olib tashlandi; statik bo'lmagan a'zo funktsiyalari nodavlat bo'lishi mumkinkonst.[6] Biroq, yuqoridagi cheklovlarga binoan,konst constexpr a'zoning funktsiyasi, agar ushbu ob'ektning ishlash muddati doimiy ifodani baholashda boshlangan bo'lsa, faqatgina sinf a'zosini o'zgartirishi mumkin.

O'zgaruvchan shablonlar

Ning oldingi versiyalarida C ++, faqat funktsiyalar, sinflar yoki turdagi taxalluslar shablon bo'lishi mumkin. C ++ 14 shablonlangan o'zgaruvchilarni yaratishga imkon beradi. Taklifda keltirilgan misol o'zgaruvchidir pi qiymatini olish uchun o'qilishi mumkin pi har xil turlari uchun (masalan, 3 ajralmas tur sifatida o'qilganda; bilan mumkin bo'lgan eng yaqin qiymat suzmoq, ikki baravar yoki uzun er-xotin sifatida o'qilganda aniqlik suzmoq, ikki baravar yoki uzun er-xotinnavbati bilan; va boshqalar.).

Shablonlarning odatiy qoidalari bunday deklaratsiyalar va ta'riflarga, shu jumladan ixtisoslashuvga taalluqlidir.[7][8]

shablon<yozuv nomi T>constexpr T pi = T(3.141592653589793238462643383);// Oddiy ixtisoslashish qoidalari qo'llaniladi:shablon<>constexpr konst char* pi<konst char*> = "pi";

Agregat a'zolarini boshlash

C ++ 11 qo'shilgan boshlang'ich tashkilotchilar, agar konstruktor a'zoning o'zi boshlanmasa, sinf doirasidagi a'zolarga qo'llaniladigan iboralar. Agregatlarning ta'rifi a'zoning boshlang'ichlari bo'lgan har qanday sinfni aniq chiqarib tashlash uchun o'zgartirildi; shuning uchun ularga agregatsiya boshlanishidan foydalanishga ruxsat berilmaydi.

C ++ 14 ushbu cheklovni yumshatadi,[3] bunday turlar bo'yicha yig'ma ishga tushirishga imkon beradi. Agar kengaytirilgan init ro'yxati ushbu argument uchun qiymat bermasa, a'zoning boshlovchisi unga javob beradi.[9]

Ikkilik adabiyotlar

C ++ 14 dagi raqamli harflar ikkilik shakl.[3] Sintaksis prefikslardan foydalanadi 0b yoki 0B. Sintaksis boshqa tillarda ham ishlatiladi, masalan. Java, C #, Tez, Boring, Scala, Yoqut, Python, OCaml va kamida 2007 yildan beri ba'zi C kompilyatorlarida norasmiy kengaytma sifatida.[10]

Raqamli ajratgichlar

C ++ 14 da bitta tirnoqli belgi o'zboshimchalik bilan a sifatida ishlatilishi mumkin raqamli ajratuvchi ikkalasi ham raqamli harflarda butun sonli harflar va suzuvchi nuqta yozuvlari.[11] Bu odam o'quvchilariga ko'p sonli raqamlarni tahlil qilishni osonlashtirishi mumkin sublitizatsiya.

avtomatik integer_literal = 1'000'000;
avtomatik suzuvchi_ nuqta_literal = 0.000'015'3;
avtomatik ikkilik_literal = 0b0100'1100'0110;
avtomatik nilufarcrores = 12'00'00'000;
avtomatik nilufar = 1'0'0'000'00;

Umumiy lambdalar

C ++ 11 da, lambda funktsiyasi parametrlarni aniq turlari bilan e'lon qilish kerak. C ++ 14 ushbu talabni yumshatadi va lambda funktsiyasi parametrlarini avtomatik turi aniqlovchi.[7]

avtomatik lambda = [](avtomatik x, avtomatik y) {qaytish x + y;};

Tegishli avtomatik tip deduksiyasi, umumiy lambdalar shablon argumentlarini chiqarib tashlash qoidalariga amal qiladi (ular o'xshash, ammo har jihatdan bir xil emas)[tushuntirish kerak ]). Yuqoridagi kod bunga teng:[12]

tuzilmaviy{  shablon<yozuv nomi T, yozuv nomi U>    avtomatik operator()(T x, U y) konst {qaytish x + y;}} lambda{};

Umumiy lambdalar asosan shablonlangan funktsional lambdalardir.

Lambda ta'qib qilish iboralari

C ++ 11 lambda funktsiyalari tashqi koeffitsientda e'lon qilingan o'zgaruvchilarni qiymat-nusxasi yoki ma'lumotnoma orqali oladi. Bu shuni anglatadiki, lambdaning qiymat a'zolari faqat harakatlanadigan turlar bo'lishi mumkin emas.[13] C ++ 14 qo'lga kiritilgan a'zolarni o'zboshimchalik bilan ifodalash bilan boshlashga imkon beradi. Bu qiymatni ko'chirish va lambdaning o'zboshimchalik bilan a'zolarini e'lon qilish orqali qo'lga kiritishga imkon beradi, tashqi doirada mos keladigan nomlangan o'zgaruvchiga ega bo'lmaydi.[7]

Bu boshlang'ich iborasi yordamida amalga oshiriladi:

avtomatik lambda = [qiymat = 1] {qaytish qiymat;};

Lambda funktsiyasi lambda qaytaradi 1, bu nima qiymat bilan boshlangan. E'lon qilingan tortishish, boshlang'ich iborasidan turini, go'yo kabi chiqaradi avtomatik.

Bu standartdan foydalangan holda, harakatga olish uchun ishlatilishi mumkin std :: move funktsiyasi:

std::noyob_ptr<int> ptr(yangi int(10));avtomatik lambda = [qiymat = std::harakat qilish(ptr)] {qaytish *qiymat;};

Xususiyat [[eskirgan]]

The eskirgan atribut ob'ektni belgilashga imkon beradi eskirgan, bu hali ham foydalanishni qonuniy holga keltiradi, ammo foydalanuvchilarga foydalanish to'xtatilganligi va kompilyatsiya paytida ogohlantiruvchi xabar chop etilishiga olib kelishi mumkinligi to'g'risida ogohlantirmoqda. Ixtiyoriy string literal argumenti sifatida paydo bo'lishi mumkin eskirgan, amortizatsiya asoslarini tushuntirish va / yoki almashtirishni taklif qilish.

[[eskirgan]] int f();[[eskirgan("g () zararli emas. Buning o'rniga h () dan foydalaning")]]bekor g( int& x );bekor h( int& x );bekor sinov(){  int a = f(); // ogohlantirish: 'f' eskirgan  g(a); // ogohlantirish: 'g' eskirgan: g () zararli emas. Buning o'rniga h () dan foydalaning}

Kutubxonaning yangi standart xususiyatlari

Umumiy mutekslar va qulflash

C ++ 14 birgalikda o'rnatilgan muteks va sherikning umumiy qulf turini qo'shadi.[14][15]

Assotsiativ idishlarda bir hil bo'lmagan qidiruv

The C ++ standart kutubxonasi to'rtta assotsiativ konteyner sinfini belgilaydi. Ushbu sinflar foydalanuvchiga ushbu turdagi qiymatga asoslangan qiymatni qidirishga imkon beradi. Xarita konteynerlari foydalanuvchiga kalit va qiymatni belgilashga imkon beradi, bu erda qidirish tugmachasi yordamida amalga oshiriladi va qiymat qaytariladi. Biroq, qidiruv har doim ham ma'lum bir kalit turi bo'yicha amalga oshiriladi, u xaritalarda bo'lgani kabi kalit yoki to'plamdagi kabi o'zi.

C ++ 14 qidiruvni o'zboshimchalik bilan amalga oshirishga imkon beradi, chunki taqqoslash operatori ushbu turni haqiqiy kalit turi bilan taqqoslashi mumkin.[16] Bu xaritani yaratishga imkon beradi std :: string a bilan taqqoslash uchun ba'zi bir qiymatga const char * yoki boshqa har qanday turi uchun operator < ortiqcha yuk mavjud. Bundan tashqari, a tarkibidagi kompozitsion ob'ektlarni indekslash uchun foydalidir std :: set foydalanuvchini majbur qilmasdan bitta a'zoning qiymati bo'yicha topmoq qo'g'irchoq ob'ekt yaratish uchun (masalan, butunni yaratish) struct shaxs ism bilan odam topish).

Orqaga muvofiqlikni saqlab qolish uchun heterojen qidiruvga faqat assotsiativ konteynerga berilgan taqqoslash moslamasi imkon berganida ruxsat beriladi. Standart kutubxona darslari std :: kamroq <> va std :: great <> heterojen qidirishga imkon berish uchun ko'paytiriladi.[17]

Foydalanuvchi tomonidan belgilangan standart harflar

C ++ 11 foydalanuvchi tomonidan aniqlangan so'zma-so'z qo'shimchalari uchun sintaksisni aniqladi, ammo standart kutubxona ulardan hech birini ishlatmadi. C ++ 14 quyidagi standart literallarni qo'shadi:[16]

  • "s", turli xil yaratish uchun std :: basic_string turlari.
  • "h", "min", "s", "ms", "us", "ns", mos keladigan yaratish uchun std :: chrono :: davomiyligi vaqt oralig'i.
  • "if", "i", "il", mos keladiganini yaratish uchun std :: complex , std :: murakkab va std :: murakkab xayoliy raqamlar.
avtomatik str = "Salom Dunyo"s; // satrni avtomatik ravishda chiqarib tashlaydiavtomatik dur = 60s;            // avtomatik chrono :: soniyani chiqaradiavtomatik z   = 1men;             // avtomatik <2 barobar> kompleksini chiqaradi

Ikkala "harflar" o'zaro ta'sir qilmaydi, chunki ip faqat ishlaydi torli harflar, va soniyalar uchun raqam faqat ishlaydi.[18]

Tuple manzilini turi bo'yicha

The std :: tuple C ++ 11 da kiritilgan tip, kiritilgan qiymatlarning yig'indisini kompilyatsiya vaqtidagi doimiy butun son bilan indeksatsiyalashga imkon beradi. C ++ 14 buni katakchadan indeks bo'yicha emas, balki turlari bo'yicha olishni ta'minlash uchun kengaytiradi.[16] Agar koridorda bir nechta element mavjud bo'lsa, kompilyatsiya vaqtida xato yuzaga keladi:[19]

panjara<mag'lubiyat, mag'lubiyat, int> t("foo", "bar", 7);int men = olish<int>(t);        // i == 7int j = olish<2>(t);          // Oldingi kabi: j == 7mag'lubiyat s = olish<mag'lubiyat>(t);  // noaniqlik sababli kompilyatsiya vaqtidagi xato

Kutubxonaning kichik xususiyatlari

std :: make_unique kabi ishlatilishi mumkin std :: make_shared uchun std :: noyob_ptr ob'ektlar.[7]

std :: integral_constant qo'lga kiritdi operator () doimiy qiymatni qaytarish uchun ortiqcha yuk.[16]

Sinf shabloni std :: integer_sequence va shunga o'xshash taxallus shablonlari parametrlar to'plamidagi elementlarning indekslari kabi kompilyatsiya vaqtining butun sonli ketma-ketliklarini aks ettirish uchun qo'shildi.[20]

Global std :: boshlash/std :: end funktsiyalar kengaytirildi std :: cbegin/std :: cend doimiy iteratorlarni qaytaradigan funktsiyalar va std :: rbegin/std :: rend va std :: crbegin/std :: crend teskari iteratorlarni qaytaradigan.

The std :: almashtirish funktsiya shabloni o'zgaruvchiga yangi qiymat tayinlaydi va eski qiymatni qaytaradi.[21]

Yangi ortiqcha yuklar std :: teng, std :: mos kelmaslikva std :: is_permutation qo'ng'iroq qiluvchiga ikkita diapazon bir xil uzunlikda bo'lishini alohida tekshirishga hojat qolmasligi uchun ikkinchi diapazon uchun bir juft iteratorni oling.[22]

The std :: is_final tip belgisi sinf belgilanganligini aniqlaydi final.

The std :: iqtibos oqim I / U manipulyatori ajratilgan satrlarni (ikkita tirnoqgacha sukut bo'yicha) chiqishda joylashtirish va ularni kiritishda echib olish va o'rnatilgan chegarachilardan qochish orqali ichki bo'shliqlar bilan satrlarni kiritish va ajratib olishga imkon beradi.[23]

Tuzuvchini qo'llab-quvvatlash

Jiringlash standart C ++ 1y nomi ostida bo'lsa-da, 3.4 da C ++ 14-ni qo'llab-quvvatladi va Clang + da 14-ni standart C ++ standartiga aylantirdi.[24] GCC GCC 5-da C ++ 14-ni qo'llab-quvvatlashni tugatdi va C ++ 14-ni GCC 6-da standart C ++ standartiga aylantirdi.[25] Microsoft Visual Studio 2017 yilda "deyarli barcha" C ++ 14 funktsiyalari amalga oshirildi.[26]

Adabiyotlar

  1. ^ Sutter, o't (18.08.2014), Bizda C ++ 14 mavjud!, olingan 2014-08-18
  2. ^ "ISO / IEC qidiruvi". ISO.
  3. ^ a b v d e Vong, Maykl (2013 yil 30-aprel). "C ++ standart yig'ilishidan ko'rinish 2013 yil aprel, 1-qism".. C / C ++ kafesi. Olingan 27 yanvar 2016.
  4. ^ a b v Merril, Jeyson (2013 yil 17 aprel). "Normal funktsiyalar uchun N3638 qaytish turidagi chegirma (5-qayta ko'rib chiqish)". Olingan 14 iyun 2013.
  5. ^ http://thbecker.net/articles/auto_and_decltype/section_10.html
  6. ^ Smit, Richard (2013 yil 18-aprel). "N3652 constexpr funktsiyalaridagi cheklovlar".
  7. ^ a b v d Sutter, o't (2013 yil 20-aprel). "Sayohat haqida hisobot: ISO C ++ 2013 yil bahorgi yig'ilishi". isocpp.org. Olingan 14 iyun 2013.
  8. ^ Dos Reis, Gabriel (19 aprel 2013). "N3651 o'zgaruvchan shablonlari (tahrir 1)" (PDF).
  9. ^ Vandevoord, Deyvid; Voutilainen, Ville (2013 yil 17 aprel). "N3653 a'zo boshlang'ichlari va agregatlari".
  10. ^ https://gcc.gnu.org/bugzilla/show_bug.cgi?id=23479#c29
  11. ^ Kroul, Lourens; Smit, Richard; Snayder, Jeff; Vandevoorde, Deyvid (2013 yil 25 sentyabr). "Raqam ajratuvchi sifatida N3781 bitta kotirovka belgisi" (PDF).
  12. ^ Vali, Faysal; Sutter, o't; Abrahams, Deyv (2013 yil 19 aprel). "N3649 umumiy (polimorfik) Lambda ifodalari (tahrir 3)".
  13. ^ "Lambda-da suratga olishni siljiting". Stack overflow.
  14. ^ Vong, Maykl (2013 yil 30-aprel). "C ++ standart yig'ilishidan ko'rinish 2013 yil aprel, 3-qism".. C / C ++ kafesi. Olingan 14 iyun 2013.
  15. ^ Xinnant, Xovard; Vollmann, Detlef; Boem, Xans (2013 yil 19-aprel). "N3659 C ++ da umumiy qulflash (Revision 2)".
  16. ^ a b v d Vong, Maykl (2013 yil 26-aprel). "C ++ standart yig'ilishidan ko'rinish 2013 yil aprel, 2-qism".. C / C ++ kafesi. Olingan 14 iyun 2013.
  17. ^ "N3657 Assotsiativ konteynerlarga heterojen taqqoslash izlanishini qo'shish (rev 4)". 19 mart 2013 yil.
  18. ^ Sommerlad, Piter (2013 yil 18-aprel). "N3642 standart kutubxona turlari uchun foydalanuvchi tomonidan belgilangan literallar (1 qism - 4-versiya)" (PDF).
  19. ^ Spertus, Mayk (2013 yil 19 aprel). "N3670 turlarga qarab manzilga murojaat qilish: Revision 2".
  20. ^ Wakely, Jonathan (2013 yil 18-aprel). "N3658 kompilyatsiya vaqtidagi butun sonli ketma-ketliklar". Olingan 5 yanvar 2016.
  21. ^ Yasskin, Jefri (2013 yil 19 aprel). "N3668 exchange () yordamchi funktsiyasi, 3-qayta ko'rib chiqish. Olingan 5 yanvar 2016.
  22. ^ Spertus, Mayk; Pall, Attila (2013 yil 19 aprel). "N3671 O'zgartirilmaydigan ketma-ketlik operatsiyalarini yanada mustahkam qilish: Revision 2". Olingan 5 yanvar 2016.
  23. ^ Dawes, Beman (2013 yil 19-aprel). "N3654 keltirilgan satrlar kutubxonasi bo'yicha taklif (2-tahrir)". Olingan 5 yanvar 2016.
  24. ^ "Clang tilida C ++ ko'magi". Olingan 28 may 2016.
  25. ^ "GCC-da C ++ standartlarini qo'llab-quvvatlash". Olingan 28 may 2016.
  26. ^ "Microsoft tomonidan C ++ standartlariga muvofiqligi". Olingan 7 mart 2017.

Tashqi havolalar