上個月,在CppCon2022上Herb Sutter介紹了他的一個處于實驗中的新編譯器:CppFront。
他通過該編譯器來實踐一種潛在的C++替換語法,簡稱為Cpp2,C++當前語法則稱為Cpp1。Herb從2015年就著手設計該項目,如今推了出來,一時激起不小浪花,項目地址為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++這是在自我破局,開辟第二曲線啊!標準是想再次實現C++11那種巨大的成功,使C++再次煥然一新,更加現代、簡單、高效。(雖然Herb說這個項目只代表個人的實踐,但是好的點子標準也不會放過,而且是實踐可行的點子)其實近幾年C++的發展速度真不慢,許多特性遲久未入,只是不想剛引入就遭淘汰。當你再次見到C++更新時,很可能又會是像見到了一個新語言一樣,語法完全變化,近幾次的標準已有這個趨勢。下面我將提供一些Cpp2的例子,這些例子都是可以使用CppFront手動編譯運行的,大家可以看看它的語法。Cpp2的目標可以概括為兩個詞:安全和簡潔,語法也以此為導向。先來看一個最簡單的例子:
main:()->int={ s:std::string="world"; std::cout<"Hello"<" "; }這就是使用純Cpp2編寫的代碼,所有的聲明都由原來的r-to-l變為了l-to-r。其實從trailing-return-type開始,C++已經慢慢變成了這種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()是作為成員函數存在的,這意味著可以觸發IDE的智能提示,提升開發效率。下面是一個類型安全的例子:
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中函數不需要前置聲明,它具有順序無關性(其實是生成代碼的時候自動提供前置聲明了)。其中的"_"是隱式模板的通配符,相當于T,而inspect is as等等這些都是Pattern Matching的語法。在CppFront中,typeid().name()返回的類型名稱是可讀的,因此最終輸出如下圖。
![9596c822-55b3-11ed-a3b6-dac502259ad0.png](https://file1.elecfans.com//web2/M00/A1/F8/wKgaomTt8c-AEzd7AAGhLagOjWM420.png)
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<">>"<" ";當試圖對指針使用這些操作時,將產生編譯期錯誤。上述代碼將報錯:
error:++-pointerarithmeticisillegal-usestd::spanorgsl::spaninstead它會推薦你使用更好的替代特性,有些特性甚至內置為了原生特性,比如智能指針,它會推薦你使用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標志,便可以幫你開啟邊界檢查,運行之時進行報錯。此外,還可以通過第2行的代碼設置一個handler,來捕獲錯誤。只有一個表達式的函數,"{}"將作為可選項,省略掉要更加簡潔。 此外,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是一個指針,但是賦值語句沒有遍及各個分支,訪問之時肯定會存在錯誤。因此它會直接產生編譯期錯誤:
example.cpp2(4,5):error:localvariablepmustbeinitializedonbothbranchesorneitherbranch example.cpp2(6,5):error:"if"initializespon: branchstartingatline6 butnoton: implicitelsebranch ==>programviolatesinitializationsafetyguarantee-seepreviouserrors這個特性可以保證變量在使用前初始化。最后,還有一個有意思的特性用于函數多返回值,一個簡單的例子:
f:()->(i:int,s:std::string)={ i=10; s="haha"; return; } automain()->int{ auto[a,b]=f(); std::cout<""<" "; }這個代碼混合了Cpp1和Cpp2。函數f()具有多個返回值,可以不用借用std::paire與std::tuple等等組件。實際上,它會自動生成一個結構體,作為函數的返回值。該例子生成的為:
structf__ret{ inti; std::strings; };這些例子都來自Herb的演講內容,他說Cpp2會比原來的C++語法簡單和安全10倍,想看的地址為:https://www.youtube.com/watch?v=ELeZAKCN4tY。Cpp2一直只是Herb個人的一個實驗性產品,項目必然存在很多缺陷,但正是這些不斷的探索,為C++提供了更多可能。 大家覺得目前的Cpp2設計怎樣呢?有沒有哪些不錯的點子?
審核編輯 :李倩
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
C++
+關注
關注
22文章
2114瀏覽量
73922 -
編譯器
+關注
關注
1文章
1642瀏覽量
49326
原文標題:Herb Sutter 介紹一個處于他實驗中的 C++ 新編譯器和一種潛在的 C++ 替換語法
文章出處:【微信號:CPP開發者,微信公眾號:CPP開發者】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
Triton編譯器與GPU編程的結合應用
Triton編譯器簡介 Triton編譯器是一種針對并行計算優化的編譯器,它能夠自動將高級語言代碼轉換為針對特定硬件優化的低級代碼。Triton編譯
Triton編譯器如何提升編程效率
在現代軟件開發中,編譯器扮演著至關重要的角色。它們不僅將高級語言代碼轉換為機器可執行的代碼,還通過各種優化技術提升程序的性能。Triton 編譯器作為一種先進的
Triton編譯器在高性能計算中的應用
高性能計算(High-Performance Computing,HPC)是現代科學研究和工程計算中不可或缺的一部分。隨著計算需求的不斷增長,對計算資源的要求也越來越高。Triton編譯器作為
Triton編譯器的優勢與劣勢分析
Triton編譯器作為一種新興的深度學習編譯器,具有一系列顯著的優勢,同時也存在一些潛在的劣勢。以下是對Triton
Triton編譯器在機器學習中的應用
1. Triton編譯器概述 Triton編譯器是NVIDIA Triton推理服務平臺的一部分,它負責將深度學習模型轉換為優化的格式,以便在NVIDIA GPU上高效運行。Triton編譯器
Triton編譯器支持的編程語言
Triton編譯器支持的編程語言主要包括以下幾種: 一、主要編程語言 Python :Triton編譯器通過Python接口提供了對Triton語言和編譯器的訪問,使得用戶可以在Pyt
Triton編譯器與其他編譯器的比較
Triton編譯器與其他編譯器的比較主要體現在以下幾個方面: 一、定位與目標 Triton編譯器 : 定位:專注于深度學習中最核心、最耗時的張量運算的優化。 目標:提供
Triton編譯器功能介紹 Triton編譯器使用教程
Triton 是一個開源的編譯器前端,它支持多種編程語言,包括 C、C++、Fortran 和 Ada。Triton 旨在提供一個可擴展和可
分享關于編譯器的科普
源代碼分析工具和IDE集成。GCC被構建成一個單一的靜態編譯器,這使得它非常難以被作為API并集成到其他工具中。 GCC比Clang支
AI編譯器技術剖析
隨著人工智能技術的飛速發展,AI編譯器作為一種新興的編譯技術逐漸進入人們的視野。AI編譯器不僅具備傳統編譯器的功能,如將高級語言編寫的源代碼
人工智能編譯器與傳統編譯器的區別
人工智能編譯器(AI編譯器)與傳統編譯器在多個方面存在顯著的差異。這些差異主要體現在設計目標、功能特性、優化策略、適用范圍以及技術復雜性等方面。以下是對兩者區別的詳細探討,旨在全面解析其內在差異。
Meta發布基于Code Llama的LLM編譯器
近日,科技巨頭Meta在其X平臺上正式宣布推出了一款革命性的LLM編譯器,這一模型家族基于Meta Code Llama構建,并融合了先進的代碼優化和編譯器功能。LLM
評論