婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > golang中為什么不存在三元運算符詳解

golang中為什么不存在三元運算符詳解

熱門標簽:長沙ai機器人電銷 澳門防封電銷卡 智能電銷機器人營銷 地圖標注測試 福州鐵通自動外呼系統 賺地圖標注的錢犯法嗎 廣東語音外呼系統供應商 濮陽自動外呼系統代理 烏魯木齊人工電銷機器人系統

三元運算符廣泛存在于其他語言中,比如:

python:

val = trueValue if expr else falseValue

javascript:

const val = expr ? trueValue : falseValue

c、c++:

const char *val = expr ? "trueValue" : "falseValue";

然而,被廣泛支持的三目運算符在golang中卻是不存在的!如果我們寫出類似下面的代碼:

val := expr ? "trueValue" : "falseValue"

那么編譯器就該抱怨了:invalid character U+003F '?'。意思是golang中不存在?這個運算符,編譯器不認識而且非字母數字下劃線也不能用做變量名,自然也就當作是非法字符了。

然而這是為什么呢,其實官方給出了解釋,這里簡單引用一下:

The reason ?: is absent from Go is that the language's designers had seen the operation used too often to create impenetrably complex expressions. The if-else form, although longer, is unquestionably clearer. A language needs only one conditional control flow construct.

golang中不存在?:運算符的原因是因為語言設計者已經預見到三元運算符經常被用來構建一些極其復雜的表達式。雖然使用if進行替代會讓代碼顯得更長,但這毫無疑問可讀性更強。一個語言只需要有一種條件判斷結構就足夠了。

毫無疑問,這是在golang“大道至簡”的指導思想下的產物。

這段話其實沒問題,因為某些三元運算符的使用場景確實會降低代碼的可讀性:

const status = (type===1?(agagin===1?'再售':'已售'):'未售')

const word = (res.distance === 0) ? 'a'
  : (res.distance === 1  res.difference > 3) ? 'b'
  : (res.distance === 2  res.difference > 5  String(res.key).length > 5) ? 'c'
  : 'd';

乍一看確實很復雜,至少第二個表達式不花個20秒細看可能沒法理清控制流程(想象一下當縮進錯位或是完全沒有縮進的時候)。

如果把它們直接轉化成if語句是這樣的:

let status = ''
if (type === 1) {
  if (again === 1) {
    status = '再售'
  } else {
    status = '已售'
  }
} else {
  status = '未售'
}

let word = ''
if (res.distance === 0) {
  word = 'a'
} else {
  if (res.distance === 1  res.difference > 3) {
    word = 'b'
  } else {
    if (res.distance === 2  res.difference > 5  String(res.key).length > 5) {
      word = 'c'
    } else {
      word = 'd'
    }
  }
}

看起來并沒有多少的改善,特別是例2,三層嵌套,不管是誰review到這段代碼難免不會抱怨你幾句。

然而事實上這些代碼是可以簡化的,考慮到三元運算符總是會給變量一個值,因此最后的else其實可以看作是變量的默認值,于是代碼可以這么寫:

let status = '未售'
if (type === 1) {
  if (again === 1) {
    status = '再售'
  } else {
    status = '已售'
  }
}

let word = 'd'
if (res.distance === 0) {
  word = 'a'
} else {
  if (res.distance === 1  res.difference > 3) {
    word = 'b'
  } else {
    if (res.distance === 2  res.difference > 5  String(res.key).length > 5) {
      word = 'c'
    }
  }
}

其次,對于例2,顯然可以使用else if來清除嵌套結構:

let word = 'd'
if (res.distance === 0) {
  word = 'a'
} else if (res.distance === 1  res.difference > 3) {
  word = 'b'
} else if (res.distance === 2  res.difference > 5  String(res.key).length > 5) {
  word = 'c'
}

現在再來看,顯然使用if語句的版本的可讀性更高,邏輯也更清晰(通過去除嵌套)。

然而事實也不盡然。除了用三元運算符表達流程控制之外,事實上更常見更廣泛的一個應用是如下這樣的表達式:

const val = expr ? trueValue : falseValue

const func = (age) => age > 18 ? '成年人' : '未成年人'

類似上述通過一個簡短的條件表達式來確定變量的值,在開發中的出現頻率是相當高的。這時三元運算符的意圖更清晰,可讀性也較if語句更高,特別是配合匿名函數(lambda表達式)使用可以極大簡化我們的代碼。

對此python的解決之道是之支持上述的簡化版三元表達式,同時表達式不支持嵌套,達到了揚長避短的目的。不過代價是編譯器的相關實現會復雜化。

