logo

FUNKTIONSPROTOTYPE I C

Introduktion:

I C-programmering, en funktion prototype bruges til at erklære Underskrift af en funktion, som omfatter dens navn, returtype , og parametre . Funktionsprototyper er vigtige, fordi de informerer compileren om funktionens grænseflade, før den kaldes, hvilket giver mulighed for korrekt typekontrol og fejlhåndtering. I denne artikel vil vi diskutere vigtigheden af ​​funktionsprototyper i C-programmering, og hvordan de bruges.

Hvorfor bruge funktionsprototyper?

Funktionsprototyper er vigtige i C-programmering af flere grunde. En af de vigtigste grunde er, at de tillader compiler for at tjekke for fejl, før programmet rent faktisk udføres. Hvis en funktion kaldes med det forkerte antal eller type argumenter, vil compileren generere en fejl besked , hvilket forhindrer programmet i at gå ned eller opfører sig uventet under kørsel.

En anden vigtig grund til at bruge funktionsprototyper er at muliggøre modulær programmering. I C er funktioner typisk defineret i separate filer fra hovedprogrammet, og er knyttet sammen på kompileringstidspunktet. Ved at deklarere funktionsprototyper i header-filer, der er inkluderet i både hovedprogrammet og funktionsdefinitionsfilerne, kan funktionen kaldes fra enhver del af programmet uden at kræve adgang til funktionens implementeringsdetaljer.

Funktionsprototyper også gøre det nemmere at læse og forstå koden. Ved at inkludere funktionens signatur i kildekoden, kan andre udviklere nemt se, hvad funktionen gør, dens argumenter og dens returtype. Det gør koden mere selvdokumenterende og reducerer sandsynligheden for fejl forårsaget af misforståelser eller fejlfortolkninger af koden.

uordensgennemgang af binært træ

Syntaks for funktionsprototype:

Syntaksen for en funktionsprototype i C-programmering er som følger:

 return_type function_name(parameter_list); 

Det return_type er den datatype, som funktion vender tilbage , såsom int, flyde , eller char . Det funktionsnavn er navnet på fungere , og parameterliste er en kommasepareret liste over parametre som funktionen tager. Hver parameter i parameterliste består af en datatype efterfulgt af parameternavn .

For eksempel er det følgende en funktionsprototype for en funktion, der kræver to heltal som argumenter og returnerer deres sum:

 int add(int num1, int num2); 

I dette eksempel er returtypen int , funktionsnavnet er tilføje , og parameterlisten består af to navngivne heltal nummer 1 og nummer 2 .

Standard funktionsprototyper:

I C-programmering, hvis en funktion kaldes før den er det defineret eller erklæret , vil compileren antage en standard funktionsprototype. Det standard funktionsprototype antager, at funktionen returnerer en int og tager et vilkårligt antal argumenter af enhver type.

Overvej f.eks. følgende kode:

 #include int main() { printf('The sum is %d
', add(2, 3)); return 0; } int add(int num1, int num2) { return num1 + num2; } 

Produktion:

 The sum is 5 

Forklaring:

I denne kode er tilføje funktion kaldes før det er erklæret eller defineret . Men fordi compileren antager en standardfunktionsprototype, kompilerer programmet uden fejl og producerer det korrekte output.

Selvom standardfunktionsprototyper nogle gange er praktiske, anbefales de generelt ikke, fordi de kan føre til subtile fejl og fejl. Det er bedste praksis at deklarere funktionsprototyper eksplicit for at undgå potentielle problemer.

Funktionsprototyper og header-filer:

I C-programmering, funktionsprototyper er ofte inkluderet i header-filer, som så indgår i både hovedprogrammet og funktionsdefinitionsfilerne. Det gør det muligt at kalde funktioner fra enhver programdel uden at kræve adgang til funktionens implementeringsdetaljer.

Header-filer har typisk en .h udvidelse , og omfatter kun funktionsprototyper , type definitioner , og andre erklæringer som er nødvendige for hovedprogrammet eller andre filer. Her er et eksempel på en header-fil, der erklærer tilføjelsesfunktionen fra tidligere:

 #ifndef ADD_H #define ADD_H int add(int num1, int num2) 

