次のようなことをします:
if value != nil {
return *value
}
return defaultValue
...このような単純なセレクターではかなり面倒です。 本当にあるべきです:
value != nil ? *value : defaultValue
... また:
cond value != nil, *value, defaultValue
Goに3進式がないことは、(読みやすさのために)明示的な設計上の決定でした。
Goを使用すると、さらに数行書くことがありますが、明確さと読みやすさのためにそのコストを受け入れます。
私は現在、単純で単純な条件マッピングが山ほどある部分に取り組んでいます。 三項演算子がないため、読みにくくなります。 とてもイライラします!
三項演算子を使用すると、コードが読みやすくクリーンになります。
これは私がJavascriptで行った方法です:
function getLevel(level) {
- if (level <= 23100) {
- return 23100
- }
- else if (level <= 24000) {
- return 24000
- }
- else if (level <= 25200) {
- return 25200
- }
- else if (level <= 26400) {
- return 26400
- }
- else if (level <= 27600) {
- return 27600
- }
- else if (level <= 28800) {
- return 28800
- }
- else if (level <= 30300) {
- return 30300
- }
- else if (level <= 31800) {
- return 31800
- }
- else if (level <= 33300) {
- return 33300
- }
- else if (level <= 34800) {
- return 34800
- }
- else if (level <= 36300) {
- return 36300
- }
- else if (level <= 38200) {
- return 38200
- }
- else if (level <= 40100) {
- return 40100
- }
- else if (level <= 42000) {
- return 42000
- }
- else if (level <= 43900) {
- return 43900
- }
- else {
- return 45800
- }
+ return level <= 23100 ? 23100 :
+ level <= 24000 ? 24000 :
+ level <= 25200 ? 25200 :
+ level <= 26400 ? 26400 :
+ level <= 27600 ? 27600 :
+ level <= 28800 ? 28800 :
+ level <= 30300 ? 30300 :
+ level <= 31800 ? 31800 :
+ level <= 33300 ? 33300 :
+ level <= 34800 ? 34800 :
+ level <= 36300 ? 36300 :
+ level <= 38200 ? 38200 :
+ level <= 40100 ? 40100 :
+ level <= 42000 ? 42000 :
+ level <= 43900 ? 43900 : 45800
}
最も参考になるコメント
Goに3進式がないことは、(読みやすさのために)明示的な設計上の決定でした。
Goを使用すると、さらに数行書くことがありますが、明確さと読みやすさのためにそのコストを受け入れます。