登录
首页 >  Golang >  Go问答

为何这个脚本无法在命令提示符下运行?

来源:stackoverflow

时间:2024-02-23 15:09:18 394浏览 收藏

大家好,今天本人给大家带来文章《为何这个脚本无法在命令提示符下运行?》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

我有以下脚本,它生成随机序列并在 cpu 上使用 go 中的多个线程对它们进行哈希处理。

package main

import(
    "fmt"
    "crypto/sha256"
    "encoding/hex"
    "math/rand"
    "time"
    "log"
    "os"
)

func randChr(i int)(string){
    i = i + 65
    if i>90 {
        i = i - 43
    }
    return string(i)
}

func randStr(random *rand.Rand, length int)(string){
    result := ""
    for len(result)<length{
        result = result + randChr(random.Intn(36))
    }
    return result
}

func HashPass(data []byte) (bool,[32]byte){
    hash := sha256.Sum256(data)
    s := hex.EncodeToString(hash[:])
    pass := true
    for i := 0; i<7; i++ {
        if s[i] != s[i+1]{
            pass = false
            break;
        }
    }
    return pass,hash
}


func getAPassingHash()(string){
    randSource := rand.NewSource(time.Now().UnixNano())
    random := rand.New(randSource)
    passes := false
    s := ""
    for !passes {
        s=randStr(random,64)
        passes,_ =  HashPass([]byte(s))
    }
    return(s)
}

func worker(ch chan string){
    ch <- getAPassingHash()
}

func timer(ch chan string,wait time.Duration){
    time.Sleep(wait)
    ch <- "End"
}

func append(fn string,conts string){
    f, err := os.OpenFile(fn,
        os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
    if err != nil {
        log.Println(err)
    }
    defer f.Close()
    if _, err := f.WriteString(conts); err != nil {
        log.Println(err)
    }
}

func main(){
    ch := make(chan string)
    go timer(ch,6*time.Hour)
    for i:=0;i<9;i++{
        time.Sleep(time.Second)
        go worker(ch)
    }
    for true{
        result := <-ch
        if result == "End"{
            break;
        }
        go worker(ch)
        fmt.Println(result)
        hash := sha256.Sum256([]byte(result))
        fmt.Println(hex.EncodeToString(hash[:]))
        fmt.Println()
        append("hashes.txt","\n"+result+"\n"+hex.EncodeToString(hash[:])+"\n")
    }
    fmt.Println("done")
}

由于某种原因,脚本偶尔会挂起,直到我单击命令提示符并按 enter 键。我不确定它卡在哪里,但我可以看到我的系统 cpu 利用率下降了,而且我知道我的结果以某种方式阻止了程序,我按 enter 键并打印结果,cpu 使用率又回升。我知道这可能很难复制,但我真的很感激任何建议。


正确答案


它不会挂起,它会等待 passes 的值为 true

func getAPassingHash()(string){
    randSource := rand.NewSource(time.Now().UnixNano())
    random := rand.New(randSource)
    passes := false
    s := ""
    for !passes { // wait for value is true
        s=randStr(random,64)
        passes,_ =  HashPass([]byte(s))
    }
    return(s)
}

好了,本文到此结束,带大家了解了《为何这个脚本无法在命令提示符下运行?》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>