Побитовый сдвиг в лево\право VB6

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
Res5
Обычный пользователь
Обычный пользователь
 
Сообщения: 72
Зарегистрирован: 07.09.2013 (Сб) 3:11

Побитовый сдвиг в лево\право VB6

Сообщение Res5 » 08.12.2013 (Вс) 18:34

Возможно ли это? В шарпе это делается легко >> или << . Можно попробовать закомпилить длл с функцией, но надеюсь есть другие варианты.

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Re: Побитовый сдвиг в лево\право VB6

Сообщение alibek » 08.12.2013 (Вс) 18:37

Нециклический — чистая арифметика.
Lasciate ogni speranza, voi ch'entrate.

Res5
Обычный пользователь
Обычный пользователь
 
Сообщения: 72
Зарегистрирован: 07.09.2013 (Сб) 3:11

Re: Побитовый сдвиг в лево\право VB6

Сообщение Res5 » 08.12.2013 (Вс) 18:47

Нециклический

The trick
Постоялец
Постоялец
 
Сообщения: 781
Зарегистрирован: 26.06.2010 (Сб) 23:08

Re: Побитовый сдвиг в лево\право VB6

Сообщение The trick » 08.12.2013 (Вс) 21:31

Умножение на 2 - сдвиг влево, деление на 2 - сдвиг вправо (арифметический). Для логического сдвига вправо, обнулять после деления старший бит. Для циклического проверять бит до сдвига и устанавливать его с другой стороны. Все это относится к одиночному случаю (один сдвиг)
UA6527P

ger_kar
Продвинутый гуру
Продвинутый гуру
Аватара пользователя
 
Сообщения: 1957
Зарегистрирован: 19.05.2011 (Чт) 19:23
Откуда: Кыргызстан, Иссык-Куль, г. Каракол

Re: Побитовый сдвиг в лево\право VB6

Сообщение ger_kar » 09.12.2013 (Пн) 16:21

Есть готовые примеры реализации сдвига на VB. Можно или использовать как есть, либо просто посмотреть как реализовано.
Бороться и искать, найти и перепрятать

The trick
Постоялец
Постоялец
 
Сообщения: 781
Зарегистрирован: 26.06.2010 (Сб) 23:08

Re: Побитовый сдвиг в лево\право VB6

Сообщение The trick » 09.12.2013 (Пн) 20:20

Есть готовые примеры реализации сдвига на VB. Можно или использовать как есть, либо просто посмотреть как реализовано.
Глупо для элементарных команд использовать кучу лишнего, проверку ошибок, когда можно сделать проще. К тому же код не будет работать на новых ОС, где требуется разрешение на выполнение. Если и делать через вызов функций, то делать по-человечески, чтобы работало везде
Код: Выделить всё
Option Explicit

Private Declare Function HeapCreate Lib "kernel32" (ByVal flOptions As Long, ByVal dwInitialSize As Long, ByVal dwMaximumSize As Long) As Long
Private Declare Function HeapDestroy Lib "kernel32" (ByVal hHeap As Long) As Long
Private Declare Function HeapAlloc Lib "kernel32" (ByVal hHeap As Long, ByVal dwFlags As Long, ByVal dwBytes As Long) As Long
Private Declare Function HeapFree Lib "kernel32" (ByVal hHeap As Long, ByVal dwFlags As Long, lpMem As Any) As Long
Private Declare Function GetMem4 Lib "msvbvm60" (pSrc As Any, pDst As Any) As Long
Private Declare Function ArrPtr Lib "msvbvm60" Alias "VarPtr" (arr() As Any) As Long
Private Declare Function CallWindowProc Lib "user32" Alias "CallWindowProcA" (ByVal ptrFc As Long, ByVal P1 As Long, ByVal P2 As Long, ByVal P3 As Long, ByVal P4 As Long) As Long

Private Const HEAP_CREATE_ENABLE_EXECUTE = &H40000
Private Const HEAP_NO_SERIALIZE = &H1

Dim Code() As Long, hHeap As Long, lpFunc As Long, lpOldPt As Long, lpSA As Long

