5

ポインターを unsigned int にキャストしてから、後でポインターにキャストすることはできますか? 構造体へのポインターを pthread_t 変数に格納しようとしていますが、うまく動作しないようです。これが私のコードの一部です (私はユーザーレベルのスレッド管理ライブラリを作成しています)。スレッドの tid を出力しようとすると、長いガベージ番号が表示されます。

編集:気にしないで、うまくいきました。

私が変更され

thread = (pthread_t) currentThread;

*thread = (pthread_t) currentThread;

それはそのようなばかげたことだと思いました。


テストプログラム:

pthread_t thread1;
pthread_t thread2;

pthread_create(&thread1, NULL, runner, NULL);
pthread_create(&thread2, NULL, runner, NULL);
pthread_join(&thread2, NULL);

私のライブラリ:

typedef struct queueItem
{
    int tid;
    ucontext_t context;

    int caller;

    struct queueItem *joiningOn;
    struct queueItem *nextContext;
} queueItem;

int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine) (void *), void *arg)
{
    thread = (pthread_t) currentThread;
}

...

int pthread_join(pthread_t thread, void **retval)
{
    queueItem *t = (queueItem *) thread;

    if(runningContext->joiningOn != NULL) // Current thread is already waiting on another
        return EINVAL;
    if(t == NULL) // If thread to join on is invalid
        return 0;

    fprintf(stdout, "JOINEE: %d\n", t->tid); // Prints weird number

    runningContext->caller = JOIN;
    runningContext->joiningOn = t;
    swapcontext(&(runningContext->context), &scheduleContext);
}
4

2 に答える 2

5

いいえ。多くのシステムでは、ポインタ型はint型よりも大きくなっています。pthread_tの使用に問題がある場合は、それについて質問してください。intは答えではありません。

たとえば、私のマシンでは、次のコードがあります。

#include <stdio.h>

int main() {
        printf("unsigned int = %lu\n", sizeof(unsigned int));
        printf("pointer = %lu\n", sizeof(void*));
        return 0;
}

出力:

unsigned int = 4
pointer = 8
于 2012-04-29T00:48:51.463 に答える
4

unsigned int がシステムの void* と同じサイズであることを確認すれば、可能です。

動作しないコードがある場合は、投稿してください。

編集: について読む必要がありますintptr_t。たとえば、こちら: Why / when to use `intptr_t` for type-casting in C?

于 2012-04-29T00:43:04.600 に答える