鱼C论坛

 找回密码
 立即注册
查看: 1619|回复: 7

[已解决]c++如何加入循环语句

[复制链接]
发表于 2017-5-7 10:44:52 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
代码如下,对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[1024];
  
void printHash(unsigned char *md, int len)  
                {  
        int i = 0;  
        for (i = 0; i < len; i++)  
                {  
            printf("%02x", md[i]);
                        sprintf(Buffer,"%02x",md[i]);
                        FileOpen.write(Buffer,strlen(Buffer));

                }  
  
         printf("\n");  
                }
void myHash224()  
                {  
            SHA256_CTX c;  
            unsigned char md[SHA224_DIGEST_LENGTH];  
            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;  
}  
最佳答案
2017-5-7 11:19:32
 for (h=0.001;h<0.601;)
        {
                FileOpen.open("fuck.txt");
                *orgStr = h;
                h += 0.001
        }
改成这样应该可以,因为h+0.001实际没有改变了h的值,所以计算的时候还是计算0.001的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-5-7 11:19:32 | 显示全部楼层    本楼为最佳答案   
 for (h=0.001;h<0.601;)
        {
                FileOpen.open("fuck.txt");
                *orgStr = h;
                h += 0.001
        }
改成这样应该可以,因为h+0.001实际没有改变了h的值,所以计算的时候还是计算0.001的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-5-7 11:54:45 | 显示全部楼层
lumber2388779 发表于 2017-5-7 11:19
改成这样应该可以,因为h+0.001实际没有改变了h的值,所以计算的时候还是计算0.001的

改好了,运行还是报错,只能输出初值的加密结果,并不能进行for循环,是不是指针赋值那里出现问题了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-5-7 11:56:27 | 显示全部楼层
lumber2388779 发表于 2017-5-7 11:19
改成这样应该可以,因为h+0.001实际没有改变了h的值,所以计算的时候还是计算0.001的

我试着把for循环里面的*orgStr=h删掉了,然后运行就是无限循环,出不来了。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-7 12:02:26 | 显示全部楼层
江南听雨 发表于 2017-5-7 11:56
我试着把for循环里面的*orgStr=h删掉了,然后运行就是无限循环,出不来了。。

等下吧 我在安装SSL环境先
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-5-7 12:09:05 | 显示全部楼层
lumber2388779 发表于 2017-5-7 12:02
等下吧 我在安装SSL环境先

好的~谢谢兄弟,加个qq吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-7 12:27:04 | 显示全部楼层
江南听雨 发表于 2017-5-7 12:09
好的~谢谢兄弟,加个qq吧

253276214
把你的发我吧.这边环境太多东西了烦- -
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-7 12:44:30 | 显示全部楼层
本帖最后由 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[10] = "0.001"; //待哈希的串  
ofstream FileOpen;
char Buffer[1024];
  
void printHash(unsigned char *md, int len)  
{  
        int i = 0;  
        for (i = 0; i < len; i++)  
        {  
                printf("%02x\t", md[i]);
                sprintf(Buffer,"%02x",md[i]);
                FileOpen.write(Buffer,strlen(Buffer));
        }  
  
        printf("\n");  
                } 
void myHash224()  
{  
        SHA256_CTX c;
        unsigned char md[SHA224_DIGEST_LENGTH];
        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;  
}  
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-28 05:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表