pointers

___ answer30749050 ___

Die Frage, die Sie erwähnen, schlägt std :: function vor, betont aber nicht (oder erwähnt überhaupt) ihren Wert, wenn sie mit std :: bind kombiniert wird.

Ihr Beispiel ist das einfachste, aber nehmen Sie an, Sie haben ein

%Vor%

Ein Funktionszeiger kann mehr oder weniger die gleichen Dinge tun. Angenommen, Sie benötigen eine Funktion g (int), die f ist, wobei der zweite Parameter an 0 gebunden ist. Mit Funktionszeigern können Sie nicht viel anfangen, mit der std :: -Funktion können Sie dies tun:

%Vor%     
___ answer30757588 ___
  

Ich möchte auch fragen, ob etwas falsch ist (nicht empfohlen)   Sache mit Funktionszeigern, da ich nie jemanden benutze   sie.

Ja . Funktionszeiger sind schreckliche, schreckliche Dinge. Erstens unterstützen sie nicht, generisch zu sein - also können Sie keinen Funktionszeiger nehmen, der, zum Beispiel, %code% für irgendeine %code% benötigt. Zweitens, sie unterstützen nicht, gebunden zu sein, so dass, wenn irgendjemand in der Zukunft irgendjemand jemals auf einen anderen Staat verweisen möchte, sind sie völlig verschraubt. Dies ist besonders schlimm, da dies %code% für Memberfunktionen enthält.

Es gibt zwei Möglichkeiten, Funktionen in C ++ 11 zu verwenden. Die erste besteht darin, eine Vorlage zu verwenden. Die zweite ist die Verwendung von std :: function.

Die Vorlage sieht irgendwie so aus:

%Vor%

Die Hauptvorteile hier sind, dass es jede Art von Funktionsobjekt akzeptiert, einschließlich Funktionszeiger, Lambda, Funktor, Bindungsergebnis, was auch immer, und F kann eine beliebige Anzahl von Funktionsaufforderungen mit jeder Signatur, einschließlich Vorlagen, haben kann irgendeine Größe mit irgendeinem gebundenen Zustand haben. Es ist also super-flexibel. Es ist auch maximal effizient, da der Compiler den Operator inline und den Status direkt im Objekt übergeben kann.

%Vor%

Der Hauptnachteil hier ist die üblichen Nachteile von Vorlagen - es funktioniert nicht für virtuelle Funktionen und muss in der Kopfzeile definiert werden.

Der andere Ansatz ist %code% . %code% hat viele der gleichen Vorteile - es kann eine beliebige Größe haben, an jeden Status gebunden werden und alles, was aufrufbar ist, aber ein Paar aushandeln. Hauptsächlich wird die Signatur zur Zeit der Typdefinition festgelegt, so dass Sie kein %code% für einige noch zu erkennende %code% haben können, und es kann auch eine dynamische Indirektion / Zuweisung geben (falls möglich). t SBO). Der Vorteil dabei ist, dass %code% ein reeller konkreter Typ ist, den Sie wie bei jedem anderen Objekt weitergeben können, so dass er als virtueller Funktionsparameter und solche Dinge verwendet werden kann.

Grundsätzlich sind Funktionszeiger unglaublich begrenzt und können nichts Interessantes tun und machen die API unglaublich unflexibel. Ihre abscheuliche Syntax ist eine Pisse im Ozean und das Reduzieren mit einem Template-Alias ​​ist urkomisch, aber sinnlos.

    
___ answer30749905 ___
  

