3 #include "cliffc_hashtable.h"
7 template<typename TypeK, typename TypeV>
8 slot* const cliffc_hashtable<TypeK, TypeV>::MATCH_ANY = new slot(false, NULL);
10 template<typename TypeK, typename TypeV>
11 slot* const cliffc_hashtable<TypeK, TypeV>::NO_MATCH_OLD = new slot(false, NULL);
13 template<typename TypeK, typename TypeV>
14 slot* const cliffc_hashtable<TypeK, TypeV>::TOMBPRIME = new slot(true, NULL);
16 template<typename TypeK, typename TypeV>
17 slot* const cliffc_hashtable<TypeK, TypeV>::TOMBSTONE = new slot(false, NULL);
25 IntWrapper(int val) : _val(val) {}
27 IntWrapper() : _val(0) {}
29 IntWrapper(IntWrapper& copy) : _val(copy._val) {}
39 bool operator==(const IntWrapper& rhs) {
43 bool equals(const void *another) {
47 (IntWrapper*) another;
48 return ptr->_val == _val;
52 cliffc_hashtable<IntWrapper, IntWrapper> *table;
53 IntWrapper *val1, *val2;
54 IntWrapper *k1, *k2, *k3, *k4, *k5;
55 IntWrapper *v1, *v2, *v3, *v4, *v5;
57 void threadA(void *arg) {
62 val1 = table->get(k3);
64 model_print("val1: %d\n", val1->_val);
66 model_print("val1: NULL\n");
71 void threadB(void *arg) {
74 val1 = table->get(k2);
76 val1 = table->get(k2);
80 void threadMain(void *arg) {
82 val1 = table->get(k1);
84 model_print("val1: %d\n", val1->_val);
86 model_print("val1: NULL\n");
89 int user_main(int argc, char *argv[]) {
91 table = new cliffc_hashtable<IntWrapper, IntWrapper>(2);
92 k1 = new IntWrapper(3);
93 k2 = new IntWrapper(5);
94 k3 = new IntWrapper(11);
95 k4 = new IntWrapper(7);
96 k5 = new IntWrapper(13);
98 v1 = new IntWrapper(1024);
99 v2 = new IntWrapper(47);
100 v3 = new IntWrapper(73);
101 v4 = new IntWrapper(81);
102 v5 = new IntWrapper(99);
104 thrd_create(&t1, threadA, NULL);
105 thrd_create(&t2, threadB, NULL);
112 cout << "val1: NULL" << endl;
114 cout << val1->get() << endl;
116 //MODEL_ASSERT(val1 == NULL || val1->get() == 2 || val1->get() == 81);
118 cout << "val2: NULL" << endl;
120 cout << val2->get() << endl;