Golang學習系列第二天:變數、常量、數據類型和流程語句

来源:https://www.cnblogs.com/dongguangming/archive/2020/07/13/13296657.html
-Advertisement-
Play Games

繼golang第一天後,今天學習下golang的變數、常量、數據類型和控制流語句。 做過其他編程語言(比如JavaScript,java,python)項目的話,其實很好理解變數、常量、數據類型和控制流。 變數也被稱為“變數”,是反映事物運動變化狀態的量,比如匯率、房貸利率、貸款利率。 常量也被稱“ ...


 

       繼golang第一天後,今天學習下golang的變數、常量、數據類型和控制流語句。

做過其他編程語言(比如JavaScript,java,python)項目的話,其實很好理解變數、常量、數據類型和控制流。

變數也被稱為“變數”,是反映事物運動變化狀態的量,比如匯率、房貸利率、貸款利率。

常量也被稱“常數”,是反映事物相對靜止狀態的量,一旦定義,後續不能更改,比如圓周率PI。

Golang是不同於JavaScript和python,但它和java一樣,是一種靜態類型的編程語言,就是說定義變數或常量前需要聲明其類型

1.   變數

1.1  聲明一個變數

變數在使用前需要聲明,例如

package main

import "fmt"

func main() {
   var age int //age預設是0
   fmt.Printf("我的年齡是:%d 歲\n", age)
   age = 99 //給age賦值
   fmt.Printf("我的年齡是:%d 歲", age)
}

輸出如圖

1.2  自動推導變數類型

也可以用另一種寫法,根據值推導變數的類型

package main

import "fmt"

func main() {
   var age = 99
   fmt.Printf("我的年齡是:%d 歲\n", age)
   age = 100  //
}

輸出結果

1.3   速記法定義變數

還有一種更簡潔的寫法


import "fmt"

func main() {
   //fmt.Printf("hello, world\n")
   //var name string
   age := 99
   fmt.Printf("我的年齡是:%d 歲\n", age)
   age = 100
}

1.4  定義多個變數

真正開發時我們需要定義多個變數,比如一個用戶有姓名,年齡,性別,地址,城市等多個欄位

我是用1.1的寫法定義變數的

package main

import "fmt"

func main() {
   //fmt.Printf("hello, world\n")
   //var name string
   var (
	name     string = "董廣明"
	age      int    =  99
	city     string = "金陵城"
    )
    
   	fmt.Printf("我叫:%s ,年齡:(%d),所在城市:%s", name, age, city)
}

輸出結果

1.5  函數式變數

JavaScript中這種定義很常見,一個變數可以是任何類型,包括函數,golang也支持,真是融合了好幾種語言的特性,java並不支持

package main

import "fmt"

func main() {
   	//變數也可以是函數定義
   	print := func() {
		var (
	     name     string = "董廣明,dgm"
         age      int    =  99
    	 city     string = "金陵其實就是南京"
         )
    
       	fmt.Printf("我叫:%s ,年齡:(%d),所在城市:%s", name, age, city)
	}
	
	print()
}

輸出結果

 

2   常量

常量定義和變數類似,只是多了個關鍵字const

package main

import "fmt"

const (
	Pi    = 3.141592653
	Loading = false
	Name   = "dongguangming"
	Age = 99
)

func main() {
	const City = "金陵城"
	fmt.Println(City)
	fmt.Println(Pi)
	fmt.Println(Loading)
	fmt.Println(Name)
    fmt.Println(Age)
	//const CompanyName := "某公司"  //不支持, 編譯不過去
}

輸出結果

常量小結:Constants can only be character, string, boolean, or numeric values and cannot be declared using the := syntax. An untyped constant takes the type needed by its context.

 

3.   數據類型

分兩種:基本數據類型和derived派生數據類型,在此只先介紹基本的數據類型,後一種以後單獨介紹

3.1   基本數據類型

基本數據類型又有以下幾種類型:布爾bool,字元串string,數值型number,複數型數據類型

3.1.1  布爾bool

bool類型表示布爾邏輯,它的值要麼為true,要麼為false

package main

import "fmt"

func main() {  
    have := true
    nohave := false
    fmt.Println("have:", have, "nohave:", nohave)
    result_and := have && nohave
    fmt.Println("result_and:", result_and)
    result_or := have || nohave
    fmt.Println("result_or:", result_or)
}

以上代碼中,定義了 變數have並賦值為true和變數nohave並賦值為false

變數result_and被賦值為false,因為邏輯操作符&&表示兩邊的值都為true的情況下才返回ture,例子中只有have為true,故運算結果為false。

