Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: Go, bitwise operations, absolute value, integer, two's complement

Как реализовать абсолютное значение для int без math.Abs?

Вопрос проверяет понимание битовых операций и представления чисел со знаком в Go.

Короткий ответ

Абсолютное значение int без math.Abs можно реализовать с помощью битовых операций. Для int32 используйте маску знака: mask := n >> 31, затем abs := (n + mask) ^ mask. Для int64 сдвиг на 63. Это работает благодаря представлению чисел в дополнительном коде.

Длинный ответ

Реализация абсолютного значения через битовые операции

В Go числа со знаком хранятся в дополнительном коде (two's complement). Старший бит (знаковый) равен 1 для отрицательных чисел и 0 для положительных. Сдвиг вправо на 31 бит для int32 (или 63 для int64) заполняет все биты значением знакового бита, создавая маску: 0 для положительных, -1 (все единицы) для отрицательных.

Формула abs = (n + mask) ^ mask работает так: для положительных n mask=0, результат n. Для отрицательных mask=-1, n + mask = n - 1, затем XOR с -1 инвертирует все биты, что даёт -n - 1 + 1 = -n.

package main

import "fmt"

func absInt32(n int32) int32 {
    mask := n >> 31
    return (n + mask) ^ mask
}

func main() {
    fmt.Println(absInt32(-5))  // 5
    fmt.Println(absInt32(3))   // 3
    fmt.Println(absInt32(0))   // 0
}

Для int64 используйте сдвиг на 63. Этот метод эффективен, так как не использует условные операторы и работает за константное время.

Применение

Такой подход полезен в высокопроизводительном коде, где важна скорость и предсказуемость, например, в обработке сигналов, графике или встраиваемых системах. Однако для обычных приложений math.Abs читаемее и безопаснее.

Вывод: Используйте битовую реализацию abs только при необходимости максимальной производительности и полном понимании работы с дополнительным кодом. В остальных случаях предпочтительнее стандартная функция math.Abs.

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    3

  • Сложность:

    5

Навыки

  • Golang

    Golang

Ключевые слова

#Go

#bitwise operations

#absolute value

#integer

#two's complement

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.