Website-Icon Embarcadero RAD Studio, Delphi, & C++Builder Blogs

C++Builder; Gemeinsame Bibliotheken (Laufzeitbibliothek), parallele Programmierbibliothek.

C++Builder bietet drei Entwicklungsstufen:
1. Komponenten (VCL und FMX)
2. Allgemeine Bibliotheken (RTL).
3. Plattform-APIs (iOS, Android, Mac OS)


In diesem Beitrag werden die Common Libraries (RTL) erläutert.

C++Builder verfügt über mehrere hundert Funktionen, Makros und Klassen, die Sie in Ihren C- und C++ – Programmen aufrufen, um eine Vielzahl von Aufgaben auszuführen, darunter E / A auf niedriger und hoher Ebene, Manipulation von Zeichenfolgen und Dateien, Speicherzuweisung und Prozesssteuerung , Datenkonvertierung, mathematische Berechnungen und mehr.

Die C++Builder-Laufzeitbibliothek (RTL) besteht aus einer Reihe von Basis-Header-Dateien, die die zugrunde liegende Unterstützung für die meisten VCL- und FireMonkey-Komponentenbibliotheken bieten. Das RTL umfasst globale Routinen, Utility – Klassen wie diejenigen , die Bäche und Listen und Klassen wie TObject, TPersistent und TComponent dar.

Obwohl eng mit Firemonkey und VCL verbündete, hat das RTL gehört keine der Komponenten , die auf dem erscheinen Werkzeugpalette.

Stattdessen werden die Klassen und Routinen in dem RTL durch die Komponenten verwendet , die auf der Tool – Palette erscheinen zu tun, und sind für Sie in Anwendungscode entweder in VCL – Projekten oder Projekten verwenden , um Firemonkey, oder wenn Sie Ihre eigenen Klassen schreiben.

Zum Beispiel enthält das System – Header die meisten der Laufzeitbibliothek (RTL). .

Und aus dem Header – System haben Sie den System.Math.hpp Header , die definiert , Klassen, Routinen, Typen, Variablen und Konstanten zu mathematischen Operationen, Vektoren und Matrizen zusammen.

Oder die System.Bluetooth.hpp Header , die Klassen zu verwenden liefert die Bluetooth – Funktionen des Geräts , das die Anwendung ausgeführt wird, um Anwendungen zu verbinden , die auf entfernten Geräten ausgeführt werden .

Oder der System.Sensors.hpp Header, Klassen und Komponenten , mit denen Sie Informationen lassen erhalten und Systemsensoren verwalten. Die Sensoren sind Teile der Hardware oder Software , die Maßnahmen von physikalischen Größen , um Ihre Anwendungen zur Verfügung stellen kann.

Oder die System.Threading.hppHeader , die definiert , Klassen und Typen, die die Umsetzung der parallelen Programmierung Bibliothek.

Es sei nun an einem Beispiel C++Builder sehen die Verwendung System.Threading.hpp Header und die Parallele Programmierung Bibliothek.

Für meine Beispielanwendung, werde ich eine C++Builder 10.4 verwenden Projektanwendung, die eine Common Run Time Library in einer Multi-Device-Anwendung unter Verwendung des System.Threading-Headers der RTL und der Parallel Programming Library verwendet.

Sie können diese Beispielprojektanwendung TParallelPrime.cbproj hier herunterladen .

 

Hier ist eine C++Builder-Projektanwendung, die eine allgemeine Laufzeitbibliothek in einer Anwendung mit mehreren Geräten unter Verwendung des System.Threading- Headers der RTL und der Parallel Programming Library verwendet.

[crayon-67500feeb08f1829069983/]

Dieses Beispiel zeigt, wie die TParallel.For-Methode aus der Parallel Programming Library (PPL) verwendet wird . TParallel.For teilt eine for-Schleife in Teile auf, die parallel ausgeführt werden, und verwendet Aufgaben, um diese Teile auszuführen.

Diese Anwendung ermittelt die Anzahl der Primzahlen zwischen 1 und einem MAX-Wert, wie z. B. 5 Millionen in dieser Anwendung. Die Anwendung berechnet die Zeit dafür mit (1) der klassischen for-Schleife und wir tun dasselbe mit der parallelen Version mit der TParallel.For-Methode.

Auf der Benutzeroberfläche der Anwendungen:

Die Schaltfläche „For Loop“ startet die serielle Version der Primzahlenberechnung.

[crayon-67500feeb08f8666288022/]

Die Schaltfläche „Parallelschleife“ startet die parallele Version der Primzahlenberechnung:

[crayon-67500feeb08f9504142274/]

Das Feld Memo zeigt die Berechnungszeiten zwischen der klassischen for-Schleife für (int I = 1; I <= Max; I ++) und der parallelen for-Schleifenversion mit der TParallel :: For- Methode an

