c++如何加入循环语句
代码如下,对C++的循环语句不是很懂,是不是加错了,我想实现:对0.001-0.601的所有数字进行sha224哈希加密,下面的程序已经实现了0.01初值的加密,但是我不知道应该在哪里加入循环,在main函数里加循环好像没有用啊#include <iostream>
#include <fstream>
#include <openssl/sha.h>
#include <openssl/crypto.h>// OPENSSL_cleanse
#pragma comment(lib, "libeay32.lib")
#pragma comment(lib, "ssleay32.lib")// 在本程序中, 可以注释掉这句
using namespace std;
char *orgStr = "0.001"; //待哈希的串
ofstream FileOpen;
char Buffer;
void printHash(unsigned char *md, int len)
{
int i = 0;
for (i = 0; i < len; i++)
{
printf("%02x", md);
sprintf(Buffer,"%02x",md);
FileOpen.write(Buffer,strlen(Buffer));
}
printf("\n");
}
void myHash224()
{
SHA256_CTX c;
unsigned char md;
SHA224((unsigned char *)orgStr, strlen(orgStr), md);
printHash(md, SHA224_DIGEST_LENGTH);
SHA224_Init(&c);
SHA224_Update(&c, orgStr, strlen(orgStr));
SHA224_Final(md, &c);
OPENSSL_cleanse(&c, sizeof(c));
}
int main()
{
long double h = 0.001;
for (h=0.001;h<0.601;h+0.001)
{
FileOpen.open("fuck.txt");
*orgStr = h;
}
myHash224();
return 0;
} for (h=0.001;h<0.601;)
{
FileOpen.open("fuck.txt");
*orgStr = h;
h += 0.001
}
改成这样应该可以,因为h+0.001实际没有改变了h的值,所以计算的时候还是计算0.001的 lumber2388779 发表于 2017-5-7 11:19
改成这样应该可以,因为h+0.001实际没有改变了h的值,所以计算的时候还是计算0.001的
改好了,运行还是报错,只能输出初值的加密结果,并不能进行for循环,是不是指针赋值那里出现问题了 lumber2388779 发表于 2017-5-7 11:19
改成这样应该可以,因为h+0.001实际没有改变了h的值,所以计算的时候还是计算0.001的
我试着把for循环里面的*orgStr=h删掉了,然后运行就是无限循环,出不来了。。 江南听雨 发表于 2017-5-7 11:56
我试着把for循环里面的*orgStr=h删掉了,然后运行就是无限循环,出不来了。。
等下吧 我在安装SSL环境先 lumber2388779 发表于 2017-5-7 12:02
等下吧 我在安装SSL环境先
好的~谢谢兄弟,加个qq吧 江南听雨 发表于 2017-5-7 12:09
好的~谢谢兄弟,加个qq吧
253276214
把你的发我吧.这边环境太多东西了烦- - 本帖最后由 lumber2388779 于 2017-5-7 12:53 编辑
#include <iostream>
#include <fstream>
#include <openssl/sha.h>
#include <openssl/crypto.h>// OPENSSL_cleanse
#pragma comment(lib, "libeay32.lib")
#pragma comment(lib, "ssleay32.lib")// 在本程序中, 可以注释掉这句
using namespace std;
char orgStr = "0.001"; //待哈希的串
ofstream FileOpen;
char Buffer;
void printHash(unsigned char *md, int len)
{
int i = 0;
for (i = 0; i < len; i++)
{
printf("%02x\t", md);
sprintf(Buffer,"%02x",md);
FileOpen.write(Buffer,strlen(Buffer));
}
printf("\n");
}
void myHash224()
{
SHA256_CTX c;
unsigned char md;
SHA224((unsigned char *)orgStr, strlen(orgStr), md);
printHash(md, SHA224_DIGEST_LENGTH);
SHA224_Init(&c);
SHA224_Update(&c, orgStr, strlen(orgStr));
SHA224_Final(md, &c);
OPENSSL_cleanse(&c, sizeof(c));
}
int main()
{
long double h = 0.001;
for (h=0.001;h<0.601;h+0.001)
{
FileOpen.open("fuck.txt");
sprintf(orgStr,"%.3f",h);
h += 0.001;
myHash224();
}
return 0;
}
页:
[1]