上個月,在CppCon2022上Herb Sutter介紹了他的一個處于實驗中的新編譯器:CppFront。
他通過該編譯器來實踐一種潛在的C++替換語法,簡稱為Cpp2,C++當(dāng)前語法則稱為Cpp1。Herb從2015年就著手設(shè)計該項目,如今推了出來,一時激起不小浪花,項目地址為https://github.com/hsutter/cppfront。官方描述如下:Cppfront is a experimental compiler from a potential C++ 'syntax 2' (Cpp2) to today's 'syntax 1' (Cpp1), to learn some things, prove out some concepts, and share some ideas. This compiler is a work in progress and currently hilariously incomplete… basic functions work, classes will be next, then metaclasses and lightweight exceptions.C++這是在自我破局,開辟第二曲線啊!標(biāo)準(zhǔn)是想再次實現(xiàn)C++11那種巨大的成功,使C++再次煥然一新,更加現(xiàn)代、簡單、高效。(雖然Herb說這個項目只代表個人的實踐,但是好的點子標(biāo)準(zhǔn)也不會放過,而且是實踐可行的點子)其實近幾年C++的發(fā)展速度真不慢,許多特性遲久未入,只是不想剛引入就遭淘汰。當(dāng)你再次見到C++更新時,很可能又會是像見到了一個新語言一樣,語法完全變化,近幾次的標(biāo)準(zhǔn)已有這個趨勢。下面我將提供一些Cpp2的例子,這些例子都是可以使用CppFront手動編譯運(yùn)行的,大家可以看看它的語法。Cpp2的目標(biāo)可以概括為兩個詞:安全和簡潔,語法也以此為導(dǎo)向。先來看一個最簡單的例子:
main:()->int={ s:std::string="world"; std::cout<"Hello"<" "; }這就是使用純Cpp2編寫的代碼,所有的聲明都由原來的r-to-l變?yōu)榱薼-to-r。其實從trailing-return-type開始,C++已經(jīng)慢慢變成了這種l-to-r形式的語言。可以混合使用Cpp1和Cpp2的語法,但是對于純Cpp2語法,它可以隱式地引入C++ 23的"import std"模塊,因此無需手動添加任何頭文件。接著來看一個文件讀寫的例子:
main:()->int={ s:std::string="Lily"; myfile:=fopen("dog","w"); myfile.fprintf("Hello%s! ",s.c_str()); myfile.fclose(); }這個代碼的確簡單不少,而且fprintf(), fclose()是作為成員函數(shù)存在的,這意味著可以觸發(fā)IDE的智能提示,提升開發(fā)效率。下面是一個類型安全的例子:
main:()->int={ v:std::variant<int,double>=42.0; a:std::any="xyzzy"asstd::string; o:std::optional<int>=(); test_generic(3.14); test_generic(v); test_generic(a); test_generic(o); std::cout<" "; v=1; a=2; o=3; test_generic(42); test_generic(v); test_generic(a); test_generic(o); } test_generic:(x:_)={ std::cout <std::setw(30)<typeid(x).name() <"valueis" <std::string{ isint=std::to_string(xasint); isstd::string=xasstd::string; is_="notanintorastring"; } <" "; }Cpp2中函數(shù)不需要前置聲明,它具有順序無關(guān)性(其實是生成代碼的時候自動提供前置聲明了)。其中的"_"是隱式模板的通配符,相當(dāng)于T,而inspect is as等等這些都是Pattern Matching的語法。在CppFront中,typeid().name()返回的類型名稱是可讀的,因此最終輸出如下圖。

