Hat die Linux-C-Sprache Bits?

藏色散人
Freigeben: 2023-03-28 10:57:51
Original
1809 Leute haben es durchsucht

Die C-Sprache von Linux verfügt über ein Bit. In der C-Sprache des Mikrocontrollers ist Bit ein neues Schlüsselwort, das häufig zum Definieren von Bittypdaten in der C-Sprache verwendet wird: 1. Definieren Sie über Sbit oder Bit; 2. Definiert durch Bitfelder (in Strukturen); 3. Definiert durch kombinierte Bitoperatoren.

Hat die Linux-C-Sprache Bits?

Die Betriebsumgebung dieses Tutorials: Linux5.9.8-System, Dell G3-Computer.

Gibt es etwas für die C-Sprache von Linux?

Ja.

C-Sprache definiert Bittypdaten:

1. Definieren Sie über sbit oder bit

sbit wird dem IO-Port zugeordnet (das „Bit“ des IO-Ports wie P1^1)

bit kann gefunden werden im RAM Im Adressraum wird es im Allgemeinen als Flag-Bit zur Programmbeurteilung verwendet.

Denken Sie, dass einer von ihnen extern (sbit) und der andere intern (bit) ist.

In der Mikrocontroller-C-Sprache ist Bit ein neues Schlüsselwort, das häufig zur Definition einer „Bitvariablen“ verwendet wird

2. Definition durch Bitfelder (in Strukturen)

Definition von Bitfeldern und Beschreibung von Bitfeldvariablen Das Bitfeld Die Definition ähnelt der Strukturdefinition und hat die Form: Strukturbitfeldstrukturname

{Bitfeldliste}

Die Bitfeldliste hat die Form: Typspezifizierer Bitdomänenname: Bitfeldlänge

Zum Beispiel :

struct bs 
{ 
 int a:8; 
 int b:2; 
 int c:6; 
};
Nach dem Login kopieren

  Bitfeldvariablen werden auf die gleiche Weise wie Strukturvariablen deklariert. Sie können zuerst definieren und dann erklären, gleichzeitig definieren und erklären oder direkt erklären. Beispiel:

struct bs 
{ 
 int a:8; 
 int b:2; 
 int c:6; 
}data;
Nach dem Login kopieren

 Gibt an, dass es sich bei den Daten um eine Bs-Variable handelt, die insgesamt zwei Bytes belegt. Bitfeld a belegt 8 Bits, Bitfeld b belegt 2 Bits und Bitfeld c belegt 6 Bits. Für die Definition von Bitfeldern gibt es mehrere Erklärungen:

 1. Ein Bitfeld muss im selben Byte gespeichert werden und darf sich nicht über zwei Bytes erstrecken. Wenn der verbleibende Platz eines Bytes nicht ausreicht, um ein weiteres Bitfeld zu speichern, sollte das Bitfeld von der nächsten Einheit gespeichert werden. Sie können ein Bitfeld auch gezielt ab der nächsten Einheit beginnen. Beispiel:

struct bs 
{ 
 unsigned a:4 
 unsigned :0 /*空域*/ 
 unsigned b:4 /*从下一单元开始存放*/ 
 unsigned c:4 
}
Nach dem Login kopieren

In dieser Bitfelddefinition belegt a 4 Bits des ersten Bytes, füllen Sie die letzten 4 Bits mit 0 auf, um anzuzeigen, dass es nicht verwendet wird, b beginnt ab dem zweiten Byte und belegt 4 Bits, und c belegt 4 Bits .

 2. Da das Bitfeld nicht zwei Bytes umfassen darf, darf die Länge des Bitfelds nicht größer als die Länge eines Bytes sein, was bedeutet, dass es 8 Binärbits nicht überschreiten darf.

  3. Das Bit-Feld kann keinen Bit-Domänennamen haben. In diesem Fall wird es nur zum Füllen oder Anpassen der Position verwendet. Unbenannte Bitfelder können nicht verwendet werden. Zum Beispiel:

struct k 
{ 
 int a:1 
 int :2 /*该2位不能使用*/ 
 int b:3 
 int c:2 
};
Nach dem Login kopieren

