为什么这个脚本挂在命令提示符上?

发布于 2025-01-13 09:23:56 字数 2126 浏览 1 评论 0原文

我有以下脚本,它生成随机序列并在 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 使用率又回升。我知道这可能很难复制,但我真的很感激任何建议。

I have the following script that generates random sequences and hashes them on the cpu with several threads in 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")
}

For some reason the script hangs up occasionally until I click on the command prompt and hit enter. I'm not sure where it is getting stuck but I can see that my system CPU utilization goes down and I know I have results somehow blocking out the program, I hit enter and results print and cpu usage spikes back up. I know this might be hard to replicate but I would really appreciate any suggestions.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

孤独患者 2025-01-20 09:23:56

它不会挂起,而是等待 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)
}

It doesn't hang, it waits for the value of passes to be 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)
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文