IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> golang-ip寻址面试题 -> 正文阅读

[网络协议]golang-ip寻址面试题

给你一个500行的文件,已知文件为有序ip段+地址,内如格式如下:
127.1.0.0 127.1.0.255 地址1
127.1.1.0 127.1.1.255 地址2
127.1.2.0 127.1.2.255 地址3
127.1.3.0 127.1.3.255 地址4
127.1.4.0 127.1.4.255 地址5

写一个算法,传入ip地址,获取到地址详情。
以下代码为本人撸出来的,大家给意见吧

package main

import (
    "os"
    "bufio"
    "io"
    "fmt"
    "strings"
    "strconv"
)

type ip struct {
    start int
    end int
    ipStart string
    ipEnd string
    address string
}

var data []ip

func main()  {
    data = make([]ip, 0)
    data = fGet("./ip.txt")
    fmt.Println(searchs("127.1.3.8"))
}

func fGet(file string) []ip {
    ipStruct := ip{
        start:   0,
        end:     0,
        ipStart: "",
        ipEnd: "",
        address: "",
    }
    ipSlice := []ip{}

    fileSource, err := os.Open(file)
    if err != nil {
        panic("文件不可用")
    }
    fread := bufio.NewReader(fileSource)
    for {
        line, _, err := fread.ReadLine()
        if err == io.EOF {
            break
        }
        lines := strings.Split(string(line), " ")
        ipStruct.start = stringIpToInt(lines[0])
        ipStruct.end = stringIpToInt(lines[1])
        ipStruct.ipStart = lines[0]
        ipStruct.ipEnd = lines[1]
        ipStruct.address = lines[2]
        ipSlice = append(ipSlice, ipStruct)
    }

    return ipSlice
}

func stringIpToInt(ipstring string) int {
    ipSegs := strings.Split(ipstring, ".")
    var ipInt int = 0
    var pos uint = 24
    for _, ipSeg := range ipSegs {
        tempInt, _ := strconv.Atoi(ipSeg)
        tempInt = tempInt << pos
        ipInt = ipInt | tempInt
        pos -= 8
    }
    return ipInt
}

func searchs(ip string) string {
    ipInt := stringIpToInt(ip)
    start := 0
    end := len(data)-1
    index := 0
    address := ""
    for{
        if index == (start + end)/2 {
            break
        }
        index = (start + end)/2
        if data[index].start < ipInt && data[index].end > ipInt {
            address = data[index].address
            break
        } else if data[index].start > ipInt {
            end = index
            continue
        } else if data[index].end < ipInt {
            start = index
            continue
        }
    }
    return address
}

                
        
        
  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-11-24 08:19:34  更:2021-11-24 08:20:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 18:49:46-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码