跳到主要內容

【開發智能合約 - Solidity系列】淺談智能合約

 為什麼會有合約的誕生? 大家想過這個問題嗎?

試想,當陌生人與陌生人之間如果要產生與金錢相關的交易時,在沒有第三方機構的見證下,我想一般人應該也會存在著「不信任」的狀況產生,因此造就了「合約」的誕生,而這個「合約」主要目的在於確保雙方能夠在不損害對方的利益下完成交易的一種約定,其中包括了雙方的資訊、條款的內容、有效期限、簽名的不可變動性,滿足這些條件後方可形成「合約」,並由第三方機構進行認證來增加公信力。

既然已經有合約的產生,那又為什麼還要創造智能合約呢? 究竟相較於傳統合約之下,更為優勢的原因在哪裡呢? 我們將在以下逐一進行說明。

首先來談談傳統合約

圖片來源: 自行製作

在開始說明智能合約之前,我們先來了解一下合約的本質,什麼是合約? 其實「合約」常常出現在我們的周遭,就以買房來說,買賣雙方簽訂契約後,會需要許多第三方機構的保證才能讓雙方安全的完成交易,諸如: 建商、銀行、代書…等,這些第三方雖然保障了雙方交易的安全性,但某一方如果發生問題也會連帶影響,況且尚未完成交易之前就支付了許多費用給這些第三方單位,有沒有可能讓這個過程更加簡單,並且更加安全呢? 答案是有機會的,智能合約就是為了滿足這樣的需求而生,當然在這裡並不是說「智能合約」就是完美無缺,我們看到好處之外,也得了解現況與缺陷,才能不會被艱澀難懂的技術名詞給誤導了。

再來看看智能合約

圖片來源: 自行製作

我想智能合約與傳統合約最大的差異就在於沒有第三方機構的介入,一但合約成立、條件滿足,雙方的交易自然得到保障,驗證、不可竄改、自動金流…等,這些過往在傳統合約的組成中,還會分別依賴外部,因此就會產生所謂的手續費,而且過程中也未必具備公平性,但在智能合約的世界裡,由於一切皆由程式執行,只要確保條件沒問題自然就不會有例外狀況,這也就是為什麼大家都在談的「去中心化」的主要核心,但值得注意的是條件必須符合合約的需求,否則需求讓的落差也是一種例外狀況。

可以用在哪些領域?

金融

智能合約非常適合用於金融領域,交易過程中的不信任是過往遇到的最大挑戰,因此造就了無數個第三方機構,就為了保障雙方的可信任度,一但智能合約引入之後,打破了第三方的存在,讓交易雙方直接溝通,過程中透明、不可竄改,對於金融領域來說真的是一大福音,但對於傳統的金融體系卻是一大挑戰,也是較難盛行的原因。

保險

試想我們平常遞繳保險費用就是為了在意外發生時能夠有一份保障, 那麼「理賠」就非常重要了, 如果在合約初始設計時就設定當某個事件發生時, 需賠付的範圍條件, 就能夠讓一份保單透明、不可竄改的留存於區塊鏈, 而被保人只要同意並簽訂合約即可, 剩下的就是待事件發生時自動化金流給付。

投票系統

投票是一種非常講求公平性的動作,因此也非常適合不易竄改的特性,加上沒有中心化的過程,能夠大幅減少舞弊的現象,最終合理的統計出正確的票數。

風險與隱憂

前面的介紹大致上已經了解「智能合約」所帶來的諸多好處,但難道只有好處沒有任何的缺點嗎? 這是值得我們深思的問題,基本上創造「合約」的還是「人」,只要本質上離不開人性,就無法保證完全公平的狀況,歸納以下幾個可能的風險與隱憂,純屬個人觀點,如若有朋友具有不同的看法歡迎下方留言討論,讓我們互相學習,共同理解智能合約的本質。