而對于golang來說一個簡單的能只通過單遍掃描即可完成ast構建的編譯器是其保持急速的構建速度的秘訣之一,為了這樣簡單的功能增加編譯器實現的復雜度是不可接受的。同時由于golang“大道至簡”的哲學,能用現有語法結構解決的問題,自然不會再添加新的語法。

不過還是有辦法的,雖然不推薦:

func If(cond bool, a, b interface{}) {
  if cond {
    return a
  }

  return b
}

age := 20
val := If(age > 18, "成年人", "未成年人").(string)

不推薦這么做是有幾個原因:

  1. 使用接口導致性能下降
  2. 需要強制的類型斷言
  3. 不管三元表達式還是if語句,對于不會到達的分支是不會計算的,也就是惰性計算;而給函數傳遞參數時每一個表達式都會被計算

最后總結一下:

三元運算符的優點:

  • 對于簡短的表達式使用三元運算符表意更清晰,特別是在習慣了線性閱讀三元運算符表達式之后
  • 不需要中間狀態(例如第一個例子中的let變量可以替換為const,代碼更健壯),心智負擔更低
  • 沒有中間狀態也就意味著更少或完全沒有副作用,代碼更易跟蹤和維護

但三元運算符也有明顯的缺點:

  • 對于復雜邏輯代碼可讀性較差(例如第一個例子中的status,需要在trueValue的位置進行進一步的條件判斷時)
  • 容易被濫用,很多人將其用于替代if語句或是簡化復雜的if嵌套,這會導致上一條中所描述的結果
  • 條件分支只能為表達式,不支持多條語句

所以這是一個見仁見智的問題,總之只能入鄉隨俗了。

參考

https://juejin.im/post/6844903561759850510

https://www.it-swarm.dev/zh/javascript/替代js中的嵌套三元運算符/1055944752/

https://golang.org/doc/faq#Does_Go_have_a_ternary_form

總結

到此這篇關于golang中為什么不存在三元運算符的文章就介紹到這了,更多相關golang不存在三元運算符內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Golang 運算符及位運算詳解
  • Go語言運算符案例講解
  • 手把手帶你走進Go語言之運算符解析

標簽:西雙版納 調研邀請 德州 太原 阿克蘇 廣西 慶陽 貴陽

