Rheinwerk Computing < openbook > Rheinwerk Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.

Inhaltsverzeichnis
Vorwort
Vorwort des Gutachters
1 Einstieg in C
2 Das erste Programm
3 Grundlagen
4 Formatierte Ein-/Ausgabe mit »scanf()« und »printf()«
5 Basisdatentypen
6 Operatoren
7 Typumwandlung
8 Kontrollstrukturen
9 Funktionen
10 Präprozessor-Direktiven
11 Arrays
12 Zeiger (Pointer)
13 Kommandozeilenargumente
14 Dynamische Speicherverwaltung
15 Strukturen
16 Ein-/Ausgabe-Funktionen
17 Attribute von Dateien und das Arbeiten mit Verzeichnissen (nicht ANSI C)
18 Arbeiten mit variabel langen Argumentlisten – <stdarg.h>
19 Zeitroutinen
20 Weitere Headerdateien und ihre Funktionen (ANSI C)
21 Dynamische Datenstrukturen
22 Algorithmen
23 CGI mit C
24 MySQL und C
25 Netzwerkprogrammierung und Cross–Plattform-Entwicklung
26 Paralleles Rechnen
27 Sicheres Programmieren
28 Wie geht’s jetzt weiter?
A Operatoren
B Die C-Standard-Bibliothek
Stichwort

Jetzt Buch bestellen
Ihre Meinung?

Spacer
<< zurück
C von A bis Z von Jürgen Wolf
Das umfassende Handbuch
Buch: C von A bis Z

C von A bis Z
3., aktualisierte und erweiterte Auflage, geb., mit CD und Referenzkarte
1.190 S., 39,90 Euro
Rheinwerk Computing
ISBN 978-3-8362-1411-7
Pfeil B Die C-Standard-Bibliothek
Pfeil B.1 <assert.h>
Pfeil B.2 <complex.h> (C99)
Pfeil B.3 <ctype.h>
Pfeil B.4 <errno.h>
Pfeil B.5 <fenv.h> (C99)
Pfeil B.6 <float.h>
Pfeil B.7 <inttypes.h> (C99)
Pfeil B.8 <iso646.h> (NA1)
Pfeil B.9 <limits.h>
Pfeil B.10 <locale.h>
Pfeil B.11 <math.h>
Pfeil B.12 <setjmp.h>
Pfeil B.13 <signal.h>
Pfeil B.14 <stdarg.h>
Pfeil B.15 <stdbool.h> (C99)
Pfeil B.16 <stddef.h>
Pfeil B.17 <stdint.h> (C99)
Pfeil B.18 <stdio.h>
Pfeil B.19 <stdlib.h>
Pfeil B.20 <string.h>
Pfeil B.21 <tgmath.h> (C99)
Pfeil B.22 <time.h>
Pfeil B.23 <wchar.h> (NA1)
Pfeil B.24 <wctype.h> (NA1)


Rheinwerk Computing - Zum Seitenanfang

B.5 <fenv.h> (C99) topZur vorigen Überschrift

In der Headerdatei <fenv.h> finden Sie verschiedene Einstellungen für das Rechnen mit Gleitpunktzahlen, um mit Gleitpunkt-Exceptions und Zustandsflags zu arbeiten. Außerdem können Sie hierbei auch das Rundungsverhalten von Gleitpunkt-Arithmetiken einstellen.

Um mit dem Programm auf diese Gleitpunkt-Umgebung zuzugreifen, empfiehlt es sich, dies dem Compiler mit dem Pragma STDC FENV_ACCESS mitzuteilen:

// Compiler-Optimierungen verhindern
#pragma STDC FENV_ACCESS ON

Mit OFF können Sie das Pragma wieder abschalten. Ob dieses Pragma mit dem Status ON oder OFF implementiert ist, hängt vom Compiler ab. Das Pragma ist ebenfalls in der Headerdatei <fenv.h> definiert.

Für den Zugriff auf die komplette Gleitpunkt-Umgebung stehen folgende typedef-Typen zur Verfügung:


Tabelle B.5 Typen in <fenv.h>

Typ Beschreibung
fenv_t

Der Typ stellt die Gleitpunkt-Umgebung als Ganzes dar.

fexcept_t

Der Typ stellt die Zustandsflags und Gleitpunkt-Exceptions als Ganzes dar.


Zugriff auf die komplette Gleitpunkt-Umgebung mit dem Typ fenv_t haben Sie mit folgenden Funktionen:


Tabelle B.6 Zugriff auf die komplette Gleitpunkt-Umgebung

Funktion Beschreibung
int fegetenv(fenv_t *envp);

