Анимация
JavaScript
|
Главная Библионтека 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
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
Ошибка Значение элемента массива 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);
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 |