Bajt Spis treści Historia | Oznaczenia | Przedrostki | Zobacz też | Przypisy | Menu nawigacyjneBity i bajtyTimeline Of The IBM Stretch/Harvest Era (1956–1961)byteC++ FAQ LiteInteger Types In C and C++Host Names On-Line
Jednostki informacji
dop.adresowalnajednostka informacjipamięci komputerowejbitówoktetemang.słowo maszynoweICLOdryCDCHoneywell1300EBCDICBCDIBM StretchIBM System/360Intel 800880808086IETFhostówFTPARPANETPDP-10beladecybelukładu SIprzedrostków o mnożniku 1000przedrostków o mnożniku 1024IECbitach na sekundę
Bajt
Przejdź do nawigacji
Przejdź do wyszukiwania
Wielokrotności bajtów | |||||
---|---|---|---|---|---|
Przedrostki dziesiętne (SI) | Przedrostki binarne (IEC 60027-2) | ||||
Nazwa | Symbol | Mnożnik | Nazwa | Symbol | Mnożnik |
kilobajt | KB | 103 = 10001 | kibibajt | KiB | 210 = 10241 |
megabajt | MB | 106 = 10002 | mebibajt | MiB | 220 = 10242 |
gigabajt | GB | 109 = 10003 | gibibajt | GiB | 230 = 10243 |
terabajt | TB | 1012 = 10004 | tebibajt | TiB | 240 = 10244 |
petabajt | PB | 1015 = 10005 | pebibajt | PiB | 250 = 10245 |
eksabajt | EB | 1018 = 10006 | exbibajt | EiB | 260 = 10246 |
zettabajt | ZB | 1021 = 10007 | zebibajt | ZiB | 270 = 10247 |
jottabajt | YB | 1024 = 10008 | jobibajt | YiB | 280 = 10248 |
Bajt (dop. bajtu lub bajta[1]) – najmniejsza adresowalna jednostka informacji pamięci komputerowej, składająca się z bitów.
Zwykle przyjmuje się, że jeden bajt to 8 bitów, choć to nie wynika z powyższej definicji. W związku z tym, w praktyce jeden bajt może zawierać dowolną liczbę bitów. Aby uniknąć niejednoznaczności, jednostka składająca się z ośmiu bitów zwana jest również oktetem. Bywa też, że bajt definiuje się jako 8 bitów, a najmniejszą adresowalną jednostkę pamięci – jako znak (ang. char).
W starszych maszynach nie stosowano pojęcia bajt ani oktet, najmniejszą jednostką było słowo maszynowe (np. 24-bitowe w maszynach standardu ICL, jak polskie Odry, albo 60-bitowe w maszynach CDC, czy 36-bitowe w Honeywell). W Odrach serii 1300 rozkazy działające na znakach adresowały pojedynczy znak używając specjalnego dla nich trybu adresowania (dodatkowych 2 bitów adresu znaku w słowie).
Ośmiobitowy bajt można podzielić na dwa czterobitowe nibble lub nybble (od ang. nibble – kęsek) bądź tetrady. Wyróżnia się mniej znaczący (dolny) i bardziej znaczący (górny) nibble/tetradę, składające się odpowiednio z bitów 0–3 i 4–7. Spotyka się też określenie strefa i cyfra wywodzące się od kodowania znaków kodem EBCDIC, oznaczające odpowiednio starszą i młodszą tetradę. Określenia nibble używa się często przy operacjach w kodzie BCD lub skompresowanym BCD.
Spis treści
1 Historia
2 Oznaczenia
3 Przedrostki
4 Zobacz też
5 Przypisy
Historia |
Jako pierwszy, terminu bajt użył Werner Buchholz w lipcu 1956 podczas projektowania komputera IBM Stretch[2][3]. Początkowo oznaczał dane 4-bitowe, co pozwalało na zapis 16 różnych liczb, lecz na etapie produkcji został zredukowany do 3 bitów (8 różnych liczb) – główne operacje komputerowe wykorzystywały bajt 3-bitowy. Bajt 8-bitowy został upowszechniony jako standard wraz z pojawieniem się komputera IBM System/360. Słowo bajt (ang. byte) powstało od angielskiego bite (kęs), jako najmniejsza porcja danych, którą komputer może „ugryźć” za jednym razem (czyli pobrać, zapisać, przetworzyć). Dzięki temu unikano pomyłek z bitem, jednak było to także spowodowane skłonnością ówczesnych naukowców do przeobrażania i tworzenia nowych nazw. Bajt również był nazywany „8-bitowym bajtem” dla podkreślenia, że jest zestawem n bitów, gdyż może składać się także z innej ich liczby:
- Sekwencja sąsiadujących bitów w szeregowym strumieniu danych (modemy, komunikacja satelitarna lub dane z głowicy dysku twardego), która jest najmniejszą jednostką informacji. Takie bajty mogą zawierać bity startu, bity stopu, bity parzystości, składając się z 7 do 12 bitów, wśród których zawarty jest pojedynczy 7-bitowy kod ASCII.
Typ danych w określonych językach programowania. Język C oraz C++ definiują bajt jako „adresowalna jednostka danych, na tyle duża, by można było do niej przypisać każdy znak z zestawu znaków środowiska wykonawczego” (paragraf 3.6 standardu C). Typ danychchar
języka C musi zawierać co najmniej 8 bitów (paragraf 5.2.4.2.1), stąd bajtem może być jedna z 256 różnych wartości (bez względu czy dana tosigned char
czyunsigned char
). Różne implementacje języka C i C++ definiują bajt jako daną 8-, 9-, 16-, 32- lub 36-bitową[4][5]. Właściwa liczba bitów w poszczególnych implementacjach jest podana jako wartośćCHAR_BIT
w pliku nagłówkowymlimits.h
. W Javie bajt jest zawsze zdefiniowany jako 8-bitowy, będący typem danych ze znakiem (ang. signed data type), stąd obejmuje wartości od -128 do 127.
Wczesne mikroprocesory, takie jak Intel 8008 (poprzednik 8080 i 8086), mogły wykonywać niektóre operacje na 4 bitach, takie jak np. DAA (ang. Decimal Adjust after Addition) oraz ustawianie flagi half carry (połowicznego przeniesienia), które służyły do implementacji arytmetyki dziesiętnej[6]. Te 4-bitowe typy danych nosiły nazwę nibble (kęsek).
Historyczne dokumenty IETF opisują różne przykłady bajtów. RFC 608 podaje rozmiar bajta dla hostów FTP (atrybut FTP-BYTE-SIZE w tablicy hostów ARPANET) jako 36 bitów dla komputerów PDP-10 i 32 bity dla IBM 360[7].
Oznaczenia |
Najczęściej stosowanym skrótem dla bajta jest wielka litera B (w odróżnieniu od bitu oznaczanego małą literą b). Takie oznaczenie koliduje wprawdzie z oznaczeniem bela, ale nie sprawia to większych problemów: bela używa się przeważnie z przedrostkiem decy, decybel [dB], niestosowanego (podobnie jak innych podwielokrotności) do bajtów, a poza tym jednostki te występują wyjątkowo rzadko obok siebie.
Można się także spotkać z oznaczeniem bajta małą literą b (bit oznacza się wtedy słowem bit), jednak pokrywa się ono z najpowszechniejszym oznaczeniem bitu i nie jest zalecane.
Przedrostki |
Stosowanie przedrostków kilo, mega, giga itd. jako do określania odpowiednich potęg liczby dwa jest niezgodne z wytycznymi układu SI (słowo kilo oznacza 1000, a nie 1024). W celu odróżnienia przedrostków o mnożniku 1000 od przedrostków o mnożniku 1024, w styczniu 1997 pojawiła się propozycja ujednoznacznienia, opracowana przez IEC, polegająca na dodawaniu litery i po symbolu przedrostka dwójkowego oraz bi po jego nazwie. Nowe przedrostki nazywane zostały przedrostkami dwójkowymi (binarnymi). Jednak ta propozycja rozwiązania problemu niejednoznaczności przedrostków nie została przyjęta przez wszystkie środowiska. Przykładowo producenci nośników pamięci i urządzeń sieciowych (z powodów marketingowych) wolą korzystać z przedrostków układu SI, co bywa źródłem nieporozumień względem faktycznej pojemności pierwszych i prędkości drugich – które podawane są w bitach na sekundę.
Zobacz też |
- kolejność bajtów
- asembler
Przypisy |
↑ Mirosław Bańko: Bity i bajty. Poradnia językowa PWN. [dostęp 2009-02-22].
↑ Timeline Of The IBM Stretch/Harvest Era (1956–1961) (ang.). computerhistory.org. [dostęp 2009-06-16].
↑ byte (ang.). catb.org. [dostęp 2009-06-16].
↑ Marshall Cline: C++ FAQ Lite (ang.). 2 stycznia 2009. [dostęp 2009-06-16].
↑ Jack Klein: Integer Types In C and C++ (ang.). 2008. [dostęp 2011-08-05].
↑ GaryG. Syck GaryG., Turbo Assembler®. Biblia użytkownika, Warszawa: LT&P, 1994, s. 156, ISBN 83-901237-2-X .
↑ M.D. Kudlick: Host Names On-Line (ang.). 10 stycznia 1974. [dostęp 2009-06-16].
Kategoria:
- Jednostki informacji
(window.RLQ=window.RLQ||[]).push(function()mw.config.set("wgPageParseReport":"limitreport":"cputime":"0.172","walltime":"0.227","ppvisitednodes":"value":1612,"limit":1000000,"ppgeneratednodes":"value":0,"limit":1500000,"postexpandincludesize":"value":15151,"limit":2097152,"templateargumentsize":"value":1795,"limit":2097152,"expansiondepth":"value":9,"limit":40,"expensivefunctioncount":"value":1,"limit":500,"unstrip-depth":"value":0,"limit":20,"unstrip-size":"value":4901,"limit":5000000,"entityaccesscount":"value":0,"limit":400,"timingprofile":["100.00% 180.280 1 -total"," 60.91% 109.809 1 Szablon:Przypisy"," 37.79% 68.133 6 Szablon:Cytuj_stronę"," 18.90% 34.067 1 Szablon:Inne_znaczenia"," 16.35% 29.474 1 Szablon:Dmbox"," 14.58% 26.291 1 Szablon:Cytuj"," 14.46% 26.066 2 Szablon:Ikona"," 12.68% 22.859 10 Szablon:Lang"," 6.91% 12.463 1 Szablon:Wikisłownik"," 3.16% 5.693 1 Szablon:Projekt_siostrzany"],"scribunto":"limitreport-timeusage":"value":"0.090","limit":"10.000","limitreport-memusage":"value":3043995,"limit":52428800,"cachereport":"origin":"mw1320","timestamp":"20190416085301","ttl":2592000,"transientcontent":false););"@context":"https://schema.org","@type":"Article","name":"Bajt","url":"https://pl.wikipedia.org/wiki/Bajt","sameAs":"http://www.wikidata.org/entity/Q8799","mainEntity":"http://www.wikidata.org/entity/Q8799","author":"@type":"Organization","name":"Contributors to Wikimedia projects","publisher":"@type":"Organization","name":"Wikimedia Foundation, Inc.","logo":"@type":"ImageObject","url":"https://www.wikimedia.org/static/images/wmf-hor-googpub.png","datePublished":"2004-01-02T18:11:00Z"(window.RLQ=window.RLQ||[]).push(function()mw.config.set("wgBackendResponseTime":158,"wgHostname":"mw1238"););