I dette eksempel er ifndef direktiv kontrollerer om ADD_H er allerede defineret. Hvis den ikke har, definerer den ADD_H og fortsætter med at inkludere funktionsprototypen til tilføjelse.

Det Definere direktiv skaber en makro som hedder ADD_H , som kan bruges til at sikre, at header-filen kun er inkluderet én gang i hver fil. Det er vigtigt at forhindre flere deklarationer af samme funktion, hvilket kan forårsage fejl. Det funktion prototype for add erklærer blot, at funktionen tager to heltal som argumenter og returnerer et heltal. Det er nok information til, at hovedprogrammet og andre filer kan kalde tilføjelsesfunktionen korrekt uden at vide, hvordan den implementeres.

Når en header-fil er inkluderet i en C program , det præprocessor erstatter #omfatte direktiv med indholdet af header-fil . Det giver hovedprogrammet og andre filer adgang til funktionsprototyperne og andre erklæringer i header-filen.

Nogle vigtige punkter i funktionsprototypen i C:

Funktionsprototyper hjælper med at fange fejl:

Når en funktion prototype er inkluderet i et C-program, kontrollerer compileren, at funktionen bruges korrekt, inden programmet køres. Det hjælper med at fange fejl tidligt, før programmet køres.

Funktionsprototyper er essentielle i store programmer:

git status -s

I store programmer er det vigtigt at adskille bekymringer mellem forskellige funktioner klart. Funktionsprototyper muliggør denne adskillelse ved at tillade, at hver funktion udvikles uafhængigt uden at kende implementeringsdetaljerne for andre funktioner.

Funktionsprototyper kan erklæres i header-filer:

Som tidligere nævnt er funktionsprototyper typisk deklareret i header-filer. Header-filer er så inkluderet i både hovedprogrammet og funktionsdefinitionsfilerne, hvilket gør funktionerne tilgængelige fra enhver del af programmet.

Funktionsprototyper kan overbelastes:

C understøtter ikke funktionsoverbelastning som nogle andre programmeringssprog, men funktionsprototyper kan overbelastes ved at bruge forskellige argumenttyper og tal. Det gør det muligt at bruge det samme funktionsnavn til forskellige formål.

Funktionsprototyper kan inkludere standard argumentværdier:

C understøtter ikke standardargumentværdier som nogle andre programmeringssprog, men funktionsprototyper kan inkludere valgfrie argumenter ved at bruge en speciel syntaks. Det gør det muligt at bruge den samme funktion med eller uden bestemte argumenter.

Funktionsprototyper kan fremad-deklareres:

I nogle tilfælde kan det være nødvendigt at deklarere en funktionsprototype, før dens implementering er tilgængelig. Det kaldes fremsende erklæring og kan være nyttige i komplekse programmer, hvor implementeringen af ​​en funktion måske ikke er kendt på tidspunktet for dens erklæring.

Her er et par flere eksempler på funktionsprototyper i C-programmering:

Eksempel 1:

 #include float calculate_average(int arr[], int size); int main() { int arr[] = {1, 2, 3, 4, 5}; int size = 5; float average = calculate_average(arr, size); printf(&apos;The average is: %.2f&apos;, average); return 0; } float calculate_average(int arr[], int size) { float sum = 0.0; for (int i = 0; i<size; i++) { sum +="arr[i];" } return size; < pre> <p> <strong>Output:</strong> </p> <pre> The average is: 3.00 </pre> <p> <strong>Explanation:</strong> </p> <p>In this example, we first declare the <strong> <em>calculate_average</em> </strong> function prototype at the beginning of our program before the main function. After that, inside the main function, we declare an integer array <strong> <em>arr</em> </strong> with some values and a size of <strong> <em>5</em> </strong> . After that, we call the <strong> <em>calculate_average function</em> </strong> , passing in the <strong> <em>arr array</em> </strong> and its size, and store the result in a <strong> <em>float variable</em> </strong> named <strong> <em>average</em> </strong> . Finally, we print out the result using printf.</p> <p>The <strong> <em>calculate_average</em> </strong> function takes in the integer <strong> <em>array arr</em> </strong> and its size as arguments and returns the average value of the array as a <strong> <em>float</em> </strong> . We first declare a float variable named <strong> <em>sum</em> </strong> inside the function and initialize it to <strong> <em>0.0</em> </strong> . After that, we loop through each element in the array using a <strong> <em>for loop</em> </strong> , adding each element to the sum variable. Finally, we return the result of dividing the sum variable by the array size.</p> <p>Its average is <strong> <em>3.00</em> </strong> because the <strong> <em>arr</em> </strong> array contains the values <strong> <em>{1, 2, 3, 4, 5}</em> </strong> , and the average of these values is <strong> <em>(1+2+3+4+5)/5 = 3.00</em> </strong> . The <strong> <em>printf</em> </strong> statement in the main function uses the <strong> <em>%f format specifier</em> </strong> to print out the average value as a floating-point number. The <strong> <em>.2 modifier</em> </strong> specifies that we want to print only two decimal places.</p> <p> <strong>Example 2:</strong> </p> <pre> #include void print_message(char *msg); int main() { char *msg = &apos;Hello, world!&apos;; print_message(msg); return 0; } void print_message(char *msg) { printf(&apos;%s
