亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用Golang實(shí)現(xiàn)對(duì)網(wǎng)絡(luò)數(shù)據(jù)包的捕獲與分析

 更新時(shí)間:2023年11月17日 09:37:41   作者:一只會(huì)寫程序的貓  
在網(wǎng)絡(luò)通信中,網(wǎng)絡(luò)數(shù)據(jù)包是信息傳遞的基本單位,抓包是一種監(jiān)控和分析網(wǎng)絡(luò)流量的方法,用于獲取網(wǎng)絡(luò)數(shù)據(jù)包并對(duì)其進(jìn)行分析,本文將介紹如何使用Golang實(shí)現(xiàn)抓包功能,包括網(wǎng)絡(luò)數(shù)據(jù)包捕獲和數(shù)據(jù)包分析,需要的朋友可以參考下

介紹

在網(wǎng)絡(luò)通信中,網(wǎng)絡(luò)數(shù)據(jù)包是信息傳遞的基本單位。抓包是一種監(jiān)控和分析網(wǎng)絡(luò)流量的方法,用于獲取網(wǎng)絡(luò)數(shù)據(jù)包并對(duì)其進(jìn)行分析。在Golang中,我們可以借助現(xiàn)有的庫(kù)來(lái)實(shí)現(xiàn)抓包功能,進(jìn)一步對(duì)網(wǎng)絡(luò)數(shù)據(jù)進(jìn)行分析和處理。

本文將介紹如何使用Golang實(shí)現(xiàn)抓包功能,包括網(wǎng)絡(luò)數(shù)據(jù)包捕獲和數(shù)據(jù)包分析。我們將使用gopacket庫(kù)來(lái)實(shí)現(xiàn)抓包功能,并結(jié)合示例代碼來(lái)演示抓包過(guò)程以及常見(jiàn)的數(shù)據(jù)包分析方法。

準(zhǔn)備工作

在開(kāi)始之前,我們需要安裝gopacket庫(kù)。打開(kāi)命令行界面,并執(zhí)行以下命令:

go get github.com/google/gopacket

安裝完成后,我們就可以開(kāi)始使用gopacket庫(kù)來(lái)進(jìn)行抓包和數(shù)據(jù)包分析。

抓包基礎(chǔ)

打開(kāi)網(wǎng)絡(luò)設(shè)備

首先,我們需要確定要監(jiān)控的網(wǎng)絡(luò)設(shè)備??梢酝ㄟ^(guò)以下代碼來(lái)獲取計(jì)算機(jī)中的網(wǎng)絡(luò)設(shè)備列表:

package main

import (
	"fmt"
	"net"
)

func main() {
	interfaces, err := net.Interfaces()
	if err != nil {
		fmt.Println("Failed to get interfaces:", err)
		return
	}

	fmt.Println("Network interfaces:")
	for _, iface := range interfaces {
		fmt.Println("- Name:", iface.Name)
	}
}

執(zhí)行上述代碼,會(huì)輸出計(jì)算機(jī)上所有的網(wǎng)絡(luò)設(shè)備名稱。

可以通過(guò)以下代碼來(lái)打開(kāi)一個(gè)網(wǎng)絡(luò)設(shè)備:

package main

import (
	"fmt"
	"log"
	"net"

	"github.com/google/gopacket/pcap"
)

func main() {
	device := "eth0" // 要打開(kāi)的網(wǎng)絡(luò)設(shè)備名稱

	handle, err := pcap.OpenLive(device, 65536, true, pcap.BlockForever)
	if err != nil {
		log.Fatal(err)
	}
	defer handle.Close()

	fmt.Println("Device opened:", device)
}

在上述代碼中,我們使用pcap.OpenLive函數(shù)來(lái)打開(kāi)一個(gè)網(wǎng)絡(luò)設(shè)備。該函數(shù)接受設(shè)備名稱、數(shù)據(jù)包最大長(zhǎng)度、是否要抓取數(shù)據(jù)包的全部?jī)?nèi)容以及超時(shí)時(shí)間作為參數(shù)。如果打開(kāi)成功,將返回一個(gè)pcap.Handle對(duì)象,可以用于后續(xù)的數(shù)據(jù)包捕獲和分析。

捕獲數(shù)據(jù)包

