4

テストしたいスレッドセーフプログラムがあります(以下を参照)。これが私の最初のテストプログラムになるので、テストプログラムの開始をどのように進めるかがわかりません。結果は、このスレッドセーフプログラムの実装を使用するデモンストレーションであり、例のようなスレッドセーフプログラムをテストするのに最適な代替手段である理由です。

#include <errno.h>
#include <pthread.h>
static pthread_mutex_t listlock = PTHREAD_MUTEX_INITIALIZER;

int accessdata_r(void) {  /* return nonnegative traversal key if successful */ 
   int error;   
   int key;
   if (error = pthread_mutex_lock(&listlock)) {        /* no mutex, give up */
      errno = error;
      return -1; 
   }
   key = accessdata();
   if (key == -1) {
      error = errno;
      pthread_mutex_unlock(&listlock);
      errno = error;
      return -1;
   }
   if (error = pthread_mutex_unlock(&listlock)) {
      errno = error;
      return -1;
   }
   return key;
}

int adddata_r(data_t data) {        /* allocate a node on list to hold data */
   int error;
   if (error = pthread_mutex_lock(&listlock)) {        /* no mutex, give up */
      errno = error;
      return -1;
   }
   if (adddata(data) == -1) {
      error = errno;
      pthread_mutex_unlock(&listlock);
      errno = error;
      return -1;
   }
   if (error = pthread_mutex_unlock(&listlock)) {
      errno = error;
      return -1;
   }
   return 0; 
}

int getdata_r(int key, data_t *datap) {             /* retrieve node by key */
   int error;
   if (error = pthread_mutex_lock(&listlock)) {        /* no mutex, give up */
      errno = error;
      return -1;
   }
   if (getdata(key, datap) == -1) {
      error = errno;
      pthread_mutex_unlock(&listlock);
      errno = error;
      return -1;
   }
   if (error = pthread_mutex_unlock(&listlock)) {
      errno = error;
      return -1;
   }
   return 0; 
}

int freekey_r(int key) {                                    /* free the key */
   int error;
   if (error = pthread_mutex_lock(&listlock)) {        /* no mutex, give up */
      errno = error;
      return -1;
   }
   if (freekey(key) == -1) {
      error = errno;
      pthread_mutex_unlock(&listlock);
      errno = error;
      return -1;
   }
   if (error = pthread_mutex_unlock(&listlock)) {
      errno = error; 
      return -1;   
   } 
   return 0;  
}
4

1 に答える 1

1

これは実装をテストするための比較的単純なオプションであり、既存のオプションはこれだけではありません。

  1. X項目をリストに追加する関数を作成します(通常のカウンターである可能性があります)
  2. ループで同じデータを取得する関数を作成します。

  3. いくつかのスレッド (pthread_create) を作成し、関数のそれぞれに割り当てます。

  4. このようにして、デッドロックがないかどうかを確認し、正確さを確認するために、挿入中に何らかのタイプのタイムスタンプを追加し (タイムスタンプでタプルされた値を挿入する必要があります)、結果を保持する各スレッドの配列を保持する必要があります、最後に結果を印刷し、タイムスタンプが正確であるかどうかを確認します。
于 2012-11-04T11:19:45.013 に答える