Wie aus den Berechnungen hervorgeht, dauerte die serielle For-Schleife 814 Millisekunden, um die Anzahl der Primzahlen zwischen 1 und 5 Millionen zu berechnen, aber es dauerte nur 267 Millisekunden, um dasselbe mit der TParallel :: For-Methode zu tun. Es ist nicht klar, dass die TParallel :: For-Methode effizienter ist und die Anwendung viel schneller ausführt, da sie die verfügbaren CPUs zum parallelen Ausführen von Prozeduren verwendet. Die virtuelle Maschine, die ich für meine Windows-Partition verwendet habe, verwendet 4 Prozessorkerne. Bei Verwendung der TParallel :: For-Methode wird die Anwendung also im Grunde viermal schneller ausgeführt! Je mehr Kerne Sie haben, desto schneller wird Ihre Anwendung mit der TParallel :: For-Methode ausgeführt!

Wenn wir uns den Code ansehen, sehen wir, wie wir diese Anwendung implementiert haben.
Wenn Sie mit der Maus über #include <System.Threading.hpp> | fahren Rechtsklick | Öffnen Sie die Datei unter dem Cursor. Sie öffnen Ihre Datei C: Programme (x86) Embarcadero Studio 21.0 include windows rtl  System.Threading.hpp .

Verwenden Sie dann Methods Insight | Suche nach .

Wir sehen, dass wir 43 Methoden zur Verwendung von TParallel haben .
Wenn wir uns das erste ansehen, sehen wir in diesem System.Threading.TParallel.For-Header, der eine Reihe überladener Argumente enthält , um es für die C ++ – Entwicklung sehr gut geeignet zu machen!

Die Parallel Programming Library (PPL) enthält die Schleifenfunktion TParallel :: For , mit der die Schleifen parallel ausgeführt werden können!

Und für all dies gibt es einen Thread-Pool, der sich automatisch selbst optimiert (basierend auf der Belastung der CPUs), sodass Sie sich nicht um das Erstellen oder Verwalten von Threads für diesen Zweck kümmern müssen!

So verwenden Sie die Bibliothek für parallele Programmierung in Ihrer Anwendung, einschließlich des System.Threading-Headers. Dieser Header verfügt über mehrere Funktionen, die in neue und vorhandene C ++ Builder-Projekte aufgenommen werden können.

Wenn wir in die Benutzeroberfläche der Anwendungen zurückkehren und auf die Schaltfläche For Loop klicken, sehen wir, dass wir die reguläre serielle For Loop-Funktion verwenden, und prüfen, ob unsere Nummer von 1 bis 5 Millionen eine Primzahl ist.

Um zu überprüfen, ob die Zahl eine Primzahl ist, verwenden wir diese Funktion in unserer Anwendung

[crayon-67500feeb08fb055205367/]

Wenn wir als nächstes auf die Schaltfläche Parallel Loop klicken, sehen wir, dass wir die TParallel :: For-Methode der RTL verwenden. In C + muss unsere IsPrime-Funktion als Iterator-Ereignis oder als C++ 11-Lambda an die TParallel.For-Methode übergeben werden.

Für das Iterator-Ereignis haben wir die IsPrime-Funktion wie folgt als Iterator-Ereignis implementiert

[crayon-67500feeb0901084323836/]

Die zweite Option für die Übergabe unserer C++ IsPrime-Funktion an die TParallel.For-Methode ist die Verwendung eines C++ 11-Lambda für Parallel :: For , wie wir hier im Code sehen. Hier sehen wir unseren Lambda-Ausdruck: [&] (int AIndex) . Dies erfasst unsere Variable durch ref

[crayon-67500feeb0902805986136/]

Wenn Sie dieselbe Anwendung mit dem Lambda-Code ausführen, erhalten Sie dieselben Ergebnisse.

Beim Ausführen der Anwendung haben wir gesehen, wie effizient TParallel :: For ist, da es die verfügbaren CPUs zum parallelen Ausführen von Prozeduren verwendet. Und diese Anwendung zeigt auch C++ 11-Unterstützung in C++ Builder, einschließlich Unterstützung für Lambda Expressions!

Zusammenfassend enthält die C++Builder RTL eine Parallel Programming Library (PPL).

Eine großartige Verwendung der PPL besteht darin, die Schleife mithilfe der TParallel.For-Methode zu beschleunigen.

Die PPL, Teil von C++Builder RTL, im System.Threading-Header bietet Ihren Anwendungen auch die Möglichkeit, Aufgaben parallel auszuführen und die Arbeit auf mehreren CPU-Geräten und Computern zu nutzen. Die PPL enthält eine Reihe erweiterter Funktionen zum Ausführen von Aufgaben, Verbinden von Aufgaben, Warten auf Gruppen von Aufgaben sowie die TParallel :: For-Methode, die wir gerade in dieser Anwendung gesehen haben.

Einige zusätzliche nützliche Referenzen:

Verwenden der RTL (Run-Time Library )

Tutorial: Verwenden der For-Schleife aus der Bibliothek für parallele Programmierung

Video: Verwendung der VCL von Parallel Prime für C++Builder.

Laden Sie noch heute Ihre kostenlose 30-Tage-Testversion von C++Builder von diesem Link herunter

Die mobile Version verlassen