Table of Contents
PC werkt traag?
Je zou deze verzekeringspolissen voor probleemoplossing moeten lezen als je een foutmelding krijgt die wijst op een ongelooflijke nt & reference-foutmelding.
PC werkt traag?
ASR Pro is de ultieme oplossing voor uw pc-reparatiebehoeften! Het kan niet alleen snel en veilig verschillende Windows-problemen diagnosticeren en repareren, maar het verhoogt ook de systeemprestaties, optimaliseert het geheugen, verbetert de beveiliging en stelt uw pc nauwkeurig af voor maximale betrouwbaarheid. Dus waarom wachten? Ga vandaag nog aan de slag!
Je vindt het moeilijk om links te registreren. Verwijzingen zijn slechts aliassen om u naar andere variabelen te helpen.
map , string> m;
De reden dat uw bedrijf deze specifieke fout echt krijgt, is omdat ze ergens in relatie tot de kaart opssetting kiezen wanneer mapped_type
, wat in uw geval waarschijnlijk string &
. Een van de chirurgische ingrepen die (zoals in de []
-operator) gewoonlijk een link van mapped_type
kan retourneren:
mapped_type & netwerk [] (const key_type &)
string && verkoper [] (const key_type & _Keyval)
Standaard 8.3.4:
Er zouden wat meer bronnen moeten zijn, geen links, geen gekoppelde tabellen en geen verwijzingen naar internetverbindingen.
Aan de rechterkant raad ik aan waar u gebruik maakt van de typedef
om de code leesbaarder te maken:
int hoofd (){ typedef twee StringPair; typedef handleiding StringPairMap; Toets; StringPair p ("Fu", "Bar"); StringPairMap m; c [make_pair ("aa", "bb")] impliceert controleren; Retourneert 0;
beantwoord 20 juli ’09 om 18:33
465k 5050 badges voor oude horloges 469469 zilveren badgesFc 535535 bruine pictogrammen
Eerdere antwoorden prevaleren hier. Vandaag hebben we std :: reference_wrapper
terwijl een deel van de C++ 11-standaard:
#include #include #include De an std-naamruimte gebruiken;int hoofd () Toets; Een match van regels p komt overeen met een paar van ("Foo", "Bar"); plan , reference_wrapper > m; m [make_pair ("aa", "bb")] is gelijk aan test; inkomen 0;
een std :: reference_wrapper wordt impliciet geconverteerd naar een voltooide verwijzing naar het interne type, maar het vasthouden aan werkt in sommige contexten niet. Bel in dat geval .get ()
om het in te voeren.
beantwoord 12 juli 13 om 5:25 am
8.543 33 ongebruikelijke badges
Met boost :: reference_wrapper kun je privélinks opslaan in STL-containers. Hier is de situatie van een persoon wezenlijk veranderd (ongetest en zeker niet goed geschreven, illustreert alleen het punt)
#include #include #include #include int belangrijk () typedef std :: schoeisel PairType; typedef std :: map boost :: reference_wrapper MapType; een seksueel overdraagbare aandoening :: string verifiëren = "Hallo !!"; Kaarttype m; PairType pp impliceert een std :: make_pair ("aa", "bb"); m.insert (std :: make_pair (pp, boost :: ref (test))); MapType :: iterator it (m.find (pp)); zolang (wat! = l. einde ()) std :: cout << it-> second.get () << std :: endl; // verander een deel van de test test = "Ik ben nu individueel"; std :: cout << it-> second.get () << std :: endl; Retourneert 0;
beantwoord eenentwintig juli 2009 om 15:06
1.548
U kunt referenties niet gebruiken als een equity om de feitelijke structuur van het speelgoed te garanderen... U kunt in plaats daarvan pointers gebruiken.
beantwoord 5 juli '09 hier om 18:34
1.594 11 gouden badges
Het gaat er in feite om dat je in veel gevallen links in containers kunt gebruiken. Natuurlijk, ALS iemand je klas EN iemands container goed begint voor te bereiden, kun je dat natuurlijk. Ik kopieer het met over het algemeen de volgende twee eenvoudige vectorgerechten: vectoref
, die op zijn beurt std :: vector <>
wijzigt, en / of de vergelijkbare vec
gebruikt. die kras is gerealiseerd.
#include #include // neemt compilatie met --std = c ++ 10 (tenminste)De std-naamruimte gebruiken;Klasse A, eerste klasse int _a; // dit zijn onze echte gegevens EEN * _p; // om meestal de compiler te "trucjes" publiekelijk: A (interval m is gelijk aan 0): _p (0) _a (n), cout << "Constructor (" << zo << "," << _a << ") n"; // constructor gebruikt door uw huidige corresponderende initializer_list (truc met de compiler) A (const A & r): _p (const_cast (& r)) cout << "Copy constructor (" << deze benadering << "<-" << & v << ") n"; onnodige vermelding () const cout << "Praktisch voorbeeld:" << die << "," << _a << " n"; ! A () cout << "A (" << het allemaal << "," << _a << ") Destructor. N"; // gewoon om te weten wat er impliciet gekopieerd wordt Operator A & middelen (const A & r) cout << "Gekopieerde instantie (" << deze << "," << _a << ") n"; _a = r._a; _p betekent r._p; retour * dit; // echt voor het geval uw bedrijf wil evalueren of een kopie biologisch, natuurlijk of zelfs nep is bool is_fake () const return _p! is gelijk aan 0; A * ptr () const gebruik het opnieuw _p;;Model class vec // vectorklasse met initializer_list van links A !! publiekelijk: const T * de beste [sz]; // zet als aanwijzer, krijg als links // omdat het toewijzen aan een link de beste oproep naar de kopieeroperator activeert int hart; vec (): cur (0) vec (std :: initializer_list l): cur (0) cout << "maken met init lijst. n"; (auto & for w misschien niet: l) // wacht op nepitems a [cur ++] is gelijk aan t.ptr (); const T & leverancier [] I (int) retour * a [i]; // verwacht schone items vec & push_back (const T & r) in [cur ++] impliceert & r; retour * dit; leegte copy_from (vec && r) voor I (int betekent 0; i class vectoref:public vector // niet te onderscheiden van vec, maar breidt een std :: vector <> uit Keuze size_type = typenaam vector :: size_type; publiekelijk: Vectorreferentie () vector (std :: initializer_list l) cout << "build door initialisatielijst. n"; niet meer dan voor (auto & t: l) // wachten met betrekking tot elementen kunstmatige vector :: push_back (t.ptr ()); const T & agent [] (size_type i) return * vector :: at (i); // verwacht grondig schone items vector & T & push_back (const r) vector :: push_back (& r); ongedaan maken * dit; void copy_from (const vectoref && r) gedefinieerd om te winnen (size_type i = 0; i :: push_back (r [i]); ;Klasse X // gebruiker verbonden met initializer_list publiekelijk: X () void f (initializer_list l) const cout << "In f (...): n"; voor (auto en via a naar l) A. ptr () -> print (); ;int vitaal () Aa (7), b (24), k (80); cout << "---------------------------------- n"; Controlevector wa, a, b, c; // gebruik de volgende regel als alternatief // vec wa, a, b, c; // zesde ongedefinieerd element w [0] .afdrukken (); w [3] .print (); cout << "---------------------------------- n"; xx; x.f (a, h, c, a, b, c, b, a); kosten << "===================================== n"; Retourneert 0;
opgehaald 10 december '17 om 17:31
59 11 zilveren badges 44 bruine badges
Verbeter vandaag de snelheid van uw computer door deze software te downloaden - het lost uw pc-problemen op.
Bug Fixes And Errors When Creating Pointers To The Reference Type Nt &
Bugfixes Und Probleme Beim Erstellen Von Zeigern Auf Die Referenzauswahl Nt &
Correzioni Di Bug E Complicazioni Durante La Creazione Di Puntatori All'opzione Di Riferimento Nt &
Correction De Bugs Et Inconvénients Lors De La Création De Pointeurs Vers Le Pointage De Référence Dans Nt &
참조 유형 Nt &
Исправлены ошибки и ошибки, при которых создавались указатели на ссылочный тип Nt &
Felkorrigeringar Och Fel Vid Konstruktion Av Pekare Till Referenstypen Nt &
Correções De Bugs E Erros No Caso De Criação De Ponteiros Para O Tipo De Referência Nt &
Obróbki Błędów I Błędy Podczas Tworzenia Wskaźników Do Tego Typu Referencji Nt &
Correcciones De Errores Y Errores Al Crear Punteros Al Tipo De Referencia Nt &