&apos;, msg); } </pre> <p> <strong>Output:</strong> </p> <pre> Hello, world! </pre> <p> <strong>Explanation:</strong> </p> <p>In this example, we first declare the <strong> <em>print_message</em> </strong> function prototype at the beginning of our program, before the main function. Then, inside the main function, we declare a character pointer <strong> <em>msg</em> </strong> and initialize it to point to a string literal <strong> <em>&apos;Hello, world!&apos;</em> </strong> . After that, we call the <strong> <em>print_message</em> </strong> function, passing in the <strong> <em>msg pointer</em> </strong> .</p> <p>The <strong> <em>print_message</em> </strong> function takes in a character pointer <strong> <em>msg</em> </strong> as an argument, and returns nothing <strong> <em>(void)</em> </strong> . Inside the function, we use the <strong> <em>printf function</em> </strong> to print out the string pointed to by <strong> <em>msg</em> </strong> , followed by a <strong> <em>newline character (
)</em> </strong> . The <strong> <em>%s</em> </strong> format specifier is used to print out a string.</p> <p>The Output is <strong> <em>Hello, world!</em> </strong> . Because the <strong> <em>print_message</em> </strong> function prints out the string pointed to by the <strong> <em>msg pointer</em> </strong> , which in this case is <strong> <em>&apos;Hello, world!&apos;</em> </strong> , followed by a newline character.</p> <p> <strong>Example 3:</strong> </p> <pre> #include int factorial(int n); int main() { int n = 5; int result = factorial(n); printf(&apos;%d! = %d
&apos;, n, result); return 0; } int factorial(int n) { if (n == 0) { return 1; } else { return n * factorial(n-1); } } </pre> <p> <strong>Explanation:</strong> </p> <p>In this example, we first declare the <strong> <em>factorial function</em> </strong> prototype at the beginning of our program, before the main function. Then, inside the main function, we declare an integer variable <strong> <em>n</em> </strong> and initialize it to <strong> <em>5</em> </strong> . After that, we call the factorial function, passing in <strong> <em>n</em> </strong> , and store the result in an integer variable named <strong> <em>result</em> </strong> . Finally, we print out the result using <strong> <em>printf</em> </strong> .</p> <p>The factorial function takes in an integer <strong> <em>n</em> </strong> as an argument, and returns its factorial as an <strong> <em>integer</em> </strong> . Inside the function, we first check if <strong> <em>n</em> </strong> is equal to <strong> <em>0</em> </strong> . If it is, we return <strong> <em>1</em> </strong> , since <strong> <em>0! = 1</em> </strong> by definition. Otherwise, we return <strong> <em>n * factorial(n-1)</em> </strong> , which is the factorial of <strong> <em>n</em> </strong> calculated recursively as the product of <strong> <em>n</em> </strong> and the factorial of <strong> <em>n-1</em> </strong> .</p> <p>The output of the code will be:</p> <pre> 5! = 120 </pre> <p>This is because the <strong> <em>factorial function</em> </strong> calculates <strong> <em>5!</em> </strong> as <strong> <em>5 * 4 * 3 * 2 * 1 = 120</em> </strong> , and this result is printed out using <strong> <em>printf</em> </strong> .</p> <p> <strong>Example 4:</strong> </p> <pre> #include int find_max(int arr[], int size); int main() { int arr[] = {3, 5, 2, 8, 1}; int size = sizeof(arr) / sizeof(int); int max = find_max(arr, size); printf(&apos;The maximum value in the array is: %d
&apos;, max); return 0; } int find_max(int arr[], int size) { int max = arr[0]; for (int i = 1; i max) { max = arr[i]; } } return max; } </pre> <p> <strong>Explanation:</strong> </p> <p>In this example, we first declare the <strong> <em>find_max</em> </strong> function prototype at the beginning of our program, before the main function. Then, inside the main function, we declare an integer <strong> <em>array arr</em> </strong> and initialize it with some values, and a variable size that stores the size of the array. After that, we call the <strong> <em>find_max function</em> </strong> , passing in the <strong> <em>arr array</em> </strong> and <strong> <em>size</em> </strong> , and store the result in an integer variable named <strong> <em>max</em> </strong> . Finally, we print out the result using <strong> <em>printf</em> </strong> .</p> <p>The <strong> <em>find_max function</em> </strong> takes in an integer array <strong> <em>arr</em> </strong> and its size <strong> <em>size</em> </strong> as arguments, and returns the maximum value in the array as an integer. Inside the function, we first initialize a variable max with the first element of the array arr. After that, we loop over the remaining elements of the array using a for loop, comparing each element to the current maximum value using an if statement. If the current element is greater than the current maximum, we update max to the value of the current element. After the loop finishes, we return the final value of max.</p> <p>The <strong> <em>output</em> </strong> of the code will be:</p> <pre> The maximum value in the array is: 8 </pre> <p>This is because the <strong> <em>find_max</em> </strong> function searches through the array <strong> <em>{3, 5, 2, 8, 1}</em> </strong> and finds that the maximum value is <strong> <em>8</em> </strong> , which is then printed out using <strong> <em>printf</em> </strong> .</p> <p>Overall, function prototypes are an essential part of C programming that allow for <strong> <em>modular programming</em> , <em>type checking</em> , <em>error handling</em> </strong> , and <strong> <em>self-documenting code</em> </strong> . By declaring function prototypes, developers can write more robust, maintainable, and error-free code.</p> <p> <strong>Example 5:</strong> </p> <pre> #include void greet_user(char *name); int main() { char name[50]; printf(&apos;What is your name? &apos;); scanf(&apos;%s&apos;, name); greet_user(name); return 0; } void greet_user(char *name) { printf(&apos;Hello, %s! Nice to meet you.
&apos;, name); } </pre> <p> <strong>Explanation:</strong> </p> <p>In this example, we first declare the <strong> <em>greet_user function</em> </strong> prototype at the beginning of our program, before the main function. Then, inside the main function, we declare a character array name with a size of <strong> <em>50</em> </strong> , and use <strong> <em>printf</em> </strong> and <strong> <em>scanf</em> </strong> to ask the user for their name and read it into the name array. After that, we call the <strong> <em>greet_user function</em> </strong> , passing in the name array as an argument.</p> <p>The <strong> <em>greet_user function</em> </strong> takes in a character pointer name as an argument, which is a pointer to the first character of a string. Inside the function, we use <strong> <em>printf</em> </strong> to print out a greeting message that includes the user&apos;s name, and a friendly message.</p> <p>The output of the code will depend on the user&apos;s input. Here&apos;s an example of what the output might look like:</p> <pre> What is your name? suman Hello, suman! Nice to meet you. </pre> <p>In this case, the user enters the name <strong> <em>&apos;suman&apos;</em> </strong> , and the program prints out a greeting message that includes their name.</p> <h2>Conclusion:</h2> <p> <strong> <em>Function prototypes</em> </strong> are an important part of C programming, enabling modular programming, error checking, and self-documenting code. By declaring the signature of a function before it is called, function prototypes allow the compiler to check for errors, enable modular programming, and make code easier to read and understand.</p> <p>In C programming, function prototypes are typically included in <strong> <em>header files</em> </strong> , which are then included in both the main program and the function definition files. It allows functions to be called from any part of the program without requiring access to the function&apos;s implementation details. By understanding the importance of function prototypes and how they are used in C programming, developers can write more robust, maintainable, and error-free code.</p> <hr></size;>

