Kā izmantot Try Catch paziņojumus C

Ka Izmantot Try Catch Pazinojumus C



Vārdi “izmēģināt” un “noķert” norāda, kā rīkoties, ja programma saskaras ar izņēmumu koda vai datu problēmas dēļ. Izņēmumi tiek risināti a mēģināt koda bloks. Noķeršanas bloki tiek izmantoti, lai atrastu un apstrādātu izņēmumus no izmēģinājuma blokiem. Ietver daudzas programmēšanas valodas, tostarp Python, C++ un JavaScript mēģināt-ķert paziņojumi.

Šis raksts parāda, kas ir try-catch priekšraksts un kā tas tiek ieviests, izmantojot piemēru C programmēšanā.

Kas ir izmēģināšanas nozvejas paziņojums?

The mēģināt paziņojums definē paziņojumu kopumu, kas var radīt izņēmumu. Ja notiek noteikta veida izņēmums, izņēmuma nosūtīšanas vieta ir uztveršanas bloks. Kompilators vai nu izvadīs kļūdas paziņojumu, vai arī izņēmums turpinās ceļot augšup pa izsaukuma steku, līdz tas tiks novērsts, ja try/catch bloks to nevar apstrādāt.







Vispārējā sintakse mēģināt-ķert paziņojums tiek sniegts šādi:



mēģināt {
/*
Ievietojiet kodu, kas, iespējams, radīs kļūdas
*/
}
noķert {
/*
Uzrakstiet kodu priekš radītās kļūdas.
*/
}

Kas ir try-catch paziņojums valodā C?

C neatbalsta izņēmumu apstrādi un tam nav iebūvēta mehānisma, lai to izdarītu. Tomēr jūs varat to zināmā mērā simulēt, izmantojot setjmp un longjmp zvani. Ja nav iespējas atbrīvot atmiņu, kad steka ir apmeklēta, izņēmumu apstrādes mehānismi ir neefektīvi un nedroši, un C nav atkritumu savācēja. Lai atbrīvotu RAM, mums, iespējams, būs jāintegrē arī konteksta pārvaldnieki.



Tagad, veicot koda uzlabojumus, mēs pakāpeniski izstrādāsim risinājumu. Longjmp un setjmp ir divas C funkcijas, kuras var nodrošināt setjmp.h galvenes fails, ko mēs izmantosim. Funkcija setjmp pieņem jmp_buf tipa mainīgos un atgriež 0, kad tā tiek tieši izsaukta. Ja to pašu jmp_buf mainīgo izmanto, lai izsauktu longjmp ar diviem mainīgajiem, funkcija setjmp atgriež vērtību, kas atbilst longjmp otrā argumenta vērtībai.





Iepriekš minētās ieviešanas piemērs ir sniegts šādi:

#include
#include
#define TRY do { jmp_buf buf_state; if ( !setjmp(buf_state)) {
#define CATCH } else {
#define ENDTRY }} while(0)
#define THROW longjmp(buf_state, 1)
int galvenais ( )
{
MĒĢINĀT {
printf ( 'Izmēģiniet paziņojumu pārbaudi \n ' ) ;
mest;
printf ( 'Paziņojums nedrīkst parādīties, jo THOW bloks jau ir iemetis izņēmumu \n ' ) ;
}
NOZVEJO {
printf ( 'Ir izņēmums \n ' ) ;
}
ENDTRY;
atgriezties 0 ;
}

Iepriekš minētajā C programmā ENDTRY funkcija tiek izmantota, lai nodrošinātu do-while bloka noslēguma daļu.



Secinājums

Ja programma saskaras ar izņēmumu datu vai kodēšanas kļūdas dēļ tās darbības laikā, ' mēģināt ' un ' noķert ” aprakstiet, kā to pārvaldīt. Iekšā mēģināt koda bloks, izņēmumi notiek, kamēr a noķert bloks ir no kurienes rodas kļūdas mēģināt bloki tiek atrasti un apstrādāti. Daudzas programmēšanas valodas atbalsta mēģināt-ķert bloķē, bet C ne. Šajā rokasgrāmatā ir aprakstīta metode try-catch paziņojumu izmantošanai C programmēšanā.