巨人網絡通訊聲明:本文標題《golang中為什么不存在三元運算符詳解》,本文關鍵詞  golang,中,為什么,不存在,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang中為什么不存在三元運算符詳解》相關的同類信息!
  • 本頁收集關于golang中為什么不存在三元運算符詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩欧美久久一区| 国产乱国产乱300精品| 国产高清久久久久| 国产精品久久久久久久久免费相片 | 欧美日韩成人在线| 日本高清成人免费播放| 日本韩国精品在线| 欧美色图免费看| 精品国偷自产国产一区| 久久久国产精华| 亚洲图片欧美色图| 成人免费视频app| 欧美一级精品大片| 亚洲综合区在线| 国产精品久久一级| 日韩一二三区视频| 日韩成人精品在线观看| 日韩一级片网站| 亚洲免费在线视频| 国产一区福利在线| 久久久精品国产免大香伊| 欧美va亚洲va| 性欧美疯狂xxxxbbbb| 麻豆国产精品视频| 国内精品久久久久影院薰衣草| 欧美性三三影院| 亚洲精品免费在线观看| 不卡一区二区在线| 亚洲一区在线电影| 91精品国产福利在线观看| 国产精品香蕉一区二区三区| 亚洲一区二区三区四区在线观看| av日韩在线网站| 欧美中文字幕一区二区三区| 床上的激情91.| av中文字幕亚洲| 欧美性色综合网| 色av一区二区| 国产麻豆欧美日韩一区| 精品一区二区av| 国产一区在线视频| 韩国精品免费视频| 91福利在线导航| 91精品国产色综合久久不卡蜜臀| 欧美日韩色一区| 欧美精品久久99| 精品蜜桃在线看| 久久精品人人做人人爽人人| 欧美日韩在线不卡| 久久蜜臀精品av| 国产精品女主播在线观看| 亚洲一区视频在线| 粉嫩av一区二区三区粉嫩| 亚洲国产精品嫩草影院| 99国产精品一区| 欧美精品 国产精品| 日韩一区二区三区在线| 亚洲一区二区欧美| proumb性欧美在线观看| 91麻豆精品国产91久久久久久久久 | www..com久久爱| 91麻豆精品91久久久久久清纯| 国产日韩欧美不卡在线| 日日夜夜一区二区| 菠萝蜜视频在线观看一区| 在线不卡一区二区| 亚洲国产精品传媒在线观看| 精品在线一区二区三区| 国产亚洲一区字幕| 91网站黄www| eeuss国产一区二区三区| 美女网站色91| 欧美激情艳妇裸体舞| 99久久综合精品| 一区二区三区在线视频播放| 91视频观看视频| 综合av第一页| 1000部国产精品成人观看| 精品久久久久一区| 一本一道波多野结衣一区二区| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲一区在线看| 国产精品久久久久aaaa樱花| 国产丝袜欧美中文另类| 成人免费看黄yyy456| 亚洲成人久久影院| 国产精品嫩草99a| 欧美无砖专区一中文字| 久99久精品视频免费观看| 久久超级碰视频| 亚洲一区免费观看| 国产精品美女久久久久久| 亚洲精品国产无套在线观| 欧美福利电影网| 尤物在线观看一区| 91视频国产资源| 亚洲免费av高清| 7799精品视频| 成人av网站在线| 亚洲国产欧美日韩另类综合 | jizzjizzjizz欧美| 1区2区3区欧美| 国产日韩视频一区二区三区| 99re6这里只有精品视频在线观看| 成人激情免费电影网址| 精品国产sm最大网站| 日韩一区二区免费电影| 欧美久久一二三四区| 成人三级在线视频| 日韩中文字幕一区二区三区| 亚洲一区二区三区自拍| 亚洲免费观看高清完整版在线观看| 欧美r级在线观看| 欧美一区二区三区免费| 久久精品国产精品亚洲综合| 国产精品影音先锋| 国产女主播视频一区二区| 日韩一区二区免费在线观看| 日韩美女在线视频| 欧美精品一区二区三区在线| 精品sm捆绑视频| 777亚洲妇女| 欧美v亚洲v综合ⅴ国产v| 欧美一二三在线| 精品日韩一区二区三区| 91国产丝袜在线播放| 欧美一区二区三区性视频| 精品一区二区三区视频在线观看| 视频一区中文字幕| 成人成人成人在线视频| 91精品国产手机| 亚洲另类在线一区| 精品一区二区三区在线播放视频| 久久九九全国免费| 一区二区三区在线不卡| 国产一区二区精品在线观看| 麻豆精品新av中文字幕| 色婷婷香蕉在线一区二区| 欧美一区二区日韩一区二区| 欧美视频中文一区二区三区在线观看| 日韩一区二区视频| 亚洲va欧美va天堂v国产综合| 丁香激情综合国产| 欧美一区二区私人影院日本| 91精品欧美福利在线观看| 《视频一区视频二区| 成年人国产精品| 国产精品白丝av| 337p粉嫩大胆色噜噜噜噜亚洲| 亚洲一区二区在线视频| 欧美三区在线观看| ...xxx性欧美| av不卡免费电影| 国产亚洲欧美中文| 免费观看成人鲁鲁鲁鲁鲁视频| 91精品国产乱码久久蜜臀| 麻豆一区二区99久久久久| 欧美一级搡bbbb搡bbbb| 亚洲精品水蜜桃| 一本色道亚洲精品aⅴ| 五月天国产精品| 94-欧美-setu| 国产精品沙发午睡系列990531| 国产又粗又猛又爽又黄91精品| 2020日本不卡一区二区视频| 不卡的看片网站| 亚洲图片一区二区| 久久一区二区三区四区| 在线欧美小视频| 成人免费视频app| 国产精品的网站| 日韩免费在线观看| 国产成人午夜高潮毛片| 亚洲成人福利片| 国产精品免费久久久久| 欧美一区二区三区色| 国产精品18久久久久久久网站| 日韩av中文在线观看| 99久久精品免费看国产免费软件| 久久国产精品第一页| 亚洲一卡二卡三卡四卡无卡久久| 18成人在线观看| 26uuu国产电影一区二区| 91久久国产综合久久| 不卡一二三区首页| 精品一区二区国语对白| 久久精品国产99久久6| 亚洲福中文字幕伊人影院| 亚洲乱码中文字幕| 26uuu精品一区二区| 久久综合网色—综合色88| 国产精品资源站在线| 国产乱码精品一区二区三区忘忧草 | 91在线视频免费观看| 喷水一区二区三区| 国产精品初高中害羞小美女文| 国产精品视频一二三| 亚洲欧洲国产专区| 亚洲午夜av在线| 婷婷中文字幕综合|