Forklaring:

I dette eksempel erklærer vi først beregne_gennemsnit funktionsprototype i begyndelsen af ​​vores program før hovedfunktionen. Derefter erklærer vi inde i hovedfunktionen et heltalsarray arr med nogle værdier og en størrelse på 5 . Derefter ringer vi til funktionen beregne_gennemsnit , der passerer i arr array og dens størrelse, og gem resultatet i en flyde variabel som hedder gennemsnit . Til sidst udskriver vi resultatet ved hjælp af printf.

Det beregne_gennemsnit funktion tager hele tallet ind række arr og dens størrelse som argumenter og returnerer den gennemsnitlige værdi af arrayet som en flyde . Vi erklærer først en flydende variabel ved navn sum inde i funktionen og initialisere den til 0,0 . Derefter går vi gennem hvert element i arrayet ved hjælp af en for sløjfe , tilføjer hvert element til sumvariablen. Til sidst returnerer vi resultatet af at dividere sumvariablen med matrixstørrelsen.

Dens gennemsnit er 3.00 fordi arr array indeholder værdierne {1, 2, 3, 4, 5} , og gennemsnittet af disse værdier er (1+2+3+4+5)/5 = 3,00 . Det printf sætning i hovedfunktionen bruger %f formatspecifikation at udskrive gennemsnitsværdien som et flydende decimaltal. Det .2 modifikator angiver, at vi kun ønsker at udskrive to decimaler.