● 開發人員撰寫合約觸發條件後,發生與用戶的預期結果不符,其實就想像軟體業的專案開發,開發者與需求者之間的認知落差,但不同的是「智能合約」一但上鏈後就無法竄改。
● 由於合約在區塊鏈上是透明的,因此合約漏洞只要被駭客發現就能夠根據漏洞造成一些危害。
● 法律尚未成熟,由於這一塊屬於較新穎的領域,因此仍處於灰色地帶,也因為去中心化的特性,導致現有的法規並無法去規範這一塊的交易。

結語

一門技術的發展都是為了改變我們過往不方便的流程,我們應該試著接納而不是抗拒,分析與理解技術的本質與帶來的好處之外,亦需考慮到衍生的風險,世界上的財富都取決於我們的認知程度,因此只要抱著持續學習的心態,就能夠賺到認知上的財富,也不會隨意的被詐騙,個人也是一路跌跌撞撞,慢慢學習,並將學習過程化為圖文,與大家共享,期望一起成長。

下一篇我們就來談談開發智能合約的入門教學,【開發智能合約 - Solidity系列】認識Solidity,讓我們一步一腳印,學習與探索智能合約誕生的過程,讓我們對這個專有名詞具有更深入的了解。

資源參考

https://www.youtube.com/watch?v=AmDj6Du4C8s&ab_channel=Coinlife


--------------------------------------------------------------------------------------------

喜歡撰寫文章的你,不妨來了解一下:
Web3.0時代下為創作者、閱讀者打造的專屬共贏平台 - 為什麼要加入?
歡迎加入一起練習寫作,賺取知識,累積財富!

留言

這個網誌中的熱門文章

java西元民國轉換_各種不同格式

C#資料庫操作(新增、修改、刪除、查詢)

【Excel好好玩】 自己的資產自己管!善用Google Sheet來幫我們評估貸款

這次介紹的主題是關於Excel的貸款還款計畫試算,我們人生中總會遇到需要大筆金額的花費,但當資金不夠時就得進行貸款,而貸款之前如果我們能夠審慎評估,並分析自己的還款能力之後在進行凍作,相信風險會小很多,因此就自己動動手來使用Google Sheet進行試算吧! 基本資料 ● 貸款總額: 1000000 ● 貸款期數: 84月 ● 年利率: 2.11% ● 月利率: 0.18% P.S 月利率 = 年利率 / 12 重要函式 PMT : 這是Google Sheet內建的重要年金計算公式,我們可以善用這個公式來計算固定利率及期數的固定攤還本息。因為PMT函式計算出的結果為負數,所以前面加上-號轉成正數。 動手做 首先我們在Excel表上列出我們的基本資料 圖片來源 其中月利率的部分就使用公式「=B4/12」 接著我們填上第一列的期數跟餘額 圖片來源 =B2 =B3 使用關鍵PMT函數來計算本息的部分 因為PMT函式計算出的結果為負數,所以前面加上-號轉成正數。 -PMT(貸款利率(月利率), 貸款期數, 貸款總額) =-PMT($B$5,$B$3,$B$2) 圖片來源 計算利息 利息 = 貸款餘額 x 月利率 =B8*$B$5 圖片來源 計算本金 本金 = 本息 - 利息 =C8-D8 圖片來源 製作第二列餘額的部分 餘額的部分 = 上一期的餘額 - 上一期的本金 圖片來源 接著拖曳該兩列往下拉,即可查看每一期的利息與本金 圖片來源 結語 雖然市面上已經有很多貸款銀行都提供了試算功能,但如果我們想要進一步管理自己的資產時,就需要將每一期的金額給計算出來,因此才會將公式運用在Excel表,讓我們的資產管理表能夠結合負債,進一步評估我們理財行動的下一步,希望這樣的經驗可以幫助到正在理財道路上打拼的夥伴,讓我們透過有效的管理,幫助荷包長大吧! 喜歡撰寫文章的你,不妨來了解一下: Web3.0時代下為創作者、閱讀者打造的專屬共贏平台 — 為什麼要加入? 歡迎加入一起練習寫作,賺取知識,累積財富!