Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.de  
   

Die mobilen Seiten von c++.de:
http://m.c-plusplus.de
Infos hier [BETA]

  
c++.de :: C++ (auch C++0x und C++11) ::  Boost Strong Typedef für nicht-primitive Typen     Zeige alle Beiträge auf einer Seite Auf Beitrag antworten
Autor Nachricht
pyhax
Mitglied

Benutzerprofil
Anmeldungsdatum: 22.11.2011
Beiträge: 692
Beitrag pyhax Mitglied 18:04:42 10.05.2012   Titel:   Boost Strong Typedef für nicht-primitive Typen            Zitieren

Hallo,

gibt es irgendwo so etwas wie http://www.boost.org/doc/ ....... n/doc/strong_typedef.html für nicht-primitive Typen (Eigene Klassen, STL Container) ?

_________________
Ich kann (teilweise): C++, Python, Java(ist lange her), PHP, D (Anfänger)
SeppJ
Moderator

Benutzerprofil
Anmeldungsdatum: 10.06.2008
Beiträge: 17931
Beitrag SeppJ Moderator 18:20:36 10.05.2012   Titel:              Zitieren

Wie wäre es mit Boost? Ich glaube die haben ein strong typedef Makro im Serialization-Teil.

edit: Ich glaube ich hatte nicht genau verstanden, was du meinst.

_________________
Du brauchst Hilfe?, Buchempfehlungen für C++,
Wie man in Fragen den richtigen Code postet,
The Definitive C++ Book Guide and List


Zuletzt bearbeitet von SeppJ am 18:23:29 10.05.2012, insgesamt 1-mal bearbeitet
pyhax
Mitglied

Benutzerprofil
Anmeldungsdatum: 22.11.2011
Beiträge: 692
Beitrag pyhax Mitglied 18:37:26 10.05.2012   Titel:              Zitieren

Hab mir jetzt selber was gebastelt: (Leider unterstützt noch kein Compiler inheriting constructors)
C++:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#include <iostream>
#include <vector>
#include <type_traits>
 
template <typename T, typename Id>
struct StrongType : T {
    template <typename Arg, typename ... Args>
    StrongType(Arg&& arg, Args&&... args) : T(std::forward<Arg>(arg), std::forward<Args>(args)...) {}
 
    template <typename V>
    StrongType(std::initializer_list<V> init) : T(init) {}
 
    StrongType& operator=(StrongType& const other) {
        T::operator=(other);
    }
};
 
int main() {
    struct a__{};
    struct b__{};
    typedef StrongType<std::vector<int>, a__> a;
    typedef StrongType<std::vector<int>, b__> b;
    a avec = {1,2,3,4,5,6};
    b bvec = {1,2,3};
    std::cout << avec.size() << std::endl;
    avec = bvec;
}

_________________
Ich kann (teilweise): C++, Python, Java(ist lange her), PHP, D (Anfänger)
SeppJ
Moderator

Benutzerprofil
Anmeldungsdatum: 10.06.2008
Beiträge: 17931
Beitrag SeppJ Moderator 18:40:35 10.05.2012   Titel:              Zitieren

Dieses hier sollte schon einmal ein Stück weiterhelfen. Das kann man dann auch insgesamt als Makro definieren, dann hat man die gleiche Syntax wie bei Boost:
C++:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <vector>
 
template <typename T> struct StrongTypedef : public T
{
  explicit StrongTypedef(const T& t): T(t) {}
  StrongTypedef(): T() {};
  StrongTypedef& operator=(const T &rhs) { T::operator=(rhs); return *this;}
  operator const T & () const {return *this; }
  operator T & () { return *this; }
};
 
typedef StrongTypedef<std::vector<int> > a;
 
void f(std::vector<int> x);  // (1) function to handle simple integers
void f(a x);    // (2) special function to handle integers of type a
int main(){
  std::vector<int> x(1);
  a y;
  y = x;      // other operations permitted as a is converted as necessary
  f(x);       // chooses (1)
  f(y);       // chooses (2)
  y.push_back(1);
}
Das sollte funktionieren, solange die Implmentierung in einer abgeleitete Klasse ohne eigene Member keinen zusätzlichen Speicher belegt. Ansonsten stirbt man am möglicherweise nicht-virtuellen Destruktor der Basisklasse. Und man hätte nun noch die wunderschöne Aufgabe, per Templatemagie alle existierenden Operatoren der Basisklasse auch auf die Typedefklasse zu übertragen.

Und vermutlich habe ich irgendwas wichtiges übersehen, da ich nach meiner ersten. falschen Antwort dies hier so hopplahop zusammengeschrieben habe.


edit: Jetzt warst du selber schneller mit der gleichen Idee. In C++11 geht's natürlich eine Nummer schöner, wie du schon siehst.
edit2: Dir fehlt noch ein return bei der Zuweisung.

_________________
Du brauchst Hilfe?, Buchempfehlungen für C++,
Wie man in Fragen den richtigen Code postet,
The Definitive C++ Book Guide and List


Zuletzt bearbeitet von SeppJ am 18:43:22 10.05.2012, insgesamt 3-mal bearbeitet
pyhax
Mitglied

Benutzerprofil
Anmeldungsdatum: 22.11.2011
Beiträge: 692
Beitrag pyhax Mitglied 18:54:47 10.05.2012   Titel:              Zitieren

Ja, das return hat mein Compiler mir auch schon gemeldet. :D Außerdem hatte ich noch einen Schreibfehler:
C++:
StrongType& const

:D

SeppJ schrieb:
Und man hätte nun noch die wunderschöne Aufgabe, per Templatemagie alle existierenden Operatoren der Basisklasse auch auf die Typedefklasse zu übertragen.

Mit Boost.Preprocessor sollte das gehen, dazu habe ich im Moment keine Lust :D

_________________
Ich kann (teilweise): C++, Python, Java(ist lange her), PHP, D (Anfänger)
c++.de :: C++ (auch C++0x und C++11) ::  Boost Strong Typedef für nicht-primitive Typen   Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum antworten.
Sie können Ihre Beiträge in diesem Forum nicht bearbeiten.
Sie können Ihre Beiträge in diesem Forum nicht löschen.
Sie können an Umfragen in diesem Forum nicht mitmachen.

Powered by phpBB © 2001, 2002 phpBB Group :: FI Theme

c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de Werbekostenerstattung verdient werden kann.

Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info und www.c-plusplus.net enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt (vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden. Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.