Eksempel 2:

 #include void print_message(char *msg); int main() { char *msg = &apos;Hello, world!&apos;; print_message(msg); return 0; } void print_message(char *msg) { printf(&apos;%s
&apos;, msg); } 

Produktion:

 Hello, world! 

Forklaring:

hvordan man sorterer en arraylist i java

I dette eksempel erklærer vi først print_besked funktionsprototype i begyndelsen af ​​vores program, før hovedfunktionen. Derefter, inde i hovedfunktionen, erklærer vi en tegnmarkør besked og initialisere den til at pege på en streng bogstavelig 'Hej Verden!' . Derefter ringer vi til print_besked funktion, der passerer i msg pointer .

Det print_besked funktionen tager en tegnmarkør ind besked som et argument, og returnerer intet (ugyldig) . Inde i funktionen bruger vi printf funktion for at udskrive den streng, der peges på besked , efterfulgt af en nylinjetegn ( ) . Det %s formatspecifikation bruges til at udskrive en streng.

Udgangen er Hej Verden! . Fordi print_besked funktion udskriver strengen, der peges på af msg pointer , hvilket i dette tilfælde er 'Hej Verden!' , efterfulgt af et linjeskifttegn.

Eksempel 3:

 #include int factorial(int n); int main() { int n = 5; int result = factorial(n); printf(&apos;%d! = %d
&apos;, n, result); return 0; } int factorial(int n) { if (n == 0) { return 1; } else { return n * factorial(n-1); } } 

Forklaring:

I dette eksempel erklærer vi først faktoriel funktion prototype i begyndelsen af ​​vores program, før hovedfunktionen. Så inde i hovedfunktionen erklærer vi en heltalsvariabel n og initialisere den til 5 . Derefter kalder vi den faktorielle funktion, der passerer ind n , og gem resultatet i en heltalsvariabel med navnet resultat . Til sidst udskriver vi resultatet vha printf .

Faktorialfunktionen tager et heltal ind n som et argument, og returnerer dets factorial som en heltal . Inde i funktionen tjekker vi først om n er lig med 0 . Hvis det er, vender vi tilbage 1 , siden 0! = 1 Per definition. Ellers vender vi tilbage n * faktor (n-1) , som er factorial af n beregnes rekursivt som produktet af n og factorial af n-1 .

Udgangen af ​​koden vil være:

ram skuespiller
 5! = 120 

Dette er fordi faktoriel funktion beregner 5! som 5 * 4 * 3 * 2 * 1 = 120 , og dette resultat udskrives vha printf .

