c++ - 更改为 C++ 时卡在 while 循环中

标签 c++ performance cryptography

我正在尝试用 C++ 重写这段代码,它创建了一个比特币迷你私钥

using System;
using System.Text;
using Org.BouncyCastle.Security;


 public string CreateRandomMinikey(){
        string keytotry = "S6c56bnXQiBjk9mqSYE7ykVQ7NzrQA";
        char[] chars = keytotry.ToCharArray();
        char[] charstest = (keytotry + "?").ToCharArray();            
        while (Util.ComputeSha256(utf8.GetBytes(charstest))[0] != 0) {// hash sha256 the key & check if the first character was '0'
                // As long as key doesn't pass typo check, increment it.
                for (int i = chars.Length - 1; i >= 0; i--) {
                    char c = chars[i];
                    if (c == '9') {
                        charstest[i] = chars[i] = 'A';                        
                        break;
                    } else if (c == 'H') {
                        charstest[i] = chars[i] = 'J';
                        break;
                    } else if (c == 'N') {
                        charstest[i] = chars[i] = 'P';
                        break;
                    } else if (c == 'Z') {
                        charstest[i] = chars[i] = 'a';
                        break;
                    } else if (c == 'k') {
                        charstest[i] = chars[i] = 'm';
                        break;
                    } else if (c == 'z') {
                        charstest[i] = chars[i] = '2';
                        // No break - let loop increment prior character.
                    } else {
                        charstest[i] = chars[i] = ++c;
                        break;
                    }
                }
            }
            string result  = new string(chars);//expect S6c56bnXQiBjk9mqSYE7ykVQ7NzrRy
            return result;
        }

这是我转换成c++的代码

#include "stdafx.h"
#include <string.h>
#include <iostream>
#include <cstring>
#include "sha256.h"

using namespace std;

int main()
{   
    string input = "S6c56bnXQiBjk9mqSYE7ykVQ7NzrQA";
    string inputcharstest = input+"?";
    char * chars = new char[input.size() + 1];
    strcpy(chars, input.c_str());//convert input to char array
    char * charstest = new char[inputcharstest.size() + 1];
    strcpy(charstest, inputcharstest.c_str());// convert inputcharstest to char array
    string output = sha256(inputcharstest); //hash sha256 inputcharstest to check typo
    while (output[0] != '0') {
        for (int i = strlen(chars) - 1; i >= 0; i--) {
            char c = chars[i];
            if (c == '9') {
                charstest[i] = chars[i] = 'A';
                break;
            }
            else if (c == 'H') {
                charstest[i] = chars[i] = 'J';
                break;
            }
            else if (c == 'N') {
                charstest[i] = chars[i] = 'P';
                break;
            }
            else if (c == 'Z') {
                charstest[i] = chars[i] = 'a';
                break;
            }
            else if (c == 'k') {
                charstest[i] = chars[i] = 'm';
                break;
            }
            else if (c == 'z') {
                charstest[i] = chars[i] = '2';              
            }
            else {
                charstest[i] = chars[i] = ++c;
                break;
            }
        }
    }
    string result = string(chars); //expect S6c56bnXQiBjk9mqSYE7ykVQ7NzrRy
        cout << "input('" << input << "'):" << result << endl;

    return 0;
}

enter image description here

这是我期望的结果 enter image description here

当我在控制台应用程序上运行时代码被卡住并返回空白,我调试并发现它永远卡在 while 循环中。请问这是否有任何问题,我该如何解决?

最佳答案

在这里你每次都改变字符串的内容:

 char[] charstest = (keytotry + "?").ToCharArray();            
    while (Util.ComputeSha256(utf8.GetBytes(charstest))[0] != 0) {

charstest 在每次循环运行时都会发生变化,因此 while 中的测试可以在某个时刻终止。然而,在 C++ 代码中,您并没有这样做:

string output = sha256(inputcharstest); //hash sha256 inputcharstest to check typo
while (output[0] != '0') {

在这里,您只在循环之前执行一次哈希,然后在循环中不再执行。循环根本不会改变 output,也不会从 whilebreak,所以如果 output[0] ! = '0' 第一次为 true,它将始终为 true,因此无限循环。

关于c++ - 更改为 C++ 时卡在 while 循环中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53442292/

相关文章:

android - 如何为 android native 应用程序生成调试符号?

c++ - 使用鼠标拖动旋转 QLabel

performance - R 中的高性能大数据处理

performance - 编译 F# 引用 : performance?

python - 从Python中的字符串解析RSA key 对

c++ - srand (time (null)) 导致编译器警告 : implicit conversion loses integer precision

c++ - 为什么我的makefile文件返回错误193?

c++ - unordered_map 在实践中真的比 map 快吗?

c - 反转 AND 按位

C# MD5 哈希结果不是预期的结果