在打開(kāi)網(wǎng)絡(luò)設(shè)備之后,我們可以開(kāi)始捕獲數(shù)據(jù)包??梢酝ㄟ^(guò)以下代碼來(lái)捕獲指定數(shù)量的數(shù)據(jù)包:

package main

import (
	"fmt"
	"log"
	"net"
	"time"

	"github.com/google/gopacket/pcap"
)

func main() {
	device, err := pcap.FindAllDevs()
	if err != nil {
		log.Fatal(err)
	}

	handle, err := pcap.OpenLive(device[0].Name, 65536, true, pcap.BlockForever)
	if err != nil {
		log.Fatal(err)
	}
	defer handle.Close()

	packetCount := 0
	packetSource := gopacket.NewPacketSource(handle, handle.LinkType())
	for packet := range packetSource.Packets() {
		packetCount++
		fmt.Println("Packet:", packetCount)

		// TODO: 進(jìn)行數(shù)據(jù)包分析
		time.Sleep(1 * time.Second) // 僅用于示例,避免數(shù)據(jù)包流量過(guò)大
	}
}

上述代碼中,我們使用gopacket.NewPacketSource函數(shù)將打開(kāi)的設(shè)備與pcap.Handle對(duì)象關(guān)聯(lián)起來(lái),然后使用PacketSource的Packets方法來(lái)獲取捕獲到的數(shù)據(jù)包。每次從Packets方法獲取到一個(gè)數(shù)據(jù)包,我們都會(huì)對(duì)其進(jìn)行處理,即打印出數(shù)據(jù)包的序號(hào)(用于示例,實(shí)際應(yīng)用中可能需要根據(jù)需求進(jìn)行其他操作)。

數(shù)據(jù)包分析

在捕獲到數(shù)據(jù)包后,我們可以對(duì)其進(jìn)行分析并提取所需的信息。gopacket庫(kù)提供了豐富的工具和功能,用于數(shù)據(jù)包分析。

以下是一些常見(jiàn)的數(shù)據(jù)包分析方法:

解析以太網(wǎng)幀

ethernetLayer := packet.Layer(layers.LayerTypeEthernet)
if ethernetLayer != nil {
    ethernetPacket, _ := ethernetLayer.(*layers.Ethernet)
    fmt.Println("Ethernet source MAC:", ethernetPacket.SrcMAC)
    fmt.Println("Ethernet destination MAC:", ethernetPacket.DstMAC)
    fmt.Println("Ethernet type:", ethernetPacket.EthernetType)
}

以上代碼演示了如何解析以太網(wǎng)幀中的源MAC地址、目的MAC地址和以太網(wǎng)類型。

解析IP包

ipLayer := packet.Layer(layers.LayerTypeIPv4)
if ipLayer != nil {
    ipPacket, _ := ipLayer.(*layers.IPv4)
    fmt.Println("IP version:", ipPacket.Version)
    fmt.Println("IP source address:", ipPacket.SrcIP)
    fmt.Println("IP destination address:", ipPacket.DstIP)
    fmt.Println("IP protocol:", ipPacket.Protocol)
}

以上代碼演示了如何解析IPv4包中的版本、源IP地址、目的IP地址和協(xié)議。

解析TCP包

tcpLayer := packet.Layer(layers.LayerTypeTCP)
if tcpLayer != nil {
    tcpPacket, _ := tcpLayer.(*layers.TCP)
    fmt.Println("TCP source port:", tcpPacket.SrcPort)
    fmt.Println("TCP destination port:", tcpPacket.DstPort)
    fmt.Println("TCP sequence number:", tcpPacket.Sequence)
    fmt.Println("TCP acknowledgment number:", tcpPacket.Acknowledgment)
    fmt.Println("TCP flags:", tcpPacket.Flags)
}

以上代碼演示了如何解析TCP包中的源端口、目的端口、序列號(hào)、確認(rèn)號(hào)和標(biāo)志位。

解析UDP包

udpLayer := packet.Layer(layers.LayerTypeUDP)
if udpLayer != nil {
    udpPacket, _ := udpLayer.(*layers.UDP)
    fmt.Println("UDP source port:", udpPacket.SrcPort)
    fmt.Println("UDP destination port:", udpPacket.DstPort)
}

以上代碼演示了如何解析UDP包中的源端口和目的端口。

解析應(yīng)用層協(xié)議