Ich habe mir diese Frage angeschaut, konnte aber keine verstehen   Vorteile gegenüber der traditionellen Verwendung von Funktionszeigern. Auch ich würde   gerne fragen, gibt es irgendwas falsches (nicht zu empfehlen) ding mit   Funktionszeiger verwenden, da ich nie jemanden sehe, der sie benutzt.

  • Normale "globale" Funktionen haben normalerweise keinen Status. Während es während des Traversals im funktionalen Programmierparadigma nicht unbedingt gut ist, einen Zustand zu haben, kann manchmal ein Zustand nützlich sein, wenn er sich orthogonal auf das bezieht, was geändert wurde (Heuristik als Beispiel). Hier haben Funktoren (oder Funktionsobjekte) den Vorteil.

  • Normale Funktionen sind nicht sehr gut (Erstellen von Funktionen auf höherer Ebene von Funktionen auf niedrigerer Ebene.

  • Normale Funktionen erlauben es nicht, zusätzliche Parameter im laufenden Betrieb zu binden.

  • Manchmal können normale Funktionen als Ersatz für Lambdas dienen, und umgekehrt, je nach Kontext. Oft möchte man keine spezielle Funktion schreiben, nur weil Sie während des "Container Traversal" eine sehr lokale / spezifische Anforderung haben.

___ tag123c ___ C ++ ist eine universelle Programmiersprache. Es wurde ursprünglich als Erweiterung von C entworfen und behält eine ähnliche Syntax, ist aber jetzt eine komplett andere Sprache. Verwenden Sie dieses Tag für Fragen zu Code, der mit einem C ++ - Compiler kompiliert werden soll. ___ tag123c11 ___ C ++ 11 ist eine 2011 verabschiedete Version des C ++ - Sprachstandards. Sie hat viele Änderungen und Ergänzungen der Kernsprache sowie der verbesserten und erweiterten C ++ - Standardbibliothek vorgenommen. ___ qstntxt ___

Ich habe bisher Funktionszeiger verwendet, wie dieses Format in C ++. Ich habe ab und zu einige Anwendungen und ich frage mich, ob es etwas anderes in c ++ 11/14 als Alternative gibt.

%Vor%

Ich habe mir diese Frage angesehen, konnte sie aber nicht verstehen irgendwelche Vorteile gegenüber der traditionellen Verwendung von Funktionszeigern. Auch ich würde gerne fragen, ob es irgendwas falsches (nicht empfohlenes) Ding mit Funktionszeigern gibt, da ich nie jemanden sehe, der sie benutzt. Oder irgendeine andere alternative Gegenwart.

    
___ answer30750711 ___

Als eine Alternative zu traditionellen Funktionszeigern hat C ++ 11 Vorlagen-Alias ​​ eingeführt in Kombination mit variadischen Vorlagen könnte der Funktionszeiger sintax vereinfacht werden. Im Folgenden ein Beispiel für die Erstellung eines Funktionszeigers "Vorlage":

%Vor%

Es kann so verwendet werden:

%Vor%

Auch kann es gut mit Funktionsüberlastungen umgehen:

%Vor%

Und kann als eine hübsche Methode verwendet werden, Funktionszeigerparameter zu deklarieren:

%Vor%

Dieser Template-Alias ​​könnte als Alternative zu %code% verwendet werden, der weder Nachteile noch Vorteile hat ( gute Erklärung hier) ).

Live-Demo

Kurz gesagt, ich denke, dass Vorlagen-Alias ​​in Kombination mit variadischen Vorlagen eine gute, nette, saubere und moderne C ++ - Alternative zu rohen Funktionszeigern ist (dieser Alias ​​ist immer noch Funktionszeiger), aber %code% ist gut, nett, ordentlich und modern C ++ auch mit guten Vorteilen zu berücksichtigen. Das Einbinden von Funktionszeigern (oder Alias) oder die Auswahl von %code% liegt an Ihren Implementierungsanforderungen.

    
___ tag123pointer ___ Datentyp, der auf einen anderen gespeicherten Wert zeigt. Eine Zeigervariable enthält eine Speicheradresse einer anderen Entität (Variable oder Funktion oder andere Entität). Dieses Tag sollte für Fragen verwendet werden, bei denen Zeiger und keine Referenzen verwendet werden. Die gebräuchlichsten Programmiersprachen, die Zeiger verwenden, sind C-, C ++ -, Go- und Assemblersprachen. Verwenden Sie ein bestimmtes Sprach-Tag. Andere hilfreiche Tags sind Methode, Funktion, Struktur usw., die die Verwendung von Pointer beschreiben. ___ tag123functionpointers ___ Ein Funktionszeiger ist ein Zeiger auf eine Funktion, die in einer Variablen gespeichert werden kann. Es ermöglicht eine Laufzeitauswahl, welche Funktion ausgeführt werden soll. ___ qstnhdr ___ moderne C ++ Alternative zu Funktionszeigern ___
2
Antworten