Aus der obigen Analyse können wir erkennen, dass das Bitfeld im Wesentlichen ein Strukturtyp ist, seine Mitglieder jedoch in binären Bits zugeordnet sind.

  2. Die Verwendung von Bitfeldern

Die Verwendung von Bitfeldern ist die gleiche wie die Verwendung von Strukturmitgliedern. Die allgemeine Form ist: Bitfeld-Variablenname • Bitdomänenname. Bitfelder ermöglichen die Ausgabe in verschiedenen Formaten.

main(){ 
 struct bs 
 { 
  unsigned a:1; 
  unsigned b:3; 
  unsigned c:4; 
 } bit,*PBit; 
 bit.a=1; 
 bit.b=7; 
 bit.c=15; 
 printf("%d,%d,%d\n",bit.a,bit.b,bit.c); 
 PBit=&bit; 
 PBit->a=0; 
 PBit->b&=3; 
 PBit->c|=1; 
 printf("%d,%d,%d\n",PBit->a,PBit->b,PBit->c); 
}
Nach dem Login kopieren

 Das obige Beispielprogramm definiert die Bitfeldstruktur bs und die drei Bitfelder sind a, b und c. Die Variable Bit vom Typ bs und die Zeigervariable PBit, die auf den Typ bs zeigt, werden erläutert. Das bedeutet, dass Bitfelder auch Zeiger verwenden können.

  Die Zeilen 9, 10 und 11 des Programms weisen jeweils drei Bitfeldern Werte zu. (Es ist zu beachten, dass die Zuweisung den zulässigen Bereich des Bitfeldes nicht überschreiten darf) Zeile 12 des Programms gibt den Inhalt der drei Felder im Integer-Format aus. Zeile 13 sendet die Adresse der Bitfeldvariablen bit an die Zeigervariable PBit. Zeile 14 verwendet einen Zeiger, um das Bitfeld a auf 0 umzuordnen. Zeile 15 verwendet den zusammengesetzten Bitoperator „&=". Diese Zeile entspricht: PBit->b=PBit->b&3. Der ursprüngliche Wert im Bitfeld b ist 7 und das Ergebnis der bitweisen UND-Verknüpfung mit 3 ist 3 (111&011=011, Dezimalwert ist 3). In ähnlicher Weise wird in Zeile 16 des Programms die zusammengesetzte Bitoperation „|=" verwendet, die äquivalent ist zu: PBit->c=PBit->c|1 und das Ergebnis ist 15. Zeile 17 des Programms gibt die Werte dieser drei Felder mithilfe von Zeigern aus.

Der Hauptzweck der Verwendung von Bitfeldern besteht darin, den Speicher zu komprimieren. Die allgemeinen Regeln sind:

1) Wenn benachbarte Bitfeldfelder vom gleichen Typ sind und die Summe ihrer Bitbreiten kleiner als die Größe des Typs ist, Die nachfolgenden Felder werden unmittelbar neben den vorherigen gespeichert, bis sie nicht mehr untergebracht werden können.

2) Wenn benachbarte Bitfeldfelder vom gleichen Typ sind, aber die Summe ihrer Bitbreiten größer als die Größe von ist der Typ, die nachfolgenden Felder beginnen bei einer neuen Speichereinheit, deren Offset ein ganzzahliges Vielfaches ihrer Typgröße ist

3) Wenn Bitfeldfelder mit Nicht-Bitfeldfeldern durchsetzt sind, wird keine Komprimierung durchgeführt

4) Die Gesamtgröße der gesamten Struktur ist ein ganzzahliges Vielfaches der Größe des breitesten Elements des Basistyps.

3. Arbeiten Sie durch Kombination von Bitoperatoren

#define Setbit(x,y)  (x|=(0x01<<y))   //置位
#define Clrbit(x,y)  (x&=(~(0x01<<y)))  //复位(清零)
#define Chkbit(x,y)  (x&(0x01<<y))     //检位
Nach dem Login kopieren

Empfohlenes Lernen: „

Linux-Video-Tutorial

Das obige ist der detaillierte Inhalt vonHat die Linux-C-Sprache Bits?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage