Форум АНТИЧАТ

Форум АНТИЧАТ (https://forum.antichat.xyz/index.php)
-   С/С++, C#, Delphi, .NET, Asm (https://forum.antichat.xyz/forumdisplay.php?f=24)
-   -   23 способа получить в регистре единицу. (https://forum.antichat.xyz/showthread.php?t=50413)

0x0c0de 03.10.2007 18:19

23 способа получить в регистре единицу.
 
23 способа получить в регистре единицу.
От самых простых до самых извратных. Хорошая разминка для мозгов.

1. непохек
Код:


mov eax,1.

Просто положить в регистр единицу

2.
Код:

sub eax,eax /xor eax,eax (по отдельности не рассматриваю)
  inc eax

Красиво, довольно коротко. Обнуляем, инкрементируем....

3.
Код:

imul eax,0
    inc eax

Тоже красиво. Обнуляем, инкрементируем

4. Сопроцессор, но тут нужна дополнительная переменная. mem dword ?
Код:

finit
fld1
fist mem
mov eax,mem

в eax - теперь 1
Сначала мы инициализируем сопроцессор (finit), потом загружаем в st0 1, потом отправляем
содержимое st0 в mem, mem ложим в eax )

5. Еще сопроцессор ( mem dword ?)
Код:

finit
fldpi
fcos
fchs
fist mem
mov eax,mem

То есть ложим в st0 число пи, находим косинус пи (-1), меняем знак, сохраняем значение

6. А теперь больше тригонометрии
Код:

finit
fldz
fcos
fist mem
mov eax,mem

Ищем косинус от нуля))))) А это 1)))

7. А еще можно так
Код:

sub eax,eax
 sub al,-1

это 4 байта.

8. Самый мой любимый способ
Код:

sub eax,eax
bfs eax,0

В нулевой бит ложим 1=)

9.
Код:

lea eax,[1]
Длинно, но все же....

10. Разновидность 5 метода, но беру модуль
Код:

finit
fldpi
fcos
fabs
fist mem
mov eax,mem

11.
Код:

sub eax,eax
  dec eax
  imul eax,eax

Ну это всем наверное ясно -1*(-1)=1

12. Этот способ я тоже люблю.
Делим двоичный логарифм 10 сам на себя.Аналогичный способ с любым др. числом (например с натуральным логарифмом 2 -
оба способа рассматриваются)
Код:

finit
fld2t
fld2t
fdiv st0,st1
fist mem
mov eax,mem

и соответственно

Код:

finit
fldln2
fldln2
fdiv st0,st1
fist mem
mov eax,mem

а можно еще с числом пи и десятичным логарифмом 2
Код:

finit
fldpi
fldpi
fdiv st0,st1
fist mem
mov eax,mem

и

Код:

finit
fldlg2
fldlg2
fdiv st0,st1
fist mem
mov eax,mem

13. Тригонометрия. Что-то меня тригонометрия в последнее время вдохновляет. Вариация на тему основного тригонометрического
тождества.
Код:

finit
fldln2 ; натуральный логарифм 2
fcos ; получаем косинус
fldln2
fcos
fmul st,st(1) ; (cos(ln2))^2
fldln2
fsin ; теперь синус
fldln2
fsin
fmul st(1),st ; (sin(ln2))^2
fincstp
fadd st,st(1) ; st0+st1=1 по основному тригонометрическому тождеству
fist mem

14. Красивый способ
Код:

stc ; установка флага переноса в 1
sbb eax,eax ; вычитание с заемом
neg eax ; -(-1)=1

15. В еax будет true, то есть 1
Код:

sub eax,eax
cmp eax,eax
sete al

16. Еще извратный способ
Код:

sub eax,eax
sub ecx,ecx
dec eax
mov cx,1fh
m1:
btc eax,ecx ; фишка в этой команде. инвертируем все биты, кроме последнего, тогда в самом регистре будет 1
loop m1

17.А еще можно так
Код:

sub eax,eax
stc ; установка флага переноса в 1
adc eax,eax ; сложнение с учетом флага переноса CF

18.Простенько, но со вкусом
Код:

sub eax,eax
or eax,1

19. Почти тоже самое
Код:


xor eax,eax
xor eax,1