變數result_or被賦值為true,因為邏輯操作符||表示兩邊的值只要有一個為true的情況下就返回ture了,例子中剛好有have為true,故運算結果為true。

執行以上輸出以下結果

理論分析是正確的

 

3.1.2  字元串String類型

字元串是位元組的集合,存儲了字元序列。

package main

import (  
    "fmt"
)

func main() {  
    first := "董"
    last := "廣明"
    name := first + last
    fmt.Println("我的名字叫: ",name)
}

輸出結果:

 

3.1.3  數值型

數值型細分有以下幾種

Numeric types:

uint        either 32 or 64 bits,represents 32 or 64 bit unsigned integers depending on the underlying platform,32 bits in 32 bit systems and 64 bits in 64 bit systems( 0 to 4294967295 in 32 bit systems and 0 to 18446744073709551615 in 64 bit systems ).
int         either 32 or 64 bits,represents 32 or 64 bit integers depending on the underlying platform. You should generally be using int to represent integers unless there is a need to use a specific sized integer,32 bits in 32 bit systems and 64 bit in 64 bit systems(-2147483648 to 2147483647 in 32 bit systems and -9223372036854775808 to 9223372036854775807 in 64 bit systems)
uintptr     an unsigned integer large enough to store the uninterpreted bits of
            a pointer value
uint8       the set of all unsigned  8-bit integers (0 to 255)
uint16      the set of all unsigned 16-bit integers (0 to 65535)
uint32      the set of all unsigned 32-bit integers (0 to 4294967295)
uint64      the set of all unsigned 64-bit integers (0 to 18446744073709551615)

int8        the set of all signed  8-bit integers (-128 to 127)
int16       the set of all signed 16-bit integers (-32768 to 32767)
int32       the set of all signed 32-bit integers (-2147483648 to 2147483647)
int64       the set of all signed 64-bit integers
            (-9223372036854775808 to 9223372036854775807)

float32     the set of all IEEE-754 32-bit floating-point numbers
float64     the set of all IEEE-754 64-bit floating-point numbers

complex64   the set of all complex numbers with float32 real and imaginary parts
complex128  the set of all complex numbers with float64 real and imaginary parts

byte        alias for uint8
rune        alias for int32 (represents a Unicode code point)

整數式

package main

import (  
    "fmt"
    "unsafe"
)

func main() {  
    var first int = 88
    second := 99
    fmt.Println("第一個值=", first, ",第二個值=", second)
    fmt.Printf("first的類型是:%T, first的大小 %d", first, unsafe.Sizeof(first)) //type and size of first
    fmt.Printf("\nsecond的類型是: %T, second的大小 %d", second, unsafe.Sizeof(second)) //type and size of second
}

浮點數

package main

import (  
    "fmt"
)

func main() {  
    first, second := 6.66, 9.99
    fmt.Printf("first的類型是 %T second的類型是%T\n", first, second)
    sum := first + second
    diff := first - second
    fmt.Println("相加和是", sum, "相減差是", diff)
}

 複數計算

package main

import (  
    "fmt"
)

func main() {  
    first := complex(5, 7)
    second := 8 + 27i
    sum := first + second
    fmt.Println("複數相加和:", sum)
    diff := first - second
    fmt.Println("複數相減差:", diff)
    product := first * second
    fmt.Println("複數相乘:", product)
}

 

由於數值型可能會參數數學計算,但golang本身沒有自動轉換功能,故需要手工顯示轉換數據類型

package main

import (  
    "fmt"
)

func main() {  
    first := 66      //int
    second := 77.7    //float64
    //sum := first + second //int + float64 not allowed,編譯不通過,故需要下麵顯示轉換,golang沒有自動轉換功能
    sum := first + int(second) //second is converted to int

    fmt.Println(sum)
}

但是有例外情況

package main

import (  
    "fmt"
)

func main() {  
    first := 10
    var second float64 = float64(first) //this statement will not work without explicit conversion
    fmt.Println("second:", second)
}

輸出結果

沒有像其他語言轉換後有標誌10.0f 

 

4. 流程語句

分三種:if條件/if else, loop迴圈,switch 

4.1  if, if else

4.1.1   if語句

用於指定是否應執行相應的代碼塊,語法結構:

if(condition) {
  // 執行condition為true時的代碼邏輯
}

例如

package main
import "fmt"

func main() {
    var country = "中國"
	var age = 18
	if(country == "中國" && age>=18) {
		fmt.Printf("你已經是成年人了,該掙錢了\n")
	}
}

輸出結果

Note that, You can omit the parentheses () from an if statement in Golang, but the curly braces {} are mandatory - 

