abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×

dnes 20:55 | Komunita

Od 18. do 21. května proběhla v Saint-Étienne Linux Audio Conference 2017. Na programu byla řada zajímavých přednášek a seminářů. Videozáznamy přednášek lze zhlédnout na YouTube. K dispozici jsou také články a prezentace.

Ladislav Hagara | Komentářů: 0
dnes 20:44 | IT novinky

Hodnota Bitcoinu, decentralizované kryptoměny, překonala hranici 2 200 dolarů. Za posledních 30 dnů tak vzrostla přibližně o 80 % [reddit].

Ladislav Hagara | Komentářů: 0
dnes 17:33 | Nová verze

Po 5 měsících vývoje od vydání verze 0.12.0 byla vydána verze 0.13.0 správce balíčků GNU Guix a na něm postavené systémové distribuce GuixSD (Guix System Distribution). Na vývoji se podílelo 83 vývojářů. Přibylo 840 nových balíčků. Jejich aktuální počet je 5 454. Aktualizována byla také dokumentace.

Ladislav Hagara | Komentářů: 1
dnes 17:22 | Nová verze

Po 5 měsících vývoje a 3 týdnech intenzivního testování byla vydána verze 12 open source systému Nextcloud, forku ownCloudu, umožňujícího provoz vlastního cloudového úložiště. Přehled novinek i s videoukázkami v poznámkách k vydání. Pro vyzkoušení je k dispozici demo.

Ladislav Hagara | Komentářů: 2
dnes 11:44 | Zajímavý článek

Týden po prvním číslu publikoval Michal Špaček na svých stránkách druhé číslo newsletteru věnovanému bezpečnosti, bezpečnému vývoji převážně webových aplikací a bezpečnosti uživatelů. Věnuje se výpadku Let's Encrypt, únikům dat, bug bounty pro WordPress nebo SQL Injection v Joomla. Zmiňuje také, že Mozilla plánuje z Firefoxu odstranit podporu pro Encrypted Media Extensions (EME) na nešifrovaném HTTP a nadále pro EME vyžadovat HTTPS.

Ladislav Hagara | Komentářů: 0
dnes 02:00 | Pozvánky

Ve středu 31. května 2017 od 17:00 proběhne v pražské pobočce SUSE Den otevřených dveří v SUSE. Čekají vás přednášky o live kernel patchingu a nástroji SaltStack. Také se dozvíte zajímavé informace o SUSE, openSUSE, a vlastně všech produktech, na kterých lidé ze SUSE pracují.

Ladislav Hagara | Komentářů: 3
dnes 01:00 | Pozvánky

Czech JBoss User Group srdečně zve na setkání JBUG v Brně, které se koná ve středu 7. června 2017 v prostorách Fakulty informatiky Masarykovy univerzity v místnosti A318 od 18:00. Přednáší Tomáš Livora na téma Fault Tolerance with Hystrix. Více informací na Facebooku a Twitteru #jbugcz.

mjedlick | Komentářů: 0
19.5. 23:22 | Zajímavý projekt

Na Texture Ninja je volně k dispozici více než 4 tisíce textur. Autora lze podpořit na Patreonu.

Ladislav Hagara | Komentářů: 0
19.5. 10:22 | Pozvánky

Mozilla.cz zve na MozBeer Prague #2. Druhé setkání Mozilla.cz proběhne 26. května od 18:00 v Praze v Diversion Bistru v ulici Mělnická.

Ladislav Hagara | Komentářů: 0
18.5. 23:22 | Bezpečnostní upozornění

Průvodce restauracemi Zomato, jenž v roce 2014 koupil Lunchtime.cz, potvrdil bezpečnostní problém. Odcizeno bylo 17 miliónů záznamů o uživatelích (jména, emailové adresy, osolené hashe).

Ladislav Hagara | Komentářů: 8
Chystáte se pořídit CPU AMD Ryzen?
 (6%)
 (32%)
 (1%)
 (8%)
 (44%)
 (9%)
