Advertisement
Guest User

Untitled

a guest
Apr 5th, 2020
159
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.50 KB | None | 0 0
  1. #include <iostream>
  2. #include <fstream>
  3. #include <vector>
  4. #include <thread>
  5. #include <string>
  6.  
  7. using namespace std;
  8.  
  9. vector<unsigned char> vektor_obrade;
  10.  
  11. void pisi(int br_blokova, int offset,char* ulazniFajl, char* kljuc)
  12. {
  13.  
  14.     char* buffer = new char[256];
  15.     char* kljuc_za_xor = new char[256];
  16.     char* rez = new char[256];
  17.  
  18.  
  19.     ifstream file;                                  //otvaranje fajla koji se obradjuje
  20.     file.open(ulazniFajl, ios::binary | ios::in);
  21.     file.seekg(offset);
  22.  
  23.     ifstream key_file;                              //otvaranje fajla u kom je kljuc za obradu prvog fajla
  24.     key_file.open(kljuc, ios::binary|ios::in);
  25.  
  26.     if(!file.is_open() || !key_file.is_open())
  27.     {
  28.         cout<<"Greska pri otvaranju nekog od fajlova."<<endl;
  29.     }
  30.  
  31.  
  32.     for(int i = 0; i < br_blokova && !file.eof(); i++)
  33.     {
  34.         file.read(buffer,256);
  35.         key_file.read(kljuc_za_xor, 256);
  36.  
  37.  
  38.         for(int j = 0; j <= 255; j++)
  39.         {                                                  
  40.  
  41.             vektor_obrade[offset+j+i] = buffer[j] ^ kljuc_za_xor[j];
  42.             //    rez[i] = buffer[i] + 1;
  43.         }
  44.  
  45.     }
  46.  
  47. }
  48.  
  49. void napravi_fajl(char* ulazniFajl, char* izlazni, char* kljuc, int br_niti){
  50.  
  51.     int br_koraka;
  52.     vector<thread> niti;
  53.  
  54.     ifstream file;                                                   // otvaranje fajla koji se obradjuje
  55.     file.open(ulazniFajl, ios::binary | ios::in | ios::ate);        //  otvori fajl i pici odmah na kraj da znam koji mi je offset/vel fajla
  56.     vektor_obrade.resize(file.tellg());                            //   uzmi velicinu fajla
  57.  
  58.     int velicina_fajla = file.tellg();
  59.     cout << "velicina fajla: " << velicina_fajla << endl;
  60.     br_koraka = file.tellg()/(br_niti*256);                         // broj blokova koji ce svaka nit da izvrsi
  61.  
  62.     file.close();
  63.      for(int i = 0; i < br_niti; i++){
  64.         cout << "kreiram nit: " << i << endl;
  65.         niti.push_back(thread(pisi,br_koraka,br_koraka*i*256,ulazniFajl, izlazni, kljuc));              //offset - odakle krece svaka od niti
  66.  
  67.     }
  68.  
  69.     for(auto it = niti.begin(); it != niti.end(); it++){
  70.  
  71.         it->join();
  72.  
  73.     }
  74.  
  75. }
  76.  
  77.  
  78. int main(int argc, char* argv[])
  79. {
  80.     char* ulazniFajl = argv[1];
  81.     char* kljuc      = argv[2];
  82.     char* izlazni    = argv[3];
  83.     int br_niti      = atoi(argv[4]);
  84.  
  85.     vector<thread> niti;
  86.  
  87.     napravi_fajl(ulazniFajl, izlazni, kljuc,br_niti);
  88.  
  89.    // int br_koraka = velicina/br_niti;
  90.  
  91.     return 0;
  92. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement