Heim >Backend-Entwicklung >Golang >Unterschied in den Ergebnissen bitweiser Verschiebungsberechnungen

Unterschied in den Ergebnissen bitweiser Verschiebungsberechnungen

WBOY
WBOYnach vorne
2024-02-08 21:11:131091Durchsuche

Unterschied in den Ergebnissen bitweiser Verschiebungsberechnungen

PHP-Editor Zimo bringt Ihnen einen Artikel über „Der Unterschied in den Ergebnissen der bitweisen Verschiebungsberechnung“. In der Computerprogrammierung ist die Bitverschiebungsoperation eine übliche Operation, mit der Binärzahlen nach links oder rechts verschoben werden können. Verschiedene Programmiersprachen können jedoch Unterschiede bei der Verarbeitung der Ergebnisse von Verschiebungsoperationen aufweisen, was von Entwicklern besondere Aufmerksamkeit erfordert. In diesem Artikel werden die Unterschiede in den Ergebnissen von Verschiebungsoperationen in verschiedenen Programmiersprachen detailliert vorgestellt und einige Beispiele bereitgestellt, um den Lesern zu helfen, Verschiebungsoperationen besser zu verstehen und anzuwenden. Unabhängig davon, ob Sie Anfänger oder Entwickler mit Programmierkenntnissen sind, können Sie sich in diesem Artikel nützliche Kenntnisse und Fähigkeiten aneignen.

Frageninhalt

Es gibt Unterschiede in der Ausgabe meines Go-Programms, insbesondere bei den Variablen x1 und x2. Hier ist der entsprechende Codeausschnitt:

package main

var n uint = 10
const N uint = 10

func main() {
    var x1 byte = (1 << n) / 100
    var x2 byte = (1 << N) / 100
    println(x1, x2)
}

Erwartete Ausgabe: 10 10

Tatsächliche Ausgabe: 0 10

Seien Sie neugierig auf die Gründe für die Unterschiede und suchen Sie nach Erklärungen.

Problemumgehung

Konstante Ausdrücke werden mit nicht spezifizierter Genauigkeit ausgewertet. Zugeordnet zu x2 的所有内容都是恒定的,因此它可以正确计算 210 / 100 = 1024 / 100 = 10。而在第一个表达式中,1 被视为 byte,这意味着它会立即移出。 1 必须被视为 byte in Spezifikation :

Wenn der linke Operand eines nicht konstanten Verschiebungsausdrucks eine untypisierte Konstante ist, wird er zunächst implizit in den Typ konvertiert, der angenommen wird, wenn der Verschiebungsausdruck nur durch seinen linken Operanden ersetzt wird.

1 ist die untypisierte Konstante auf der linken Seite, nvar 使得表达式变得非常量,因此 1 必须具有其受让人 x1 的类型,即 byte.

Das obige ist der detaillierte Inhalt vonUnterschied in den Ergebnissen bitweiser Verschiebungsberechnungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:stackoverflow.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen