Academic Tutorials



English | French | Portugese | Dutch | Italian
Google

on-line

Haupt Quellenprogramme E-Bücher Downloads Mit uns in Verbindung treten Über uns

HTML Tutorials
HTML Tutorial
XHTML Tutorial
CSS Tutorial
TCP/IP Tutorial
XML Tutorials
XML Tutorial
XSL Tutorial
XSLT Tutorial
DTD Tutorial
Schema Tutorial
XForms Tutorial
XSL-FO Tutorial
XML DOM Tutorial
XLink Tutorial
XQuery Tutorial
XPath Tutorial
XPointer Tutorial
RDF Tutorial
SOAP Tutorial
WSDL Tutorial
RSS Tutorial
WAP Tutorial
Web Services Tutorial
Browser Scripting
JavaScript Tutorial
VBScript Tutorial
AJAX Tutorial
DHTML Tutorial
HTML DOM Tutorial
WMLScript Tutorial
E4X Tutorial
Server Scripting
ASP Tutorial
PHP Tutorial
PERL Tutorial
SQL Tutorial
ADO Tutorial
.NET (dotnet)
Microsoft.Net
XML Web Services
ASP.Net
.Net Mobile
C# : C Sharp
ADO.NET
VB.NET
Multimedia
SVG Tutorial
Flash Tutorial
Media Tutorial
SMIL Tutorial
Web Building
Web Browsers
Web Hosting
W3C Tutorial
Web Building
Web Quality
Web Semantic
Web Careers
Java Tutorials
Java Tutorial
JSP Tutorial
Servlets Tutorial
Struts Tutorial
EJB Tutorial
JMS Tutorial
JMX Tutorial
Programming Langauges
C Tutorial
C++ Tutorial
Visual Basic Tutorial
Data Structures Using C
Soft Skills
Communication Skills
Time Management
Project Management
Team Work
Leadership Skills
Corporate Communication
Negotiation Skills


Dynamische Speicherallozierung in C
Previous Next




