![]() -16 / 0 / 0
Регистрация: 14.04.2022
Сообщений: 82
|
||||||
Почему положительное меньше чем отрицательное?24.09.2022, 18:49. Показов 2195. Ответов 38
почему отрицательное значение int больше чем положительное значение unsigned
0
|
24.09.2022, 18:49 | |
Ответы с готовыми решениями:
38
Минимальное положительное и максимальное отрицательное Найти минимальное положительное и максимальное отрицательное в массиве |
383 / 280 / 112
Регистрация: 28.04.2015
Сообщений: 1,724
|
|
24.09.2022, 19:05 | |
имхо
в выражении a > c разные типы все приведется к беззнаковому типу, т е к unsigned в результате, если взять, что типа unsigned 4байтовый, то будет такое сравнение a > c 232 - 110 > 11111 - true зы: а может все совсем не так... ![]()
1
|
Вездепух
![]() ![]() ![]() 12873 / 6737 / 1810
Регистрация: 18.10.2014
Сообщений: 17,057
|
|
24.09.2022, 21:24 | |
В языке С нет сравнений между разными типами. Невозможно сравнить
int и unsigned . Типы в сравнении предварительно неявно приводятся к одному общему типу. В данном случае общим типом будет тип unsigned . То есть никакого "отрицательное больше чем положительное" тут нет. Сравниваются два положительных значения типа unsigned .
0
|
Злостный нарушитель
![]() 9847 / 5377 / 1225
Регистрация: 12.03.2015
Сообщений: 25,144
|
|
24.09.2022, 22:45 | |
0
|
Злостный нарушитель
![]() 9847 / 5377 / 1225
Регистрация: 12.03.2015
Сообщений: 25,144
|
||||||
24.09.2022, 23:23 | ||||||
Я чот вот тоже заинтересовался.
Ты ж знаешь, что я в Сях не копенгаген, а работаю на более другом языке программирования. И этот язык как-то более логично себя ведёт.
Вот почему так, а?
0
|
![]() 483 / 349 / 64
Регистрация: 09.03.2016
Сообщений: 3,453
|
|
25.09.2022, 00:14 | |
Компилятор выдаёт предупреждения.
Разные типы ни кто не сравнивает. Следовательно поведение не определено. Хрен его знает, почему... (Обойди проблему иначе) Не надо их сравнивать. Добавлено через 2 минуты a = (unsigned int)-110; Как вам такое?
0
|
Злостный нарушитель
![]() 9847 / 5377 / 1225
Регистрация: 12.03.2015
Сообщений: 25,144
|
|
25.09.2022, 00:19 | |
Ты объясни, пачиму сишный компайлер неявно приводит к unsigned, а паскальный - нет.
0
|
фрилансер
![]() 6334 / 5473 / 1108
Регистрация: 11.10.2019
Сообщений: 14,568
|
|
25.09.2022, 00:20 | |
Verevkin, где-то тут
0
|
Злостный нарушитель
![]() 9847 / 5377 / 1225
Регистрация: 12.03.2015
Сообщений: 25,144
|
|
25.09.2022, 00:23 | |
0
|
![]() 483 / 349 / 64
Регистрация: 09.03.2016
Сообщений: 3,453
|
|
25.09.2022, 00:28 | |
Без приведения типов, то же самое.
Добавлено через 1 минуту значение одно и тоже. Представление разное. А в паскале я ни чего не понимаю. Добавлено через 1 минуту Что лежит в ячейках памяти. Хочешь так, хочешь эдак.
0
|
Злостный нарушитель
![]() 9847 / 5377 / 1225
Регистрация: 12.03.2015
Сообщений: 25,144
|
|
25.09.2022, 00:29 | |
0
|
из племени тумба-юбма
![]() |
|||||||||||
25.09.2022, 02:50 | |||||||||||
Оригинал тут https://en.cppreference.com/w/... conversion а так, достаточно цитаты из последнего абзаца:
Кликните здесь для просмотра всего текста
В довесок сделал явное преобразование типов, где видно как изменяются переменные
0
|
Вездепух
![]() ![]() ![]() 12873 / 6737 / 1810
Регистрация: 18.10.2014
Сообщений: 17,057
|
||||||
25.09.2022, 04:03 | ||||||
Эта тема разбирается на странице 44 "Rationale". Там приводятся какие-то (относительно неубедительные) аргументы не тему того, почему для intergral promotions при расширении типа был выбран вариант "к знаковому", а вот для usual arithmetic conversions при одинаковой ширине типов - "к беззнаковому". Ясно, что в последнем случае идеального решения без расширения типа тут быть не может - как ни сделай, будут примеры, в которых это приводит к неожиданным результатам.
Потому что С и Паскаль - разные языки. В С++20 в стандартной библиотеке добавлены функции, выполняющие "безопасные" целочисленные сравнения
0
|
0 / 0 / 0
Регистрация: 25.09.2022
Сообщений: 25
|
||||||
25.09.2022, 09:00 | ||||||
Ответ в способе записи целых отрицательных чисел в компьютере — они записываются в [дополнительном коде](один из способов кодирования знаковых целых чисел), когда отрицательное число это [побитовое отрицание числа и инкремент этого числа(увеличение значения на единицу)].
//Пример: (-a) == ((~110)+1)
0
|
Вездепух
![]() ![]() ![]() 12873 / 6737 / 1810
Регистрация: 18.10.2014
Сообщений: 17,057
|
|
25.09.2022, 09:07 | |
Ответ - в спецификации языка С в таких случаях, а не в способе представления чисел.
Никакого принципиального отношения к способу представления чисел в компьютере это не имеет. Никто не мешает выполнить сравнение так, чтобы результат был "ожидаемым", независимо от способа представления чисел (как, например, это делает Паскаль).
0
|
Злостный нарушитель
![]() 9847 / 5377 / 1225
Регистрация: 12.03.2015
Сообщений: 25,144
|
|
25.09.2022, 10:50 | |
Спасибо тебе, прапорщик Очевидность! Я-то, дурак, думал, что одинаковые.
------- Я тебе так скажу: при сравнении знакового и беззнакового в паскале происходит с преобразованием к "общему знаменателю" - более широкому знаковому типу. Компилятор справедливо от этом предупреждает: Однако, если вручную сделать операнды сравнения 64-битными, то расширять их компилятору некуда. И сравниваются они как знаковые, без всяких ворнингов. ИЧСХ, результат сравнения - false, что мне кажется более правильным. Я кончил и закурил. ![]()
0
|
Вездепух
![]() ![]() ![]() 12873 / 6737 / 1810
Регистрация: 18.10.2014
Сообщений: 17,057
|
|
25.09.2022, 11:19 | |
Как я и сказал выше.
И, как я и сказал выше, в С такого не происходит. А в С - как беззнаковые. Добро пожаловать в С. Ну на таком "хорошем" примере - получается правильным. А сделай беззнаковое значение большим - результат получится "неправильным" по тем же причинам.
0
|
Злостный нарушитель
![]() 9847 / 5377 / 1225
Регистрация: 12.03.2015
Сообщений: 25,144
|
|
25.09.2022, 11:22 | |
0
|
25.09.2022, 11:22 | ||||||
Помогаю со студенческими работами здесь
20
Машинная арифметика.Определить отрицательное(положительное) число
Выяснить, какое число встречается раньше — положительное или отрицательное
Искать еще темы с ответами Или воспользуйтесь поиском по форуму:
|
|
Новые блоги и статьи
![]() |
||||
Работа с объемным DOM в javascript
Htext 04.04.2025
Сегодня прочитал статью тут о расходах памяти в JS, ее утечках и т. п. И вот что вспомнил из своей недавней практики. Может, кому пригодится. Хотя, в той статье об этом тоже есть.
Дело в том, что я. . .
|
Оптимизация производительности Node.js с помощью кластеризации
run.dev 04.04.2025
Масштабирование приложений для обработки тысяч и миллионов запросов — обыденная задача для многих команд. Node. js, благодаря своей асинхронной событийно-ориентированной архитектуре, стал популярной. . .
|
Управление зависимостями в Python с Poetry
py-thonny 04.04.2025
Стандартный инструмент для установки пакетов в Python - pip - прекрасно справляется с базовыми сценариями: установил пакет командой pip install и используешь его. Но что произойдёт, когда разные. . .
|
Мониторинг с Prometheus в PHP
Jason-Webb 04.04.2025
Prometheus выделяется среди других систем мониторинга своим подходом к сбору и хранению метрик. В отличие от New Relic, который использует агентный подход и отправляет данные во внешнее хранилище,. . .
|
Пакет Context в Golang: Управление потоками и ресурсами
golander 04.04.2025
Работа с горутинами в Go часто напоминает управление непослушными детьми - они разбегаются кто куда, делают что хотят и не всегда завершаются вовремя. К счастью, в Go 1. 7 появился пакет context,. . .
|
Контейнеризация React приложений с Docker
Reangularity 03.04.2025
Контейнеризация позволяет упаковать приложение со всеми его зависимостями в автономный контейнер, который можно запустить на любой платформе с установленным Docker. Это существенно упрощает процессы. . .
|
Свой попап в SwiftUI
mobDevWorks 03.04.2025
SwiftUI, как декларативный фреймворк от Apple, предоставляет множество инструментов для создания пользовательских интерфейсов. В нашем распоряжении есть такие API как alerts, popovers, action sheets. . .
|
Антипаттерны микросервисной архитектуры
ArchitectMsa 03.04.2025
Хорошо спроектированная микросервисная система может выдержать испытание временем, оставаясь гибкой, масштабируемой и устойчивой к большинству проблем. Такая архитектура обладает высоким уровнем. . .
|
std::mutex в C++: Советы и примеры использования
bytestream 03.04.2025
std::mutex - это механизм взаимного исключения, который гарантирует, что критический участок кода выполняется только одним потоком в каждый момент времени. Это простое, но могущественное средство. . .
|
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
|