鱼C论坛

 找回密码
 立即注册
查看: 1536|回复: 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
  1. for (h=0.001;h<0.601;)
  2.         {
  3.                 FileOpen.open("fuck.txt");
  4.                 *orgStr = h;
  5.                 h += 0.001
  6.         }
复制代码

改成这样应该可以,因为h+0.001实际没有改变了h的值,所以计算的时候还是计算0.001的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-5-7 11:19:32 | 显示全部楼层    本楼为最佳答案   
  1. for (h=0.001;h<0.601;)
  2.         {
  3.                 FileOpen.open("fuck.txt");
  4.                 *orgStr = h;
  5.                 h += 0.001
  6.         }
复制代码

改成这样应该可以,因为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 编辑
  1. #include <iostream>
  2. #include <fstream>
  3. #include <openssl/sha.h>   
  4. #include <openssl/crypto.h>  // OPENSSL_cleanse  
  5. #pragma comment(lib, "libeay32.lib")  
  6. #pragma comment(lib, "ssleay32.lib")  // 在本程序中, 可以注释掉这句  
  7. using namespace std;  
  8.   
  9. char orgStr[10] = "0.001"; //待哈希的串  
  10. ofstream FileOpen;
  11. char Buffer[1024];
  12.   
  13. void printHash(unsigned char *md, int len)  
  14. {  
  15.         int i = 0;  
  16.         for (i = 0; i < len; i++)  
  17.         {  
  18.                 printf("%02x\t", md[i]);
  19.                 sprintf(Buffer,"%02x",md[i]);
  20.                 FileOpen.write(Buffer,strlen(Buffer));
  21.         }  
  22.   
  23.         printf("\n");  
  24.                 }
  25. void myHash224()  
  26. {  
  27.         SHA256_CTX c;
  28.         unsigned char md[SHA224_DIGEST_LENGTH];
  29.         SHA224((unsigned char *)orgStr, strlen(orgStr), md);
  30.         printHash(md, SHA224_DIGEST_LENGTH);  
  31.   
  32.         SHA224_Init(&c);
  33.         SHA224_Update(&c, orgStr, strlen(orgStr));
  34.         SHA224_Final(md, &c);
  35.         OPENSSL_cleanse(&c, sizeof(c));
  36. }  
  37.   
  38. int main()  
  39. {
  40.         long double h = 0.001;
  41.    
  42.         for (h=0.001;h<0.601;h+0.001)
  43.         {
  44.                 FileOpen.open("fuck.txt");
  45.                 sprintf(orgStr,"%.3f",h);
  46.                 h += 0.001;
  47.                 myHash224();
  48.         }
  49.     return 0;  
  50. }  
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 04:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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