註意,在golang的世界里你可以不使用if後面的插入語(),但是後面的花括弧是必須的,示例

if country == "中國" && age>=18 {
		fmt.Printf("你已經是成年人了,該掙錢了\n")
}

4.1.2  If-Else語句

一個if語句能配合else語句塊使用,當if里的條件為false,else語句塊的邏輯代碼會被執行,代碼結構

if condition {
  // code to be executed if the condition is true
} else {
  // code to be executed if the condition is false
}

示例代碼

package main
import "fmt"

func main() {
	var age = 18
	if age >= 18 {
		fmt.Println("很好,你已經是個成年人了,不是小孩子了!!!")
	} else {
		fmt.Println("抱歉,你還未成年!")
	}
}

輸出結果

4.1.3   If-Else-If鏈

if語句能夠有多個else語句塊,例如

package main
import "fmt"

func main() {
	var age = 12
	if age>=6 && age < 11 {
		fmt.Println("你可能在上小學");
	} else if age >= 12 && age < 15 {
		fmt.Println("你可能在上初中");
	} else if age >= 15 && age < 18 {
		fmt.Println("你可能在上高中")
	} else {
		fmt.Println("上大學了")
	}
}

4.1.4  if短語句

if語句允許在條件表達式之前包含一個簡短的聲明語句

package main
import "fmt"

func main() {
   if first := 10; first%2 == 0 {
     fmt.Printf("%d 是偶數\n", first)
   } 

   if second := 15; second%2 == 0 {
  fmt.Printf("%d 是偶數\n", second)
} else {
  fmt.Printf("%d 是奇數\n", second)
}
}

特別留意: The variable declared in the short statement is only available inside the if block and it’s else or else-if branches ,

If you’re using a short statement, then you can’t use parentheses. 如下代碼會報錯

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • WEB學習路線2020完整版+附視頻教程,適合初學者的最新WEB前端學習路線彙總! ...
  • 以下純屬個人觀點和建議,肯定是有局限性的,但是也希望能給你帶來一些幫助。 我們儼然能感受到前端崗位現在已經發展成了最重要的研發崗位之一,所以多我們提出的要求也就越來越高了。所以我們需要的也就不僅僅只是掌握css、html、JavaScript了,但是這三大件一直都是前端的根本,這一點從未改變,而這三 ...
  • 1. 引言 1.1. 背景 隨著時代的進步,社會的發展,人們的生活形式與習慣也越來越多樣化,出行成為了人們生活中的一個重要組成部分,而客車成為許多人出行選擇的交通工具。面對巨大數量的乘客的購票需要,客車站就要選擇使用先進的管理方法來實現方便、快捷的售票、退票等方面的票務管理。隨著電腦的普及,信息處 ...
  • 動畫是將靜止的畫面變為動態的藝術.實現由靜止到動態,主要是靠人眼的視覺殘留效應。視覺殘留也叫視覺暫留現象,物體在快速運動時, 當人眼所看到的影像消失後,人眼仍能繼續保留其影像0.1~0.4秒左右的圖像,這種現象被稱為視覺暫留現象。利用人的這種視覺生理特性可製作出具有高度想象力和表現力的動畫影片。 電 ...
  • 一、 引言 對於一個多人團隊來說,制定一個統一的規範是必要的,因為個性化的東西無法產生良好的聚合效果,規範化可以提高編碼工作效率,使代碼保持統一的風格,以便於代碼整合和後期維護。 二、 HTML/CSS規範 2.1 瀏覽器相容 根據公司業務要求而定,一般:主流程測試:Chrome 30+、IE9+; ...
  • 結構型模式 適配器模式 類適配器和對象適配器 結構型模式 結構型模式的重點在於如何通過靈活的體系組織不同的對象,併在此基礎上完成更為複雜的類型(或者類型系統),而參與組合的各類型之間始終保持儘量鬆散的結構關係。 結構型模式包括以下幾種: 適配器模式 橋接模式 組合模式 裝飾模式 外觀模式 享元模式 ...
  • 前段時間做了個node全棧項目,服務端技術棧是 nginx + koa + postgresql。其中在centos上搭建環境和部署都挺費周折,部署測試伺服器,接著上線的時候又部署生產環境伺服器。這中間就有很多既無聊又費精力,吃力不討好的"體力活"。所以就開始思考怎麼自動化這部分搭建部署的工作,也就 ...
  • 1 #include <emscripten/bind.h> 2 #include <string> 3 4 using namespace std; 5 using namespace emscripten; 6 7 class xClass { 8 public: 9 // 構造方法; 10 x ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...