Zakaj ima char 1 bajt v jeziku C

Zakaj Ima Char 1 Bajt V Jeziku C



Kot programer C ste se verjetno spraševali, zakaj je velikost char v jeziku C le 1 bajt. Morda se zdi majhna podrobnost, a iskanje vzroka vam lahko pomaga pri pisanju učinkovitejših programov.

V tem članku se bomo osredotočili na razlog za 1-bajtni char v jeziku C.

Kaj je char v jeziku C

Za shranjevanje znakov in črk C uporablja tip char. Vrednosti znakov (char) v C so shranjene v 1 bajtu pomnilnika in imajo obseg vrednosti od 0 do 255 ali od -128 do 127. Računalnik mora vsako celo število preslikati z ujemajočim se znakom z uporabo številčne kode, da lahko predstavi znake. Najpogosteje uporabljena številčna koda je ASCII, kar pomeni American Standard Code for Information Interchange.







Zakaj ima char 1 bajt v jeziku C

Obstaja več razlogov, zakaj je tip podatkov char 1 bajt:



1 : Prvi razlog je, da je velikost znakov vnaprej določena v standardni knjižnici C. Ne glede na to, kateri prevajalnik uporabljate, bo shranjeval in manipuliral z znaki prek 1-bajtnih vrednosti. Najverjetnejša razlaga je, da se lahko char (binarni) ekvivalent v standardnem naboru znakov prilega enemu samemu bajtu. V času začetnega razvoja C sta bila najpogosteje uporabljena standarda ASCII in EBCDIC, ki sta zahtevala sedem oziroma osem bitno kodiranje. Zato je bil 1 bajt dovolj za simbolizacijo celotnega nabora znakov.



2 : črka ASCII je običajno predstavljena s char, ki vsebuje le 256 znakov. Zato morate navesti le obseg številk od 0 do 255 ali 8 bitov = 1 bajt.





3 : Ker je bil C zasnovan za uporabo v računalnikih s 16-bitnim naslovnim prostorom, je uporaba več kot enega bajta za nize veljala za potratno.

4 : Če imate char 1 bajta v jeziku C, programerjem olajša prenos kode na različne stroje.



5 : Obstaja več programskih jezikov, kot sta Java in C++, ki uporabljajo 1-bajtne znake, kar vam olajša medsebojno delovanje med različnimi jeziki.

Kako najti velikost podatkovnega tipa char

The sizeof lahko uporabite za določitev natančne velikosti tipa ali spremenljivke na določeni platformi. Izraz sizeof(type) vrne velikost pomnilnika predmeta ali vrste v bajtih.

#include
int main ( ) {
char ch;
printf ( 'Velikost znaka: %d bajt \n ' , velikost ( pogl ) ) ;
vrnitev 0 ;
}

V zgornji kodi uporabljamo sizeof funkcijo za iskanje velikosti char v programskem jeziku C, kar je 1 bajt, ki ga potrdi prevajalnik, prikazan v spodnjem izhodu.

Izhod

Prednosti in slabosti 1-bajtnega znaka v jeziku C

Sledijo prednosti 1-bajtnega znaka v jeziku C.

  • Zaradi tega je jezik C učinkovitejši.
  • Naredi jezik C bolj skladen z drugimi jeziki, ki prav tako uporabljajo bajte za tipe znakovnih podatkov.
  • Liki so zdaj lahko podvrženi bolj zapletenim operacijam.

Edina pomanjkljivost, ki jo boste dobili s char 1 bajt, je, da se boste soočili s težavami pri delu z velikimi znaki, ker lahko nekateri jeziki zahtevajo več kot 256 znakov.

Zaključek

V zgornjih smernicah smo videli, da je podatkovni tip char v jeziku C 1 bajt, razlog za to pa je ohranjanje doslednosti na vseh platformah. Če velikost char določite na 1 bajt, lahko iste operacije izvajate na različnih strojih z dosledno natančnostjo, ne glede na to, katero strojno opremo ali prevajalnik uporabljate.