Dereferenzierung beliebiger Speicherorte in C

Ich versuche ein Programm zu debuggen, das ich geschrieben habe. Je nach Debugger enthält ein bestimmter void * den Wert 0x804b008. Ich würde gerne in der Lage sein, diesen Wert zu dereferenzieren (erstelle ihn auf int * und erhalte seinen...
16.02.2010, 05:08
5
Antworten

Doppelsternchen und 'malloc' in C

Ich habe seit einiger Zeit Hinweise studiert und ich kann meinen Kopf nicht vollständig umschließen. Es scheint eine Lücke zu geben, die nicht erklärt wird, wenn Sie von Tutorials springen, die Zeiger auf tatsächliche Funktionen und Code erkläre...
22.03.2017, 03:34
1
Antwort

Warum funktioniert fopen ohne den zurückgegebenen Zeiger zu speichern?

Ich habe ein kleines Programm geschrieben, um eine OTP verschlüsselte Datei zu entschlüsseln. Das funktioniert gut. Aber ich habe bemerkt, dass ich vergessen habe, den zurückgegebenen Dateizeiger beim Aufruf von fopen auf "Solution.jpg" zu sp...
17.02.2016, 10:54
2
Antworten

Sind diese beiden Stile der C-Funktionszeigerdefinition unterschiedlich?

Ich habe mich zufällig dabei ertappt, dass ich zwei verschiedene Arten von C-Funktionszeiger-Definitionen an verschiedenen Stellen verwendet habe und habe beschlossen, ein minimales Programm zu schreiben, um diese Unterschiede zu testen. Die...
10.03.2016, 17:23
3
Antworten

Speicherverbrauch mit Zeigern

Bitte sehen Sie sich das Bild unten an. Nachdem der Wert von p1 geändert wurde, zeigt er nun auf den B2-Speicherort. Was ist mit dem schattierten Speichersegment passiert? Wie ich weiß, wird es bleiben, bis der Codeblock seine Ausführung beendet...
08.10.2015, 10:07
1
Antwort

Probleme mit Zeigern und Zeigern auf Zeiger

Ich habe Probleme, zu verstehen, warum ein Code funktioniert. Das Folgende ist eine Vergleichsfunktion für die Implementierung von qsort in stdlib: %Vor% Das funktioniert natürlich nur für Strings. Meine Frage ist: Warum funktioniert der Cod...
30.05.2016, 20:57
2
Antworten

Kann der int-Zeiger in char * umgewandelt werden?

Das folgende Programm testet Little / Big Endian auf Intel Prozessor. Eigentlich ist Little Endian korrekt ausgegeben. Zuerst werfe ich int auf char* und greife auf seinen Wert ohne Initialisierung auf int * zu. Ich verstehe den zweiten...
26.01.2013, 19:53
1
Antwort

Cython std :: ein Paar von zwei Zeigern, erwartet einen Bezeichner oder ein Literal

Warum in Cython ist es möglich, zu umbrechen %Vor% aber nicht %Vor% Insbesondere wird das Umbrechen von std::pair in Cython wie folgt durchgeführt: %Vor% und funktioniert reibungslos, aber wenn das erste Element von ist auch ein Z...
06.11.2012, 10:24
2
Antworten

Liefert Zeiger auf eine String-Konstante

%Vor% "BM" muss irgendwo im schreibgeschützten Speicherbereich liegen, warum kann ich dann keinen Zeiger darauf bekommen? (Es kompiliert, aber es sagt ungültigen Speicherbereich (clang compiler))     
16.04.2015, 11:26
1
Antwort

Verwirrung über Typen, Überläufe und UB in Zeiger-Integral-Addition

Ich dachte, dass das Hinzufügen eines ganzzahligen Typs zu einem Zeiger (vorausgesetzt, dass der Zeiger auf ein Array mit einer bestimmten Größe usw. zeigt) immer gut definiert ist, unabhängig vom Integraltyp. Der C ++ 11 Standard sagt ([expr.ad...
12.06.2015, 13:44