在數(shù)據(jù)包的應(yīng)用層有各種各樣的協(xié)議,如HTTP、DNS等。gopacket庫(kù)提供了根據(jù)協(xié)議類型解析數(shù)據(jù)包的方法。以下是解析HTTP協(xié)議的示例代碼:

httpLayer := packet.Layer(layers.LayerTypeHTTP)
if httpLayer != nil {
    httpPacket, _ := httpLayer.(*layers.HTTP)
    fmt.Println("HTTP method:", httpPacket.Method)
    fmt.Println("HTTP host:", httpPacket.Host)
    fmt.Println("HTTP user-agent:", httpPacket.UserAgent)
}

以上代碼演示了如何解析HTTP包中的方法、主機(jī)和用戶代理信息。

示例:捕獲HTTP請(qǐng)求

現(xiàn)在,我們將結(jié)合以上的知識(shí)來(lái)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的示例:捕獲HTTP請(qǐng)求,并提取請(qǐng)求的URL和請(qǐng)求頭信息。

package main

import (
	"fmt"
	"log"
	"net"
	"strings"
	"time"

	"github.com/google/gopacket"
	"github.com/google/gopacket/pcap"
	"github.com/google/gopacket/layers"
)

func main() {
	device, err := pcap.FindAllDevs()
	if err != nil {
		log.Fatal(err)
	}

	handle, err := pcap.OpenLive(device[0].Name, 65536, true, pcap.BlockForever)
	if err != nil {
		log.Fatal(err)
	}
	defer handle.Close()

	packetSource := gopacket.NewPacketSource(handle, handle.LinkType())
	for packet := range packetSource.Packets() {
		ethernetLayer := packet.Layer(layers.LayerTypeEthernet)
		if ethernetLayer != nil {
			ethernetPacket, _ := ethernetLayer.(*layers.Ethernet)

			ipLayer := packet.Layer(layers.LayerTypeIPv4)
			if ipLayer != nil {
				ipPacket, _ := ipLayer.(*layers.IPv4)

				tcpLayer := packet.Layer(layers.LayerTypeTCP)
				if tcpLayer != nil {
					tcpPacket, _ := tcpLayer.(*layers.TCP)

					httpLayer := packet.Layer(layers.LayerTypeHTTP)
					if httpLayer != nil {
						httpPacket, _ := httpLayer.(*layers.HTTP)

						fmt.Println("Source MAC:", ethernetPacket.SrcMAC)
						fmt.Println("Destination MAC:", ethernetPacket.DstMAC)

						fmt.Println("Source IP:", ipPacket.SrcIP)
						fmt.Println("Destination IP:", ipPacket.DstIP)

						fmt.Println("Source Port:", tcpPacket.SrcPort)
						fmt.Println("Destination Port:", tcpPacket.DstPort)

						fmt.Println("HTTP Method:", httpPacket.Method)
						fmt.Println("HTTP Host:", httpPacket.Host)

						headers := strings.Split(string(httpPacket.Headers), "\r\n")
						for _, header := range headers {
							fmt.Println("HTTP Header:", header)
						}
						
						fmt.Println("--------")
					}
				}
			}
		}

		time.Sleep(1 * time.Second) // 僅用于示例,避免數(shù)據(jù)包流量過(guò)大
	}
}

以上示例代碼中,我們使用了嵌套的條件語(yǔ)句來(lái)逐級(jí)解析數(shù)據(jù)包的各個(gè)層級(jí),并提取所需的信息。其中,我們關(guān)注以太網(wǎng)幀、IPv4包、TCP包和HTTP協(xié)議,提取了包括源MAC地址、目的MAC地址、源IP地址、目的IP地址、源端口、目的端口、HTTP方法、主機(jī)和請(qǐng)求頭信息等。

案例

案例一:統(tǒng)計(jì)流量

我們可以使用抓包技術(shù)來(lái)統(tǒng)計(jì)特定端口的流量。以下示例代碼演示了如何捕獲HTTP流量,并統(tǒng)計(jì)總共傳輸?shù)臄?shù)據(jù)量:

package main

import (
	"fmt"
	"log"
	"net"
	"strings"
	"time"

	"github.com/google/gopacket"
	"github.com/google/gopacket/pcap"
	"github.com/google/gopacket/layers"
)