Was ist dynamische Speicherallozierung?

  • Dynamische Speicherallozierung wird als die dynamisch Verteilung des Raumes für Variablen an der Laufzeit definiert.


  • Es ist kostspielig beim Beschäftigen Reihe Art Strukturen, Raum soviel zuzuteilen, wenn es erklärt wird



  • Fünf ANSI Standartd Funktion verwendet in der dynamischen Speicherallozierung

    ANSI C liefert fünf Standardfunktionen, die dir helfen, Gedächtnis auf dem Haufen zuzuteilen, die sind, wie folgt:

    1. sizeof()
    2. malloc()
    3. calloc()
    4. realloc()
    5. free()




    Die folgende Tabelle beschreiben die fünf unterschiedlichen Standardfunktionen, denen Hilfen du Gedächtnis dynamisch zuteilen
    Function Task
    sizeof The sizeof() function returns the memory size of the requested variable
    malloc Allocates memory requests size of bytes and returns a pointer to the Ist byte of allocated space
    calloc Allocates space for an array of elements initializes them to zero and returns a pointer to the memory
    free Frees previously allocated space
    realloc Modifies the size of previously allocated space.



    sizeof ()

    Die sizeof () Funktion bringt die Speichergröße der erbetenen Variable zurück. Dieser Anruf sollte im Zusammenhang mit dem calloc () Funktion Anruf, damit nur das notwendige Gedächtnis zugeteilt wird, anstatt in einer örtlich festgelegten Größe verwendet werden. Das folgende betrachten,

    struct date {
    int hour, minute, second;
    };

    int x;

    x = sizeof( struct date );



    malloc ()

    Ein Block mf Gedächtnis kann mit der Funktion zugeteilt werden, die malloc genannt wird. Die malloc Funktion hebt einen Block des Gedächtnisses der spezifizierten Größe auf und bringt einen Zeiger der Art Lücke zurück. Dies heißt, daß wir es irgendeiner Art Zeiger zuweisen können. Es nimmt die folgende Gestalt an:

    ptr=(cast-type*)malloc(byte-size);

    PTR ist ein Zeiger der Art Werfenart, die das malloc einen Zeiger (der geworfenen Art) zu einem Bereich des Gedächtnisses mit der Größe Bytegröße zurückbringt. Das folgende ist das Beispiel des Verwendens von malloc Funktion

    x=(int*)malloc(100*sizeof(int));



    calloc ()

    Calloc ist eine andere Speicherallozierungfunktion, die normalerweise verwendet, um um die mehrfachen Blöcke der Ablage jeden zu bitten der gleichen Größe und dann alle Bytes auf Null stellt wird. Die allgemeine Form von calloc ist:

    ptr=(cast-type*) calloc(n,elem-size);

    Die oben genannte Aussage teilt angrenzenden Raum für n Blöcke jede Größe der Elementgröße Bytes zu. Alle Bytes werden bis null initialisiert und ein Zeiger zum ersten Byte der zugeteilten Region wird zurückgebracht. Wenn es nicht genügend Raum gibt, wird ein ungültiger Zeiger auch zurückgebracht.




    realloc ()

    Das Gedächtnis, das zugeteilt wurde, indem es calloc oder malloc verwendete, konnte unzulänglich oder überfluß in beiden Situationen manchmal sein, die wir die Speichergröße ändern können, die bereits mit Hilfe der Funktion zugeteilt wird, die realloc genannt wird. Dieser Prozeß wird die Neuverteilung des Gedächtnisses genannt. Die allgemeine Aussage über Neuverteilung des Gedächtnisses ist:

    ptr=realloc(ptr,newsize);



    freigeben ()

    Kompilierzeitspeicher einer Variable wird zugeteilt und freigegeben durch das System in übereinstimmung mit seiner Speicherkategorie. Mit der dynamischen Laufzeitverteilung ist es unsere Verantwortlichkeit, den Raum freizugeben, wenn es nicht an allen angefordert wird. Wenn die Ablage begrenzt ist, wird die Freigabe des Speicherplatzes wichtig. Wenn wir nicht mehr die Daten benötigen, die wir in einem Block des Gedächtnisses speicherten und wir beabsichtigen nicht zu verwenden, daß Block für die Speicherung aller möglicher anderen Informationen mit der freien Funktion, wir diesen Block des Gedächtnisses für zukünftigen Gebrauch freigeben kann.

    free(ptr);

    PTR ist ein Zeiger, der hergestellt worden ist, indem man calloc oder malloc verwendete.




    Das folgende Programm veranschaulichen die Neuverteilung des Gedächtnisses mit realloc () und malloc ()
    /*Example program for reallocation*/

    #include< stdio.h >
    #include< stdlib.h >
    define NULL 0
    main()
    {
    char *buffer;
    /*Allocating memory*/
    if((buffer=(char *) malloc(10))==NULL)
    {
    printf("Malloc failed\n");
    exit(1);
    }
    printf("Buffer of size %d created \n",_msize(buffer));
    strcpy(buffer,Bangalore);
    printf(\nBuffer contains:%s\n,buffer);
    /*Reallocation*/
    if((buffer=(char *)realloc(buffer,15))==NULL)
    {
    printf("Reallocation failed\n");
    exit(1);
    }
    printf("\nBuffer size modified".\n);
    printf("\nBuffer still contains: %s\n",buffer);
    strcpy(buffer,Mysore);
    printf("\nBuffer now contains:%s\n",buffer);
    /*freeing memory*/
    free(buffer);
    }




    Previous Next

    Schlüsselwörter: Dynamische Speicherallozierung in C, dynamische Speicherallozierung in c++, c Reihen, c Tutorial, c Reihe, leeres c, c Syntax, Unix Gedächtnis, Wertverteilung, C-Sprache, Rückholc, Gedächtnisart, dynamisches Beispiel, dynamischer Algorithmus, dynamischer Tutorial, c Beispiel, c Algorithmus, variables c, c Art, c Programm, Speichergröße, Unix c


    HTML Quizes
    HTML Quiz
    XHTML Quiz
    CSS Quiz
    TCP/IP Quiz
    XML Quizes
    XML Quiz
    XSL Quiz
    XSLT Quiz
    DTD Quiz
    Schema Quiz
    XForms Quiz
    XSL-FO Quiz
    XML DOM Quiz
    XLink Quiz
    XQuery Quiz
    XPath Quiz
    XPointer Quiz
    RDF Quiz
    SOAP Quiz
    WSDL Quiz
    RSS Quiz
    WAP Quiz
    Web Services Quiz
    Browser Scripting Quizes
    JavaScript Quiz
    VBScript Quiz
    AJAX Quiz
    DHTML Quiz
    HTML DOM Quiz
    WMLScript Quiz
    E4X Quiz
    Server Scripting Quizes
    ASP Quiz
    PHP Quiz
    PERL Quiz
    SQL Quiz
    ADO Quiz
    .NET (dotnet) Quizes
    Microsoft.Net Quiz
    XML Web Services Quiz
    ASP.Net Quiz
    .Net Mobile Quiz
    C# : C Sharp Quiz
    ADO.NET Quiz
    VB.NET Quiz
    Multimedia Quizes
    SVG Quiz
    Flash Quiz
    Media Quiz
    SMIL Quiz
    Web Building  Quizes
    Web Browsers Quiz
    Web Hosting Quiz
    W3C Quiz
    Web Building Quiz
    Web Quality Quiz
    Web Semantic Quiz
    Web Careers Quiz
    Java Quizes
    Java Quiz
    JSP Quiz
    Servlets Quiz
    Struts Quiz
    EJB Quiz
    JMS Quiz
    JMX Quiz
    Programming Langauges Quizes
    C Quiz
    C++ Quiz
    Visual Basic Quiz
    Data Structures Using C Quiz
    Soft Skills Quizes
    Communication Skills Quiz
    Time Management Quiz
    Project Management Quiz
    Team Work Quiz
    Leadership Skills Quiz
    Corporate Communication Quiz
    Negotiation Skills Quiz

    Privacy Policy
    Copyright © 2003-2008 Vyom Technosoft Pvt. Ltd., All Rights Reserved.