上個月,在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()返回的類型名稱是可讀的,因此最終輸出如下圖。
對于指針,許多運算符都被禁止了,看如下例子: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文章
2124瀏覽量
77119 -
編譯器
+關注
關注
1文章
1672瀏覽量
51615
原文標題:Herb Sutter 介紹一個處于他實驗中的 C++ 新編譯器和一種潛在的 C++ 替換語法
文章出處:【微信號:CPP開發者,微信公眾號:CPP開發者】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
熱點推薦
C編譯器錯誤與解決方法
C語言keil編譯器提示錯誤的解決方法,可以幫你解決程序編譯中的煩惱!!
C編譯器錯誤與解決方法
1. Warning 280:’i’:unreferenced local var
發表于 01-22 08:03
在ADS編譯器中,用標準的C庫函數printf()需要哪些設置呢?
在ADS編譯器中,用標準的C庫函數printf()需要哪些設置呢?又在哪兒可以看到printf()輸出的信息呢?
發表于 12-23 07:32
單片機開發功能安全中編譯器
的行為將符合開發人員的意圖。對調試工具使用的數據的“后門”訪問代表了該語言不允許的另一種情況,因此可能會帶來意想不到的后果。
編譯器優化可能對所有這些領域產生重大影響,因為它們都不屬于編譯器供應商
發表于 12-01 06:44
性能突破 | SpacemiT-X60 在 LLVM 編譯器上實現 16% 顯著提升
2025年10月,在北美RISC-V峰會上,Igalia編譯器工程師Mikhail發表專題演講《Unlocking15%MorePerformance
開源鴻蒙技術大會2025丨編譯器與編程語言分論壇:語言驅動系統創新,編譯賦能生態繁榮
在萬物智聯的時代背景下,操作系統底層能力的構建離不開編程語言與編譯器的關鍵支撐。作為開源鴻蒙生態的核心技術,語言設計與編譯器、虛擬機實現的進步直接關系到開發效率、運行性能與系統安全。本次分論壇聚焦
GCC編譯器,怎么才能實現c文件中未被調用的函數,不會被編譯呢?
GCC編譯器,怎么才能實現c文件中未被調用的函數,不會被編譯?有什么編譯選項可以設置嗎?
移植代碼,有些函數沒被調用的函數想留在代碼里,但不想被編譯
發表于 09-28 12:25
修改Kconfig的配置后,編譯基本等于重新編譯一遍,怎么解決?
進行重新編譯既可?
像linux有fixdep,那么rt-thread中能夠有類似手段嗎?如果使用GCC應該可以做,其他編譯器就困難了吧
發表于 09-28 11:17
邊緣設備AI部署:編譯器如何實現輕量化與高性能?
、ASIC等)上高效執行的機器代碼。AI編譯器在AI模型的部署和優化中扮演著關鍵角色,能夠顯著提升模型的運行效率和性能。 ? AI編譯器的主要功能 ? AI編譯器的主要功能包括模型優化
編譯器功能安全驗證的關鍵要素
在汽車、工業、醫療等安全關鍵型應用中,確保功能安全合規性需要嚴格的工具鏈驗證。開發安全關鍵型軟件的企業必須遵守ISO 26262、IEC 61508、ISO 62304等國際標準對編譯器工具鏈進行全面的驗證。
兆松科技ZCC編譯器全面支持芯來科技NA系列處理器
近日,兆松科技(武漢)有限公司(以下簡稱“兆松科技”)宣布正式發布高性能RISC-V編譯器ZCC 4.0.0版本。
RISC-V架構下的編譯器自動向量化
進迭時空專注于研發基于RISC-V的高性能新AICPU,對于充分發揮CPU核的性能而言,編譯器是不可或缺的一環,而在AI時代,毫無疑問向量算力將發揮越來越重要的作用。進迭時空非常重視RISC-V
RVCT編譯器是否比GNU的編譯器的代碼執行速度更快?
使用FX3S遇到了RVCT編譯器的問題。
1、在SDK的release note中有支持RVCT的描述,
但是在EZ USB Suite的設置中沒有找到RVCT的選項,
請問支持的具體版本
發表于 05-08 07:49
HighTec編譯器全面支持芯馳科技車規MCU芯片E3650
近日,HighTec與芯馳科技共同宣布HighTec編譯器套件將全面支持芯馳新一代旗艦智控MCU-E3650芯片。此次合作,進一步豐富了芯馳車芯產品的工具鏈生態,雙方將攜手為客戶提供高性能、高安全性的解決方案。
HighTec編譯器全面適配紫光同芯THA6 Gen2系列產品
近日,紫光同芯與全球領先的汽車級C/C++編譯器供應商HighTec共同宣布,HighTec編譯器完成對紫光同芯THA6 Gen2系列產品的全面適配。此次合作實現了從指令集優化到功能安全的全棧支持,是國產高端車規芯片與國際領先開發工具的深度技術融合,將為全球汽車電子開發者
一個處于實驗中的新編譯器:CppFront
評論