1'u64 .. 25'u64 :
prod = prod * num2
echo prod
возвращает
Product numbers 1-25:
7034535277573963776
что не есть тру, ибо
fact(N) -> fact(N, 1).
fact(0, A) -> A;
fact(N, A) when N > 0 -> fact(N - 1, N * A).
> test1:fact(25).
15511210043330985984000000
____________________
var prod: uint64 = 1
echo "Product numbers 1-100:"
for num2 in 1'u64 .. 100'u64 :
prod = prod * num2
echo prod
будет
Product numbers 1-100:
0
___________________________
если сигнед
var prod: int64 = 1
echo "Product numbers 1-100:"
for num2 in 1'i64 .. 100'i64 :
prod = prod * num2
echo prod
будет рантайм падение
Product numbers 1-100:
fatal.nim(53) sysFatal
Error: unhandled exception: over- or underflow [OverflowDefect]
_______________
шо не так с Nim?))
почему всегда разное поведение?
Стикер
У тебя исключение оверфлоу/андерфлоу свалилось только для типа int64 - знаковое целое длиной 63 бита + 1 бит знака. На типе uint64 - беззнаковое целое длиной 64 бита исключения небыло и не должно было быть, т.к. в этом типе переполнение не предусмотрено.
ну исключения небыло — небыло падения в рантайме, ок но есть два результата, которые не равны правильным-ожидаемым — 0 и число, меньшее за реальный результат это же тоже оверфлоу, или как это зовется то?
ну да, у тебя переполнение 64 бит не хватает
Блин, ты изучи что такое int64 и uin64 и почему там цифра 64 стоит. А есть ещё int32, int16 и int8 и их беззнаковые варианты. И удивляться почему я пихаю число 255 в int8, а получаю почему-то -127 ты более не будешь.
надо еще суметь запихнуть, компилятор просто так не даст
да знаю) просто удивило, что проведение разное
Обсуждают сегодня