func main() {
	device, err := pcap.FindAllDevs()
	if err != nil {
		log.Fatal(err)
	}

	handle, err := pcap.OpenLive(device[0].Name, 65536, true, pcap.BlockForever)
	if err != nil {
		log.Fatal(err)
	}
	defer handle.Close()

	packetSource := gopacket.NewPacketSource(handle, handle.LinkType())
	totalBytes := 0
	startTime := time.Now()
	for packet := range packetSource.Packets() {
		ethernetLayer := packet.Layer(layers.LayerTypeEthernet)
		if ethernetLayer != nil {
			ethernetPacket, _ := ethernetLayer.(*layers.Ethernet)

			ipLayer := packet.Layer(layers.LayerTypeIPv4)
			if ipLayer != nil {
				ipPacket, _ := ipLayer.(*layers.IPv4)

				tcpLayer := packet.Layer(layers.LayerTypeTCP)
				if tcpLayer != nil {
					tcpPacket, _ := tcpLayer.(*layers.TCP)

					httpLayer := packet.Layer(layers.LayerTypeHTTP)
					if httpLayer != nil {
						httpPacket, _ := httpLayer.(*layers.HTTP)

						if tcpPacket.SrcPort.String() == "80" || tcpPacket.DstPort.String() == "80" {
							totalBytes += len(packet.Data())
						}
					}
				}
			}
		}

		elapsed := time.Since(startTime)
		if elapsed.Seconds() >= 10 {
			fmt.Printf("Total Bytes: %d\n", totalBytes)
			break
		}
	}
}

上述代碼中,我們?cè)跀?shù)據(jù)包捕獲的過(guò)程中判斷源端口或目標(biāo)端口是否為80(HTTP默認(rèn)端口),如果是則統(tǒng)計(jì)這些HTTP流量的數(shù)據(jù)量。我們使用一個(gè)計(jì)時(shí)器來(lái)控制統(tǒng)計(jì)的時(shí)間,示例中設(shè)置為10秒。隨著流量的捕獲,我們將統(tǒng)計(jì)的總數(shù)據(jù)量打印出來(lái)。

案例二:HTTP請(qǐng)求重放

我們可以抓取HTTP請(qǐng)求,并將其重放到目標(biāo)服務(wù)器。以下示例代碼演示了如何捕獲HTTP請(qǐng)求,并將其重放到指定的目標(biāo)服務(wù)器:

package main

import (
	"log"
	"net/http"
	"strings"

	"github.com/google/gopacket"
	"github.com/google/gopacket/pcap"
	"github.com/google/gopacket/layers"
)

func main() {
	device, err := pcap.FindAllDevs()
	if err != nil {
		log.Fatal(err)
	}

	handle, err := pcap.OpenLive(device[0].Name, 65536, true, pcap.BlockForever)
	if err != nil {
		log.Fatal(err)
	}
	defer handle.Close()

	packetSource := gopacket.NewPacketSource(handle, handle.LinkType())
	for packet := range packetSource.Packets() {
		ethernetLayer := packet.Layer(layers.LayerTypeEthernet)
		if ethernetLayer != nil {
			ethernetPacket, _ := ethernetLayer.(*layers.Ethernet)

			ipLayer := packet.Layer(layers.LayerTypeIPv4)
			if ipLayer != nil {
				ipPacket, _ := ipLayer.(*layers.IPv4)

				tcpLayer := packet.Layer(layers.LayerTypeTCP)
				if tcpLayer != nil {
					tcpPacket, _ := tcpLayer.(*layers.TCP)

					httpLayer := packet.Layer(layers.LayerTypeHTTP)
					if httpLayer != nil {
						httpPacket, _ := httpLayer.(*layers.HTTP)

						if tcpPacket.SrcPort.String() == "80" || tcpPacket.DstPort.String() == "80" {
							method := httpPacket.Method
							url := "http://" + string(ipPacket.DstIP) + string(httpPacket.URL)
							headers := make(http.Header)
							for _, header := range strings.Split(string(httpPacket.Headers), "\r\n") {
								parts := strings.SplitN(header, ":", 2)
								if len(parts) == 2 {
									headers.Add(strings.TrimSpace(parts[0]), strings.TrimSpace(parts[1]))
								}
							}

							client := &http.Client{}
							req, err := http.NewRequest(method, url, nil)
							if err != nil {
								log.Fatal(err)
							}
							req.Header = headers

							resp, err := client.Do(req)
							if err != nil {
								log.Fatal(err)
							}

							log.Println("Response:", resp)
						}
					}
				}
			}
		}
	}
}