Gleitpunkt-Umgebung speichern

int feholdexcept(
   fenv_t *envp );

Gleitpunkt-Umgebung in einen Non-Stop-Modus setzen. Hierbei unterbricht eine Exception nicht die Programmausführung.

int fesetenv(
   const fenv_t *envp );

Gleitpunktumgebung wiederherstellen

int feupdateenv(
   const fenv_t *envp );

eine gespeicherte Gleitpunkt-Umgebung wiederherstellen und alle zur Laufzeit gesetzten Exceptions erneut auslösen


Für den Zugriff auf die Gleitpunkt-Exception und Zustandsflags stehen Ihnen folgende Funktionen zur Verfügung:


Tabelle B.7 Zugriff auf die Gleitpunkt-Exception und Zustandflags

Funktion Beschreibung
int feclearexcept (int excepts);

Exception wieder löschen

int fegetexceptflag (
   fexcept_t *flagp,
   int excepts);

Exception-Statusflags speichern

int feraiseexcept (int excepts);

Exception manuell auslösen

int fesetexceptflag (
   const fexcept_t *flagp,
   int excepts);

Exception-Statusflags wiederherstellen

int fetestexcept (int excepts);

Exception-Statusflags testen


Zur genauen Identifizierung der Exeception- und Zustandsflags sind in der Headerdatei <fenv.h> folgende ganzzahlige Makros definiert:


Tabelle B.8 Verschiedene Typen von Exception- und Zustandsflags in <fenv.h>

Makro Beschreibung
FE_DIVBYZERO

Division durch null

FE_INEXACT

Ungenauigkeit bei der Gleitpunktberechnung

FE_INVALID

Ungültige Gleitpunktberechnung

FE_OVERFLOW

Überlauf bei der Gleitpunktberechnung

FE_UNDERFLOW

Unterlauf bei der Gleitpunktberechnung

FE_ALL_EXCEPT

Zugriff auf alle unterstützten Exceptions


Ebenfalls in der Headerdatei <fenv.h> sind Funktionen definiert, um das Rundungsverhalten der Gleitpunkt-Arithmetik einzustellen:


Tabelle B.9 Funktionen zum Einstellen des Rundungsmodus bei der Gleitpunkt-Arithmetik

Funktion Beschreibung
int fegetround (void);

Gibt den aktuellen Rundungsmodus zurück (gewöhnlich ist hier FE_TONEAREST eingestellt).

int fesetround (int round);

Setzt den Rundungsmodus auf round.


Folgende Makros sind hier in der Headerdatei <fenv.h> definiert, um den Rundungsmodus abzufragen bzw. zu setzen:


Tabelle B.10 Makros zum Einstellen des Rundungsverhalten bei Gleitpunktberechnungen

Makro Beschreibung
FE_DOWNWARD

Gleitpunktzahl zum nächsten Integer abrunden

FE_UPWARD

Gleitpunktzahl zum nächsten Integer aufrunden

FE_TONEAREST

Gleitpunktzahl auf nächstnäheren Integer auf- oder abrunden (Standardeinstellung)

FE_TOWARDZERO

Gleitpunktzahl auf den nächstmöglichen Integer in der Nähe von 0 runden




Ihre Meinung

Wie hat Ihnen das Openbook gefallen? Wir freuen uns immer über Ihre Rückmeldung. Schreiben Sie uns gerne Ihr Feedback als E-Mail an kommunikation@rheinwerk-verlag.de.

<< zurück
  
  Zum Rheinwerk-Shop
Zum Rheinwerk-Shop: C von A bis Z

 C von A bis Z
Jetzt bestellen


 Ihre Meinung?
Wie hat Ihnen das Openbook gefallen?
Ihre Meinung

 Buchtipps
Zum Rheinwerk-Shop: C/C++






 C/C++


Zum Rheinwerk-Shop: Einstieg in C






 Einstieg in C


Zum Rheinwerk-Shop: Schrödinger programmiert C++






 Schrödinger
 programmiert C++


Zum Rheinwerk-Shop: C++ Handbuch






 C++ Handbuch


Zum Rheinwerk-Shop: IT-Handbuch für Fachinformatiker






 IT-Handbuch für
 Fachinformatiker


 Lieferung
Versandkostenfrei bestellen in Deutschland, Österreich und der Schweiz
InfoInfo




Copyright © Rheinwerk Verlag GmbH 2009
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das Openbook denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt.
Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.


Nutzungsbestimmungen | Datenschutz | Impressum

Rheinwerk Verlag GmbH, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, service@rheinwerk-verlag.de

Cookie-Einstellungen ändern