20.Обалденный способ. 4 bsr над -1 и получаем 1)
Код:

  sub eax,eax
  dec eax
  bsr eax,eax
  bsr eax,eax
  bsr eax,eax
  bsr eax,eax

21. Тоже вариант
Код:

sub eax,eax
 dec eax
 shr eax,1fh ; логический сдвиг вправо

22. Скушный метод, но результат тот же
Код:

xor eax,eax
dec eax
and eax,1

23. Довольно неинтересно.. но все же
Код:

xor eax,eax
dec eax
neg eax

Пока на этом все......

Ni0x 03.10.2007 18:39

Это все конечно круто, только зачем мне куча каких-то извращенных способов, если обычно используются 3-4 способа из списка? Причем по размеру они выигравают все остальные. Честно говоря, похоже на детское хвастовство, теперь сделай 23 способа как получить -1 в регистре. Без обид, но лучше вкладывать свой потенциал во что-то более серьезное.

0x0c0de 03.10.2007 18:45

Ну цель вообще другая была... А именно
Цитата:

Хорошая разминка для мозгов
Выйти за рамки стандартных команд так сказать. Я таким образом после дня напряженной учебы расслабляюсь

Цитата:

теперь сделай 23 способа как получить -1 в регистре
думаю их больше... тоже мысль.

ЗЫ Ясное дело, что лучше всего

Код:


sub eax,eax
inc eax

это всего 3 байта. Но юзают-то в основном mov eax,1
а это 5 байт=\\\\ Так что материал полезен для общего развития)

Xserg 04.10.2007 10:43

Цитата:

Сообщение от 0x0c0de
Пока на этом все......

+7 до 30

тоже 3 байта (константа до 255 для W32)
Код:

push 1
pop eax

с использованием API, которая обязательно возвратит 0
Код:

invoke IsWindow,-1
inc eax

; неудобный метод
Код:

push 1
push esp
pop esi
lodsd
pop esi

способ с исчезновением стека
Код:

stc ;<- 1
pushfd
xchg esi,esp
lodsd
xchg esi,esp
and eax,1

мешает отладке
Код:

  call @1
    dd 1
@1: pop eax   
mov eax,[eax]

всего 11 байт запутанное зануление EAX
Код:

movzx ebx,ax
xchg ebx,eax
bswap eax
movzx ebx,ax
xchg ebx,eax
inc eax

полное извращение, но прикольно
Код:

  call @2
@2: pop esi
    push esi
    std
    lodsb
    sub [esp],esi
    cld
    pop eax


dmnt 16.11.2007 21:29

вы таки шеллкодесов не писали
тут есть таки разница что использовать

nerezus 16.11.2007 22:01

Цитата:

это всего 3 байта. Но юзают-то в основном mov eax,1
а это 5 байт=\\\\
Так он понятнее. Понятность кода намного важнее размера и скорости ) Есть конечно пара исключений, но это редкость.

Piflit 16.11.2007 22:26

Цитата:

Сообщение от nerezus
Понятность кода намного важнее размера и скорости )

-1. для понятности существуют комментарии

Hellsp@wn 16.11.2007 23:15

ещё так... тока мсысл всего этого? =) нету...

Xor eax,eax
Mov Al,1

Forcer 16.11.2007 23:15

А я наоборот, полностью согласен с nerezus. Скорость, быстродействие - зависит от скила кодера в данный момент времени. А вот понятность кода, возможность его модернизации - это, так сказать, на все времена! Но это отнюдь не означает, что надо писать медленный и алгоритмически неправильный код в ушерб понятности. надо знать меру : ). По теме: асм не знаю, заметил лишь одно: не "ложим", а "кладем" - рус.яз. рулит : )

0x0c0de 16.11.2007 23:27

Клево. "Кладем"... Важное замечание такое)))))))))
В чем смысл? Я уже писала в чем смысл.... в далеком октябре. Читаем пост номер 1 вторая строка второе предложение. Читаем пост номер три. ЦЕЛИКОМ.

Цитата:

ещё так... тока мсысл всего этого? =) нету...

Xor eax,eax
Mov Al,1
нууууууу))))))) ну ладно... пусть будет. 31-й.


Время: 23:32