上述代碼中,我們?cè)谧ト〉紿TTP請(qǐng)求后,構(gòu)造一個(gè)新的HTTP請(qǐng)求,其中包括方法、URL、請(qǐng)求頭等信息。然后,我們使用http.Client發(fā)送這個(gè)新的HTTP請(qǐng)求,并打印出服務(wù)器的響應(yīng)。通過(guò)這種方式,我們可以捕獲并重放HTTP請(qǐng)求。

案例三:網(wǎng)絡(luò)嗅探器

我們可以使用抓包技術(shù)來(lái)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的網(wǎng)絡(luò)嗅探器,監(jiān)控網(wǎng)絡(luò)通信并輸出相關(guān)信息。以下示例代碼演示了如何實(shí)現(xiàn)一個(gè)簡(jiǎn)單的網(wǎng)絡(luò)嗅探器:

package main

import (
	"fmt"
	"log"
	"net"

	"github.com/google/gopacket"
	"github.com/google/gopacket/pcap"
	"github.com/google/gopacket/layers"
)

func main() {
	device, err := pcap.FindAllDevs()
	if err != nil {
		log.Fatal(err)
	}

	handle, err := pcap.OpenLive(device[0].Name, 65536, true, pcap.BlockForever)
	if err != nil {
		log.Fatal(err)
	}
	defer handle.Close()

	packetSource := gopacket.NewPacketSource(handle, handle.LinkType())
	for packet := range packetSource.Packets() {
		ethernetLayer := packet.Layer(layers.LayerTypeEthernet)
		if ethernetLayer != nil {
			ethernetPacket, _ := ethernetLayer.(*layers.Ethernet)

			ipLayer := packet.Layer(layers.LayerTypeIPv4)
			if ipLayer != nil {
				ipPacket, _ := ipLayer.(*layers.IPv4)

				fmt.Println("Source IP:", ipPacket.SrcIP)
				fmt.Println("Destination IP:", ipPacket.DstIP)

				tcpLayer := packet.Layer(layers.LayerTypeTCP)
				if tcpLayer != nil {
					tcpPacket, _ := tcpLayer.(*layers.TCP)

					fmt.Println("Source Port:", tcpPacket.SrcPort)
					fmt.Println("Destination Port:", tcpPacket.DstPort)

					fmt.Println("Payload:", string(tcpPacket.Payload))
				}

				udpLayer := packet.Layer(layers.LayerTypeUDP)
				if udpLayer != nil {
					udpPacket, _ := udpLayer.(*layers.UDP)

					fmt.Println("Source Port:", udpPacket.SrcPort)
					fmt.Println("Destination Port:", udpPacket.DstPort)

					fmt.Println("Payload:", string(udpPacket.Payload))
				}
			}
		}
	}
}

上述代碼中,我們?cè)跀?shù)據(jù)包捕獲的過(guò)程中,獲取到IP層和TCP/UDP層的信息,并將其打印出來(lái)。通過(guò)此網(wǎng)絡(luò)嗅探器,我們可以實(shí)時(shí)監(jiān)控網(wǎng)絡(luò)通信,并輸出重要的數(shù)據(jù)包信息。

總結(jié)

通過(guò)使用gopacket庫(kù),我們可以輕松地實(shí)現(xiàn)網(wǎng)絡(luò)數(shù)據(jù)包的抓取和分析。本文介紹了使用Golang實(shí)現(xiàn)抓包功能的基本步驟,包括打開(kāi)網(wǎng)絡(luò)設(shè)備、捕獲數(shù)據(jù)包和數(shù)據(jù)包分析等。我們還提供了一些常用的數(shù)據(jù)包分析方法的示例代碼,以幫助讀者更好地理解數(shù)據(jù)包的解析過(guò)程。

抓包是網(wǎng)絡(luò)安全、網(wǎng)絡(luò)性能優(yōu)化、網(wǎng)絡(luò)協(xié)議分析等領(lǐng)域的重要工具,掌握抓包技術(shù)不僅可以幫助我們更好地理解網(wǎng)絡(luò)通信過(guò)程,還可以幫助我們發(fā)現(xiàn)網(wǎng)絡(luò)中的問(wèn)題和潛在威脅。通過(guò)使用Golang實(shí)現(xiàn)抓包功能,我們可以利用Golang的優(yōu)勢(shì),如高效性能、并發(fā)性和豐富的庫(kù)支持,來(lái)實(shí)現(xiàn)更靈活、高效的網(wǎng)絡(luò)數(shù)據(jù)包捕獲與分析。

