Re: [討論] 為什麼不要用c++寫網站

作者: pichubaby (Pichu)   2024-06-28 04:00:44
※ 引述《brucetu (sec)》之銘言:
: 現代網站開發一定有框架
: 幾乎所有的操作都有現成的函數讓你用
: 也是就說
: 就算用c++開發也只是在call框架的API
: 把資料丟來丟去而已
: 有人覺得python / .net 寫網站比較簡單
: 但其實框架包得好
: 就算是c++也沒有什麼不同吧?
: 例如 python 的 list comprehension
: 或是 .net 的 linq
: 都可以包成一個套件來做啊
: 在 c++ 也就只是一行 function call 而已了
: 那為什麼不用c++開發網站就好了?
如果是我的話也許寧願選擇用 C 也不太會選擇用 C++ 開發網站。
C 和 C++ 的好處在於沒有節操,大部分軟體工程師講得出來的程式語言,都會有記憶體
範圍保護以及垃圾回收的設計。
但是 C 和 C++ 沒有,C 和 C++ 覺得這是工程師應該要負責的事情。
而大部分的 HTTP 伺服器,如果是使用 nginx 或是 apache 的話,基本上這兩套都是純
C 下去開發的,在更底層的 Linux 或是 Windows 的 TCP 演算法原則上也是 C 開發的
居多。
資料庫的部分 Postgres 是 C, MongoDB 是 C++,所以其實大多數組件都是 C 開發的,
只是一般的軟體開發團隊比較不會真的去重新編譯這些東西,但是如果是做路由器相關
的 HTTP Server 的話,或是物聯網相關的,那就有可能真的是用 C 直接輸出 HTML。
回到正題。
在工程上選擇要用什麼語言或是更精確來說要用什麼技術來開發,原則上取決於專案預期
獲利以及死線大概在哪邊。哪個語言有相對多的函式庫或者是範例通常就會用哪個語言,
但更現實的是前人留下來的東西是什麼語言通常就是那個語言。
Meta =FB 現在還有部分 PHP, 畢竟老闆以前就是用 PHP 的。
然後如果是手機 APP, 因為 Apple 給的範例就是 Obj-C, 所以雖然可以用 C++ 來寫,但
是可能不會是太愉快的體驗。
接著談到框架,大部分的框架都會降低執行期效能。
降低執行期效能等於增加上線後伺服器資源費用也等同於消耗更多電力或者是說不環保。
同時執行期效能降低也會增加反應時間降低使用者體驗。
但是在十到二十年前,大部分的效能並不是卡在商業邏輯的部分。
同樣是 printf("<html ...... 使用 C 和 PHP 並不會差到哪裡去,大部分的效能差異
會在使用者 56K 的數據機以及 SAS 硬碟的轉速上面。
所以與其用 C 去改善商業邏輯,不如多投資一些頻寬或者是磁碟陣列,甚至是記憶體。
但是現在的狀況稍微不太一樣,畢竟 Redis 興起,資料庫可以直接放在記憶體做 IMDB
網路速度是 10Gbps 起跳,已經超過普遍伺服器 CPU 3GHz 的速率了,因此商業邏輯
的常數效能是不是仍然不重要這點可以重心評估。
另外雖然 Python 有助於讓大眾可以接觸到 AI,很快速的兜出模型出來,但畢竟他還是
有一些記憶體保護上的矜持,所以效能注定沒辦法超越 C / C++ ,因此也有出現像是
LLAMA.cpp 這樣的專案,那麼他也是有 HTTP Server 的,所以說千萬不要說死說不可能用
C / C++ 去做的這種事。
那不過通常寫 C / C++ 的工程師必須要能夠保持很多好習慣,例如玩具玩玩要收好,
malloc 用完要做 free,我的瀏覽器分頁數量證明了我很難保持這種習慣,所以基本上
我都是用 Golang 這類型有垃圾回收機制的語言來做開發。
順帶一提,「把 C 包裝起來這樣就可以有 C 的效能而且還可以快速開發」的想法很多工
程師都想過,所以我們才會有了各式各樣的程式語言,包括 PHP, Python, Ruby ... ...
大概除了 JAVA 以外大致上都是因為這樣所以開發了一個框架語言出來。
如果說一點都不在乎有可能發生 Stack overflow 或是 memleak 的話,那還是可以試試
看用 C 開發,否則現在的話或許會比較推薦可以用 Rust 做開發。
至於開發速度而言,目前已經是 Copilot 的時代了,開發速度原則上取決於在心中想像
架構以及如果遇到問題除錯的速度,打字或是變數命名交給 IDE 處理就行了。
使用 C 但是卻無視掉記憶體複製造成的成本的話,那可能就和使用其他語言的狀況差不
多,甚至會更糟,但是如果在每個設計都仔細考慮記憶體複製的成本的時候,那麼整體
的設計速度就會稍微下降了,大概是這樣。
作者: final01 (牛頓運動定律)   2024-06-28 07:31:00
好慘,一個不懂c++的人說c比c++適合...
作者: RouterHsieh (醉臥美人膝,醒掌天下權)   2024-06-28 07:55:00
作為一個搞底層出身的人我覺得這篇很中肯啊,一樓的覺得人家不懂的話要不要自己回一篇?
作者: sw12 (專注.幽默)   2024-06-28 09:14:00
看到節操我笑了...要你什麼姿勢就什麼姿勢。這是C的魅力
作者: psychic (過路人)   2024-06-28 09:26:00
用C寫web,都不用考慮相容性了嗎...更新改死你
作者: nicehorse06 (嘿嘿馬)   2024-06-28 09:50:00
請問原po覺得rust未來趨勢?是否很多C的情景都可以改用rust
作者: Bencrie   2024-06-28 10:14:00
我是覺得 CPU 3GHZ 跟 10Gbps 的關係比較奇怪啦
作者: neo5277 (I am an agent of chaos)   2024-06-28 10:20:00
純推分頁開一堆
作者: wei115 (ㄎㄎ)   2024-06-28 10:25:00
用cpython技術上來說也是用c寫web
作者: abccbaandy (敏)   2024-06-28 10:49:00
效能真的沒人在乎啦,看electron寫出來體驗爛到爆還不是只能繼續用趕快寫出來讓老闆能拿出去賣錢實在
作者: kshieh   2024-06-28 11:13:00
C++ smart pointer 表示
作者: x000032001 (版廢了該走了)   2024-06-28 13:33:00
C++ RAII表示
作者: fatb (胖逼=口=)   2024-06-28 14:01:00
確實不可能 這跟市佔扯上關係了除非不同語言做串接
作者: brucetu (sec)   2024-06-28 17:19:00
作者: knme (knem)   2024-06-29 14:52:00
作者: superpandal   2024-06-29 18:06:00
rust不論編譯耗時還是硬碟佔用都很多 整天被編譯器整蠱時間都沒了
作者: BoXeX (心愛騎士團異端審判騎士)   2024-06-29 19:53:00
一些底層的程式 連malloc都沒 記憶體自己管理的應該是沒有用 rust 的必要
作者: wsad50232 (阿豐)   2024-06-29 22:04:00
老是有人愛說別人不懂C++, 那自己又懂了什麼
作者: pot1234 (鍋子)   2024-06-29 23:47:00
不太喜歡new完不知道什麼時候會delete掉的感覺
作者: alex70266 (小眼)   2024-06-30 01:34:00
喜歡沒有節操這句 XDD害我在手機面前笑出來
作者: wizozd84070   2024-06-30 07:34:00
推,長知識了謝謝分享
作者: CoNsTaR ((const *))   2024-06-30 18:38:00
第三句就看得出來原 Po 半毛 C++ 都不懂,這樣都不能噓?你來給我教 15 分鐘會的 C++ 可能比原 Po 還多
作者: hobnob (hobnob)   2024-06-30 18:58:00
能請樓上教兩句,我最近正好在學
作者: j0958322080 (Tidus)   2024-06-30 21:33:00
給樓上,去看智慧指標
作者: wuyiulin (龍破壞劍士-巴斯達布雷達)   2024-06-30 22:40:00
三小有幫你寫好的GC比較有節操?我的頭開始痛了。
作者: wulouise (在線上!=在電腦前)   2024-06-30 22:53:00
我覺得很多lib都用c開發跟從c c++中選c這兩者沒有關聯,原PO的確沒說理由
作者: Dracarys (MayShowGunMore)   2024-07-01 15:59:00
作者: Hitmear (屍殌化液)   2024-07-01 16:00:00
現在這個時代生產力比效能重要多了,你的產品真的會壓榨全部效能嗎?我懷疑
作者: Dracarys (MayShowGunMore)   2024-07-01 16:00:00
@hobnob RAII, Rule of 0/3/5
作者: superpandal   2024-07-02 12:03:00
效能並不是完全不重要 只是效能瓶頸不在語言本身
作者: hobnob (hobnob)   2024-07-03 17:02:00
謝謝關鍵字

Links booklink

Contact Us: admin [ a t ] ucptt.com