Public Function InitSh() As Boolean ' Инициализация процедур
    ReDim Code(4)
    hHeap = HeapCreate(HEAP_CREATE_ENABLE_EXECUTE Or HEAP_NO_SERIALIZE, (UBound(Code) + 1) * 4, (UBound(Code) + 1) * 4)
    If hHeap = 0 Then MsgBox "Error creating heap", vbCritical: Exit Function
    lpFunc = HeapAlloc(hHeap, HEAP_NO_SERIALIZE, (UBound(Code) + 1) * 4)
    If lpFunc = 0 Then MsgBox "HeapAlloc return NULL", vbCritical: Exit Function
    GetMem4 ByVal ArrPtr(Code()), lpSA
    GetMem4 ByVal lpSA + 12, lpOldPt
    GetMem4 lpFunc, ByVal lpSA + 12
    Code(0) = &H53E58955: Code(1) = &H8B08458B: Code(2) = &HD30C4D: Code(3) = &H5DEC895B: Code(4) = &HC3
End Function
Public Function DeinitSh() As Boolean   ' Деинициализация
    GetMem4 lpOldPt, ByVal lpSA + 12
    If lpFunc Then HeapFree hHeap, HEAP_NO_SERIALIZE, ByVal lpFunc
    If hHeap Then HeapDestroy hHeap
End Function
Public Function Shl(ByVal Operand As Long, ByVal Count As Long) As Long     ' Логический сдвиг влево
    Code(2) = &HE0D30C4D
    Shl = CallWindowProc(VarPtr(Code(0)), Operand, Count, 0, 0)
End Function
Public Function Sal(ByVal Operand As Long, ByVal Count As Long) As Long     ' Арифметический сдвиг влево
    Sal = Shl(Operand, Count)
End Function
Public Function Shr(ByVal Operand As Long, ByVal Count As Long) As Long     ' Логический сдвиг вправо
    Code(2) = &HE8D30C4D
    Shr = CallWindowProc(VarPtr(Code(0)), Operand, Count, 0, 0)
End Function
Public Function Sar(ByVal Operand As Long, ByVal Count As Long) As Long     ' Арифметический сдвиг вправо
    Code(2) = &HF8D30C4D
    Sar = CallWindowProc(VarPtr(Code(0)), Operand, Count, 0, 0)
End Function
Код: Выделить всё
Private Sub Form_Load()
    Dim i As Long
   
    InitSh
   
    For i = 0 To 32
        Debug.Print Hex(Shr(-1, i)); Tab(20); Hex(Sar(-1, i)); Tab(40); Hex(Shl(-1, i))
    Next
   
    DeinitSh
End Sub
UA6527P

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Re: Побитовый сдвиг в лево\право VB6

Сообщение alibek » 10.12.2013 (Вт) 8:10

Кривоус Анатолий писал(а):Если и делать через вызов функций, то делать по-человечески, чтобы работало везде

Это как раз не по человечески, использовать машиннокодовые вставки в языке высокого уровня, когда в этом нет острой необходимости.
Lasciate ogni speranza, voi ch'entrate.

Хакер
Телепат
Телепат
Аватара пользователя
 
Сообщения: 16478
Зарегистрирован: 13.11.2005 (Вс) 2:43
Откуда: Казахстан, Петропавловск

Re: Побитовый сдвиг в лево\право VB6

Сообщение Хакер » 10.12.2013 (Вт) 11:38

alibek писал(а):Это как раз не по человечески, использовать машиннокодовые вставки в языке высокого уровня, когда в этом нет острой необходимости.

Код GSerg-а, на который ссылаются выше. тоже их использует. Так что в этом плане разницы нет. А под чёловечностью он имел в виду HEAP_CREATE_ENABLE_EXECUTE, ибо те, кто этим не пользуются — не человеки.
—We separate their smiling faces from the rest of their body, Captain.
—That's right! We decapitate them.


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: AhrefsBot, Majestic-12 [Bot] и гости: 39

    TopList