main:()->int={ words:std::vector<std::string>= ("decorated","hello","world"); first:*std::string=words.front()&; last:*std::string=words.back()&; whilefirst<=?last?{ ????????print_and_decorate(first*); ????????first++;?//unsafe //first+1; //first[1]; //first~; //deletefirst; } } print_and_decorate:(thing:_)= std::cout<">>"<" ";當(dāng)試圖對指針使用這些操作時,將產(chǎn)生編譯期錯誤。上述代碼將報錯:
error:++-pointerarithmeticisillegal-usestd::spanorgsl::spaninstead它會推薦你使用更好的替代特性,有些特性甚至內(nèi)置為了原生特性,比如智能指針,它會推薦你使用unique.new
main:()->int={ cpp2::Bounds.set_handler(call_my_framework); words:std::vector<std::string>= ("decorated","hello","world"); s:std::span=words; print_and_decorate(s[3]); } print_and_decorate:(thing:_)= std::cout<">>"<" "; call_my_frameword:(msg:*constchar)= std::cout <"sendingerrortomyframework...[" <"] ";代碼中訪問s[3]越界,編譯時指定-s標(biāo)志,便可以幫你開啟邊界檢查,運(yùn)行之時進(jìn)行報錯。此外,還可以通過第2行的代碼設(shè)置一個handler,來捕獲錯誤。只有一個表達(dá)式的函數(shù),"{}"將作為可選項,省略掉要更加簡潔。 此外,Cpp2也支持初始化安全,對此,指針不可賦值為nullptr/0/NULL。看一個例子:
main:()->int={ cpp2::Bounds.set_handler(call_my_framework); p:*std::string; ifstd::rand()%2{ p=words.front()&; } //else{ //p=words.back()&; //} print_and_decorate(p*); } print_and_decorate:(thing:_)= std::cout<">>"<" ";例子中,p是一個指針,但是賦值語句沒有遍及各個分支,訪問之時肯定會存在錯誤。因此它會直接產(chǎn)生編譯期錯誤:
example.cpp2(4,5):error:localvariablepmustbeinitializedonbothbranchesorneitherbranch example.cpp2(6,5):error:"if"initializespon: branchstartingatline6 butnoton: implicitelsebranch ==>programviolatesinitializationsafetyguarantee-seepreviouserrors這個特性可以保證變量在使用前初始化。最后,還有一個有意思的特性用于函數(shù)多返回值,一個簡單的例子:
f:()->(i:int,s:std::string)={ i=10; s="haha"; return; } automain()->int{ auto[a,b]=f(); std::cout<""<" "; }這個代碼混合了Cpp1和Cpp2。函數(shù)f()具有多個返回值,可以不用借用std::paire與std::tuple等等組件。實際上,它會自動生成一個結(jié)構(gòu)體,作為函數(shù)的返回值。該例子生成的為:
structf__ret{ inti; std::strings; };這些例子都來自Herb的演講內(nèi)容,他說Cpp2會比原來的C++語法簡單和安全10倍,想看的地址為:https://www.youtube.com/watch?v=ELeZAKCN4tY。Cpp2一直只是Herb個人的一個實驗性產(chǎn)品,項目必然存在很多缺陷,但正是這些不斷的探索,為C++提供了更多可能。 大家覺得目前的Cpp2設(shè)計怎樣呢?有沒有哪些不錯的點子?
審核編輯 :李倩
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
C++
+關(guān)注
關(guān)注
22文章
2117瀏覽量
74861 -
編譯器
+關(guān)注
關(guān)注
1文章
1657瀏覽量
49968
原文標(biāo)題:Herb Sutter 介紹一個處于他實驗中的 C++ 新編譯器和一種潛在的 C++ 替換語法
文章出處:【微信號:CPP開發(fā)者,微信公眾號:CPP開發(fā)者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
熱點推薦
Triton編譯器與GPU編程的結(jié)合應(yīng)用
Triton編譯器簡介 Triton編譯器是一種針對并行計算優(yōu)化的編譯器,它能夠自動將高級語言代碼轉(zhuǎn)換為針對特定硬件優(yōu)化的低級代碼。Triton編譯
Triton編譯器如何提升編程效率
在現(xiàn)代軟件開發(fā)中,編譯器扮演著至關(guān)重要的角色。它們不僅將高級語言代碼轉(zhuǎn)換為機(jī)器可執(zhí)行的代碼,還通過各種優(yōu)化技術(shù)提升程序的性能。Triton 編譯器作為一種先進(jìn)的
Triton編譯器在高性能計算中的應(yīng)用
高性能計算(High-Performance Computing,HPC)是現(xiàn)代科學(xué)研究和工程計算中不可或缺的一部分。隨著計算需求的不斷增長,對計算資源的要求也越來越高。Triton編譯器作為
Triton編譯器的優(yōu)化技巧
在現(xiàn)代計算環(huán)境中,編譯器的性能對于軟件的運(yùn)行效率至關(guān)重要。Triton 編譯器作為一個先進(jìn)的編譯器
Triton編譯器的優(yōu)勢與劣勢分析
Triton編譯器作為一種新興的深度學(xué)習(xí)編譯器,具有一系列顯著的優(yōu)勢,同時也存在一些潛在的劣勢。以下是對Triton
Triton編譯器在機(jī)器學(xué)習(xí)中的應(yīng)用
1. Triton編譯器概述 Triton編譯器是NVIDIA Triton推理服務(wù)平臺的一部分,它負(fù)責(zé)將深度學(xué)習(xí)模型轉(zhuǎn)換為優(yōu)化的格式,以便在NVIDIA GPU上高效運(yùn)行。Triton編譯器
Triton編譯器的常見問題解決方案
Triton編譯器作為一款專注于深度學(xué)習(xí)的高性能GPU編程工具,在使用過程中可能會遇到一些常見問題。以下是一些常見問題的解決方案:
Triton編譯器支持的編程語言
Triton編譯器支持的編程語言主要包括以下幾種: 一、主要編程語言 Python :Triton編譯器通過Python接口提供了對Triton語言和編譯器的訪問,使得用戶可以在Pyt
Triton編譯器與其他編譯器的比較
Triton編譯器與其他編譯器的比較主要體現(xiàn)在以下幾個方面: 一、定位與目標(biāo) Triton編譯器 : 定位:專注于深度學(xué)習(xí)中最核心、最耗時的張量運(yùn)算的優(yōu)化。 目標(biāo):提供
Triton編譯器功能介紹 Triton編譯器使用教程
Triton 是一個開源的編譯器前端,它支持多種編程語言,包括 C、C++、Fortran 和 Ada。Triton 旨在提供一個可擴(kuò)展和可
分享關(guān)于編譯器的科普
源代碼分析工具和IDE集成。GCC被構(gòu)建成一個單一的靜態(tài)編譯器,這使得它非常難以被作為API并集成到其他工具中。 GCC比Clang支
AI編譯器技術(shù)剖析
隨著人工智能技術(shù)的飛速發(fā)展,AI編譯器作為一種新興的編譯技術(shù)逐漸進(jìn)入人們的視野。AI編譯器不僅具備傳統(tǒng)編譯器的功能,如將高級語言編寫的源代碼
人工智能編譯器與傳統(tǒng)編譯器的區(qū)別
人工智能編譯器(AI編譯器)與傳統(tǒng)編譯器在多個方面存在顯著的差異。這些差異主要體現(xiàn)在設(shè)計目標(biāo)、功能特性、優(yōu)化策略、適用范圍以及技術(shù)復(fù)雜性等方面。以下是對兩者區(qū)別的詳細(xì)探討,旨在全面解析其內(nèi)在差異。
Meta發(fā)布基于Code Llama的LLM編譯器
近日,科技巨頭Meta在其X平臺上正式宣布推出了一款革命性的LLM編譯器,這一模型家族基于Meta Code Llama構(gòu)建,并融合了先進(jìn)的代碼優(yōu)化和編譯器功能。LLM
評論