Eksempel 4:

 #include int find_max(int arr[], int size); int main() { int arr[] = {3, 5, 2, 8, 1}; int size = sizeof(arr) / sizeof(int); int max = find_max(arr, size); printf(&apos;The maximum value in the array is: %d
&apos;, max); return 0; } int find_max(int arr[], int size) { int max = arr[0]; for (int i = 1; i max) { max = arr[i]; } } return max; } 

Forklaring:

I dette eksempel erklærer vi først find_max funktionsprototype i begyndelsen af ​​vores program, før hovedfunktionen. Så inde i hovedfunktionen erklærer vi et heltal række arr og initialisere den med nogle værdier og en variabel størrelse, der gemmer størrelsen af ​​arrayet. Derefter ringer vi til find_max funktion , der passerer i arr array og størrelse , og gem resultatet i en heltalsvariabel med navnet max . Til sidst udskriver vi resultatet vha printf .

Det find_max funktion tager et heltalsarray ind arr og dens størrelse størrelse som argumenter, og returnerer den maksimale værdi i arrayet som et heltal. Inde i funktionen initialiserer vi først en variabel max med det første element i arrayet arr. Derefter sløjfer vi over de resterende elementer i arrayet ved hjælp af en for-løkke, og sammenligner hvert element med den aktuelle maksimale værdi ved hjælp af en if-sætning. Hvis det aktuelle element er større end det aktuelle maksimum, opdaterer vi max til værdien af ​​det aktuelle element. Når løkken er færdig, returnerer vi den endelige værdi på max.

Det produktion af koden vil være:

 The maximum value in the array is: 8 

Dette er fordi find_max funktion søger gennem arrayet {3, 5, 2, 8, 1} og finder, at den maksimale værdi er 8 , som så udskrives vha printf .

Samlet set er funktionsprototyper en væsentlig del af C-programmering, der giver mulighed for modulær programmering , typekontrol , fejlhåndtering , og selvdokumenterende kode . Ved at erklære funktionsprototyper kan udviklere skrive mere robust, vedligeholdelig og fejlfri kode.

Eksempel 5:

 #include void greet_user(char *name); int main() { char name[50]; printf(&apos;What is your name? &apos;); scanf(&apos;%s&apos;, name); greet_user(name); return 0; } void greet_user(char *name) { printf(&apos;Hello, %s! Nice to meet you.
&apos;, name); } 

Forklaring:

I dette eksempel erklærer vi først greet_user funktion prototype i begyndelsen af ​​vores program, før hovedfunktionen. Derefter, inde i hovedfunktionen, erklærer vi et tegnarraynavn med størrelsen på halvtreds , og brug printf og scanf at bede brugeren om deres navn og læse det ind i navnearrayet. Derefter ringer vi til greet_user funktion , der sender navnearrayet som et argument.

Det greet_user funktion tager et tegnmarkørnavn ind som et argument, som er en pointer til det første tegn i en streng. Inde i funktionen bruger vi printf at udskrive en hilsen, der indeholder brugerens navn, og en venlig besked.

Udgangen af ​​koden vil afhænge af brugerens input. Her er et eksempel på, hvordan outputtet kan se ud:

 What is your name? suman Hello, suman! Nice to meet you. 

I dette tilfælde indtaster brugeren navnet 'sumam' , og programmet udskriver en hilsen med deres navn.

Konklusion:

Funktionsprototyper er en vigtig del af C-programmering, hvilket muliggør modulær programmering, fejlkontrol og selvdokumenterende kode. Ved at erklære signaturen af ​​en funktion, før den kaldes, giver funktionsprototyper kompilatoren mulighed for at tjekke for fejl, aktivere modulær programmering og gøre kode lettere at læse og forstå.

I C-programmering indgår funktionsprototyper typisk i header-filer , som så er inkluderet i både hovedprogrammet og funktionsdefinitionsfilerne. Det gør det muligt at kalde funktioner fra enhver del af programmet uden at kræve adgang til funktionens implementeringsdetaljer. Ved at forstå vigtigheden af ​​funktionsprototyper og hvordan de bruges i C-programmering, kan udviklere skrive mere robust, vedligeholdelig og fejlfri kode.