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 15:55 | Komunita

    FFmpeg nechal kvůli porušení autorských práv odstranit z GitHubu jeden z repozitářů patřících čínské technologické firmě Rockchip. Důvodem bylo porušení LGPL ze strany Rockchipu. Rockchip byl FFmpegem na porušování LGPL upozorněn již téměř před dvěma roky.

    🇨🇽 | Komentářů: 4
    dnes 15:44 | Zajímavý software

    K dispozici je nový CLI nástroj witr sloužící k analýze běžících procesů. Název je zkratkou slov why-is-this-running, 'proč tohle běží'. Klade si za cíl v 'jediném, lidsky čitelném, výstupu vysvětlit odkud daný spuštěný proces pochází, jak byl spuštěn a jaký řetězec systémů je zodpovědný za to, že tento proces právě teď běží'. Witr je napsán v jazyce Go.

    🇨🇽 | Komentářů: 0
    dnes 15:33 | Zajímavý software

    Yazi je správce souborů běžící v terminálu. Napsán je v programovacím jazyce Rust. Podporuje asynchronní I/O operace. Vydán byl v nové verzi 25.12.29. Instalovat jej lze také ze Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    26.12. 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

    Ladislav Hagara | Komentářů: 0
    26.12. 13:22 | Zajímavý software

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 7
    26.12. 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    26.12. 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

    Ladislav Hagara | Komentářů: 0
    25.12. 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 30
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (33%)
     (1%)
     (22%)
     (1%)
     (1%)
     (1%)
     (12%)
     (12%)
     (16%)
    Celkem 171 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    Rozcestník

    Dotaz: problem s gcc

    26.8.2006 13:53 secido | skóre: 27
    problem s gcc
    Přečteno: 100×
    Tento kod mi so starsou verziu gcc fungoval:
    Fraction::Fraction(int znum, int zden) {
    num = znum;
    den = zden;
    normalize();
    }
    
    Fraction::Fraction(double f) {
    num = int(f) * 10000;
    num += int((f - int(f))*10000.0);
    den = 10000;
    normalize();
    }
    
    Fraction Fraction::operator+(Fraction b) {
    return Fraction(den*b.num+b.den*num, den*b.den);
    }
    
    ...
    
    c4=-.5+c1
    
    Teraz s pouzitim gcc 4.0.3 dostanem chybu:

    no match for ‘operator+’ in ‘-5.0e-1 + c1’

    Po takejto uprave to chodi:

    c4=Fraction(-.5)+c1

    V com je problem? Nemal by sa implicitne pouzit konstruktor Fraction(double)?

    Odpovědi

    26.8.2006 14:19 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: problem s gcc

    Aby vám tohle prošlo, musel byste použít samostatný operátor, ne metodu. Tedy např.:

    inline Fraction operator + (const Fraction& x, const Fraction& y)
    {
      return Fraction(x.den*y.num+y.den*x.num, x.den*y.den);
    }
    
    26.8.2006 20:51 secido | skóre: 27
    Rozbalit Rozbalit vše Re: problem s gcc
    Skusal som to pridat, ale den a num su private. Radsej uvediem kompletny kod. Trochu som cvicil s C++ pred par rokmi no daleko som sa nedostal, teraz som znovu dostal chut :-).
    fraction.h:
    #ifndef FRACTION_H
    #define FRACTION_H
    
    #include <iostream>
    
    using namespace std;
    
    class Fraction
    {
        int num, den;
    
        int gcd(int, int);
    
        public:
    
        Fraction(int = 0, int = 1);
        Fraction(double);
        Fraction(const Fraction&);
        void normalize();
        Fraction operator+(const Fraction&);
        Fraction operator-();
        Fraction operator-(const Fraction&);
        Fraction operator*(const Fraction&);
        Fraction operator/(const Fraction&);
        const int numerator() const;
        const int denominator() const;
        friend ostream& operator<<(ostream& os, const Fraction& z);
        friend istream& operator>>(istream& is, Fraction& z);
        const double toDouble() const;
    };
    #endif
    
    fraction.cpp:
    #include "fraction.h"
    
    int Fraction::gcd(int a, int b) {
      int c = 1;
      a = (a >= 0) ? a : - a;
      b = (b >= 0) ? b : - b;
      while (c > 0) {
        c = a % b;
        a = b;
        b = c;
      }
      return a;
    }
    
    Fraction::Fraction(int znum, int zden) {
      num = znum;
      den = zden;
      normalize();
    }
    
    Fraction::Fraction(const Fraction& z):num(z.num), den(z.den) {
      cout << "Fraction(const Fraction&) : " << *this << endl;
    }
    
    Fraction::Fraction(double f) {
      num = int(f) * 10000;
      num += int((f - int(f))*10000.0);
      den = 10000;
      normalize();
    }
    
    void Fraction::normalize() {
      int lgcd = gcd(num, den);
      num /= lgcd;
      den /= lgcd;
    }
    
    Fraction Fraction::operator+(const Fraction &b) {
      return Fraction(den*b.num+b.den*num, den*b.den);
    }
    
    Fraction Fraction::operator-() {
      return Fraction(-num, den);
    }
    
    Fraction Fraction::operator-(const Fraction& b) {
      return Fraction(b.den*num-den*b.num, den*b.den);
    }
    
    Fraction Fraction::operator*(const Fraction& b) {
      return Fraction(num*b.num,den*b.den);
    }
    
    Fraction Fraction::operator/(const Fraction& b) {
      return Fraction(num*b.den, den*b.num);
    }
    
    const int Fraction::numerator() const {
      return num;
    }
    
    const int Fraction::denominator() const {
      return den;
    }
    
    ostream& operator<<(ostream& os, const Fraction& z) {
      if(z.den == 1)
        return os << z.num;
      else
        return os << z.num << "/" << z.den;
    }
    
    istream& operator>>(istream& is, Fraction& z) {
      char c;
      is >> z.num;
      is >> c;
      is >> z.den;
      return is;
    }
    
    const double Fraction::toDouble() const
    {
      return double(num)/double(den);
    }
    
    fractest.cpp:
    #include <iostream>
    #include "fraction.h"
    
    #define P(x) cout << "[" #x "] = " << (x) << endl;
    
    /*
    inline Fraction operator+(const Fraction& x, const Fraction& y) {
      return Fraction(x+y);
    }
    */
    
    
    int main()
    {
        Fraction c1(12,123);
        Fraction c2(98);
        Fraction c3(0,1);
        Fraction* c5 = new Fraction(2,3);
    
        P(c1); P(c2); P(c3); P(*c5);
    
        P(c3=c1+c2);
        P(c3=c1-c2);
        P(c3=c1*c2);
        P(c3=c1/c2);
        P(*c5=c1+c2+c3);
        P(c3=c1+c2/c3-c1);
        P(c3=(c1+c2)/(c3-c1));
    
        Fraction c4 = c3;
        P(c4);
        P(c4=c1+5+5.5);
        P(c4=7);
        P(c4=-.5);
        P(c4=c4+c1);
        P(c4=Fraction(-.5)+c1);
    //    P(c4=-.5+c1);
        P(c4=c1-.5);
        P(c4.toDouble());
    //    P(double(c4));
    
        delete c5;
        return 0;
    }
    
    26.8.2006 22:22 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: problem s gcc

    Jestli je problém jen v tom, že jsou private, tak buď v implementaci operátoru použíjte přístupové metody numerator() a denominator() nebo ten operátor deklarujte jako friend.

    Mimochodem, z logiky věci by asi metodu gcd() bylo v tomto případě vhodnější deklarovat jako static.

    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.