Celkem 586 hlasů
 Komentářů: 62, poslední 19.5. 01:57
    Rozcestník

    Dotaz: porovnavani souboru

    3.5.2005 19:47 Bobr
    porovnavani souboru
    Přečteno: 52×
    Dobry den, predelavam jeden program na linux a potreboval bych poradit jak porovnavat 2 binarni soubory v C.Chtel bych pouzit fce fread a pak memcmp pro porovnani bufferu. Sice jsem neco zkousel ale vzdy neuspesne. Pokousel jsem se i neco vyguglit ale taky neuspesne. Volat externi program (diff) take nemohu pac pozdeji budu muset program prekompilovat i na windows. Dekuji vsem za rady. S pozdravem Bobrik

    Odpovědi

    3.5.2005 19:51 Michal Kubeček
    Rozbalit Rozbalit vše Re: porovnavani souboru
    Ach jo. To je jako házet hrách na stěnu. Co jste zkoušel? Co to znamená neúspěšně?
    3.5.2005 19:59 Bobr
    Rozbalit Rozbalit vše Re: porovnavani souboru
      #define BLOCK_SIZE 1024
      char block1[BLOCK_SIZE];
      char block2[BLOCK_SIZE];
      FILE *fr1, *fr2;
      int readed;
      int same_file = 0;
    
      fr1= fopen(config_file,"rb");
      fr2= fopen("temp_config_bin","rb");
    
      while( ((readed = fread(block1, sizeof(char), BLOCK_SIZE, fr1) ) == BLOCK_SIZE) ){
       if( fread(block2, sizeof(char), BLOCK_SIZE, fr2) == BLOCK_SIZE ){
        if( memcmp(block1, block2, BLOCK_SIZE) != 0 ){
         same_file = 1;
        }
       } else {
        same_file = 1;
        if(ferror(fr2) != 0)
         printf("%s: error: can't read file temp_config_bin !\n", prog_name);
       }
      }
    
    Yin avatar 3.5.2005 20:11 Yin | skóre: 39 | blog: Yinotopia | Slovesnko, Košice
    Rozbalit Rozbalit vše Re: porovnavani souboru
    #define BUF_SIZE 1024
    FILE *fr1, *fr2;
    char buf1[BUF_SIZE], buf2[BUF_SIZE];
    size_t rs1, rs2;
    int same_files = 1;

    fr1 = fopen...
    fr2 = fopen...

    while(!(feof(fr1) || feof(fr2))) {
      rs1 = fread(buf1, sizeof(char), BUF_SIZE, fr1);
      rs2 = fread(buf2, sizeof(char), BUF_SIZE, fr2);

      if(rs1 != rs2 || memcmp(buf1, buf2, BUF_SIZE) != 0) {
        same_files = 0;
        break;
      }
    }
    Nikdy nie je tak zle, aby to jeden poharik nemohol ešte zhorsiť.
    3.5.2005 20:25 Michal Kubeček
    Rozbalit Rozbalit vše Re: porovnavani souboru
    V tom porovnání byste jako třetí argument memcmp měl použít rs1 (nebo rs2), jinak budete u posledního bloku (není-li délka souboru násobkem BUF_SIZE) porovnávat i části bufferů, do kterých se nic nenačetlo. Pokud bude poslední blok zároveň prvním (délka souborů stejná a menší než BUF_SIZE), může se stát, že váš program označí stejné soubory za různé.

    P.S. sizeof(char) je vždy 1, je to definováno normou; a z hlediska efektivity bude vhodnější fread(buf1, BUF_SIZE, 1, fr1) než fread(buf1, 1, BUF_SIZE, fr1)

    Yin avatar 3.5.2005 20:35 Yin | skóre: 39 | blog: Yinotopia | Slovesnko, Košice
    Rozbalit Rozbalit vše Re: porovnavani souboru
    dobry postreh... ale aby som uplne chapal... ak zmenim poradie tych dvoch, precita sa naraz 1-krat 'kus dat' o dlzke BUF_SIZE.. ak nie bude sa citat BUF_SIZE-krat 'kus dat' o dlzke 1?
    Nikdy nie je tak zle, aby to jeden poharik nemohol ešte zhorsiť.
    3.5.2005 20:39 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: porovnavani souboru
    Glibc to čte stejně po čtyřech kilech (resp. asi po PAGE_SIZE) :-)
    3.5.2005 20:46 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: porovnavani souboru
    Hledat se mi to teď nechce, prostě
    info '(libc)Stream Buffering'
    
    Yin avatar 3.5.2005 20:30 Yin | skóre: 39 | blog: Yinotopia | Slovesnko, Košice
    Rozbalit Rozbalit vše Re: porovnavani souboru
    hned na zaciatku by si mohol urobit stat() na tie dve subory, zistit ich velkosti a porovnat ich. A taktiez by si mohol z struct stat vytiahnut velkost bloku suboru na danom fs a tym (mozno aj rapidne) urychlit citanie.

    #import <sys/stat.h>
    struct stat sb1, sb2;
    size_t buf_size;

    stat(filename1, &sb1);
    stat(filename2, &bs2);

    if(sb1.st_size == sb2.st_size) {
      buf_size = sb1.st_blksize;
      
      // dynamicky alokovat buf a buf2, napr. cez alloca()
      // zvysok codu (fopen, while, fclose)
    } else {
      same_files = 0;
    }
    Nikdy nie je tak zle, aby to jeden poharik nemohol ešte zhorsiť.
    3.5.2005 20:00 Bobr
    Rozbalit Rozbalit vše Re: porovnavani souboru
    Stale to i 2 stejne soubory, vyhodi jako jine
    3.5.2005 21:54 Bobr
    Rozbalit Rozbalit vše Re: porovnavani souboru
    Tak uz se mi to s pomoci vas vsech povedlo naprogramovat.Prikladam sem jeste cely kod pokud by nekdo jiny resil stejny problem. Jeste jednou vam vsem velice dekuji za pomoc. Bobrik.
    #include <stdio.h>
    #include <stdlib.h>
    #include <sys/stat.h>
    
    int main(int argc, char *argv[])
    {
      FILE *fr1, *fr2;
      char *buf1, *buf2;
      size_t rs1, rs2;
      int same_files = 1;
      struct stat sb1, sb2;
      size_t buf_size;
      
      stat("file1.txt", &sb1);
      stat("file2.txt", &sb2);
    
      if(sb1.st_size == sb2.st_size) {
                    
        buf_size = sb1.st_size;
       
        buf1= alloca(buf_size);
        buf2= alloca(buf_size);
       
        fr1 = fopen("file1.txt","rb");
        fr2 = fopen("file2.txt","rb");
    
        while(!(feof(fr1) || feof(fr2))) {
                          
          rs1 = fread(buf1, sizeof(char), buf_size, fr1);
          rs2 = fread(buf2, sizeof(char), buf_size, fr2);
    
          if(rs1 != rs2 || memcmp(buf1, buf2, buf_size) != 0) {
            same_files = 0;
            break;
          }
    
        }
       
        fclose(fr1);
        fclose(fr2);    
            
      } else {
        same_files= 0;
        printf("Size is not the same.\n");
        system("PAUSE");
        exit(0);
      }  
      same_files?printf("The file is not different\n"):printf("The file is different\n");
      system("PAUSE");	
      return 0;
    }
    

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.