Анимация
JavaScript


Главная  Библионтека 

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 [ 122 ] 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140

a=CreateArray("MyArray"); SetHashString(a,"Ivanov","Patron"); Message("%s \n", GetHashLong(a,"Ivanov")

DeleteArray(a);

Patr

Необходимо помнить, что IDA учитывает регистр индексов. Так "Ivanov" и "ivanov" это два разных индекса и при попытке прочитать присвоенное значение функция возвратит ноль.

Например:

auto a;

DeleteArray(GetArrayId("MyArray")); a=CreateArray("MyArray"); SetHashLong(a,"Ivanov",0x66); Message("%x \n", GetHashLong(a,"ivanov")

DeleteArray(a);

Возникает неоднозначность, - то ли действительно возникла ошибка, то ли такое значение имеет элемент?

В остальном же никаких проблем с использованием этой функции не возникает. Например:

auto a;

DeleteArray(GetArrayId("MyArray")); a=CreateArray("MyArray"); SetHashLong(a,"Ivanov",0x66); Message("%x \n", GetHashLong(a,"Ivanov")

DeleteArray(a);

0x66

Операнд

Пояснения

Идентификатор массива

Индекс массива (строковой!)

Return

==return Пояснения

!=0 Значение элемента массива

==0 Ошибка

Значение элемента массива

char GetHashString(long id,char idx);

Функция возвращает значение элемента ассоциативного массива типа «строка»



Как уже говорилось выше один и тот же элемент не может содержать значения «строка» и «длинное целое» одновременно. Поэтому возникает возможность присвоить значение одного типа, а попытаться прочитать другого. Эта операция завершиться корректно и типы будут автоматически преобразованы.

При этом функция GetHashString возвращает четыре первые байта, если ни один из них не является нулем, в противном случае весь отрезок до первого нуля.

Например:

auto a;

DeleteArray(GetArrayId("MyArray"));

a=CreateArray("MyArray");

SetHashLong(a,"Ivanov",0x66776677);

Message("%s \n",

GetHashString(a,"Ivanov"));

DeleteArray(a);

Wfwf

Необходимо помнить, что IDA учитывает регистр индексов. Так "Ivanov" и "ivanov" это два разных индекса и при попытке прочитать присвоенное значение функция возвратит пустую строку.

Например:

auto a;

DeleteArray(GetArrayId("MyArray")); a=CreateArray("MyArray"); SetHashString(a,"Ivanov",0x66); Message("%s \n", GetHashLong(a,"ivanov")

DeleteArray(a);

Возникает неоднозначность, - то ли действительно возникла ошибка, то ли такое значение имеет элемент?

В остальном же никаких проблем с использованием этой функции не возникает. Например:

auto a;

DeleteArray(GetArrayId("MyArray")); a=CreateArray("MyArray"); SetHashString(a,"Ivanov","Patron"); Message("%s \n", GetHashLong(a,"Ivanov")

DeleteArray(a); Patron

Операнд

Пояснения

Идентификатор массива

Индекс массива (строковой!)

Return

==return

Пояснения

Значение элемента массива



Ошибка

Значение элемента массива

success DelHashElement(long id,char idx);

Функция удаляет один элемент ассоциативного массива. Поскольку один и тот же элемент не может содержать значения «строка» и «длинное целое» одновременно, отпадает необходимость указывать теги (смотри описание функции DelArrayElement для разряженных массивов)

Необходимо помнить, что IDA учитывает регистр индексов. Так "Ivanov" и "ivanov" это два разных индекса и представляют собой два разных элемента.

В остальном же функция ничем не отличается от аналогичной, использующийся для удаления элементов разряженных массивов.

Например:

auto a;

DeleteArray(GetArrayId("MyArray")); a=CreateArray("MyArray"); SetHashString(a,"Ivanov","Patron"); Message("%s \n", DelHashElement(a,"Ivanov")

DeleteArray(a);

Операнд

Пояснения

Идентификатор массива

Индекс массива (строковой!)

Return

==return

Пояснения

Операция выполнена успешно

Ошибка

char GetFirstHashKey(long id);

Функция возвращает индекс первого элемента ассоциативного массива. Поскольку ассоциативные массивы индексируются строковыми значениями, то привычные для нас способы обращения к элементам не подходят.

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

Индексы ассоциативных массивов хранятся в списке, упорядоченном в алфавитной последовательности, не зависимо от порядка добавления в него новых элементов, что и доказывает следующий пример:

auto a;

DeleteArray(GetArrayId("MyArray"));

a=CreateArray("MyArray");

SetHashLong(a,"Ivanov",0x66);

SetHashLong(a,"Cheputilo",0x77);

SetHashLong(a,"Alushta",0x67);

Message("%s \n",



0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 [ 122 ] 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140