以上就是使用Golang實(shí)現(xiàn)網(wǎng)絡(luò)數(shù)據(jù)包捕獲與分析的詳細(xì)內(nèi)容,更多關(guān)于Golang數(shù)據(jù)包捕獲與分析的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Golang學(xué)習(xí)筆記(六):struct

    Golang學(xué)習(xí)筆記(六):struct

    這篇文章主要介紹了Golang學(xué)習(xí)筆記(六):struct,本文講解了struct的聲明及初始化、struct的匿名字段(繼承)、method、method繼承和重寫等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • 入門學(xué)習(xí)Go的基本語(yǔ)法

    入門學(xué)習(xí)Go的基本語(yǔ)法

    這篇文章主要介紹了Go語(yǔ)法的基本概念,本文講解了Golang的基本知識(shí)、基礎(chǔ)語(yǔ)法、相關(guān)術(shù)語(yǔ)等,需要的朋友可以參考下,希望能幫助到你
    2021-07-07
  • golang post請(qǐng)求常用的幾種方式小結(jié)

    golang post請(qǐng)求常用的幾種方式小結(jié)

    這篇文章主要介紹了golang post請(qǐng)求常用的幾種方式小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04
  • Go疑難雜癥講解之為什么nil不等于nil

    Go疑難雜癥講解之為什么nil不等于nil

    在日常開(kāi)發(fā)中,可能一不小心就會(huì)掉進(jìn)?Go?語(yǔ)言的某些陷阱里,而本文要介紹的?nil?≠?nil?問(wèn)題,感興趣的小伙伴可以跟隨小編一起了解一下
    2022-10-10
  • Go語(yǔ)言中的定時(shí)器原理與實(shí)戰(zhàn)應(yīng)用

    Go語(yǔ)言中的定時(shí)器原理與實(shí)戰(zhàn)應(yīng)用

    在Go語(yǔ)言中,Timer和Ticker是處理定時(shí)任務(wù)的重要工具,Timer用于一次性事件,而Ticker則用于周期性事件,本文詳細(xì)介紹了這兩種定時(shí)器的創(chuàng)建、使用和停止方法,并通過(guò)實(shí)際案例展示了它們?cè)诒O(jiān)控日志、檢查系統(tǒng)狀態(tài)等方面的應(yīng)用
    2024-10-10
  • go語(yǔ)言變量定義用法實(shí)例

    go語(yǔ)言變量定義用法實(shí)例

    這篇文章主要介紹了go語(yǔ)言變量定義用法,實(shí)例分析了go語(yǔ)言變量的定義及使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • GO的range具體使用

    GO的range具體使用

    GO語(yǔ)言的for…range 能做什么呢?golang的for…range是go 身的語(yǔ)法,可以用來(lái)遍歷數(shù)據(jù)結(jié)構(gòu),本文就詳細(xì)的來(lái)介紹一下具體使用,感興趣的可以了解一下
    2021-10-10
  • golang switch語(yǔ)句的靈活寫法介紹

    golang switch語(yǔ)句的靈活寫法介紹

    這篇文章主要介紹了golang switch語(yǔ)句的靈活寫法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-05-05
  • Go語(yǔ)言切片前或中間插入項(xiàng)與內(nèi)置copy()函數(shù)詳解

    Go語(yǔ)言切片前或中間插入項(xiàng)與內(nèi)置copy()函數(shù)詳解

    這篇文章主要介紹了Go語(yǔ)言切片前或中間插入項(xiàng)與內(nèi)置copy()函數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04
  • Go?語(yǔ)言中運(yùn)行?C程序?代碼?

    Go?語(yǔ)言中運(yùn)行?C程序?代碼?

    這篇文章主要介紹了Go?語(yǔ)言中運(yùn)行?C程序代碼,通過(guò)直接在?Go?代碼中寫入?C?程序運(yùn)行,下面操作過(guò)程需要的小伙伴可以參考一下
    2022-03-03

最新評(píng)論