- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
int"的 C 函数-6ren"> int"的 C 函数-我需要使用 pthread_create 来调用类型的 C 函数 int main_original(int argc, char** argv) 我试过这样的: pthread_create(&t,-6ren">
我需要使用 pthread_create 来调用类型的 C 函数
int main_original(int argc, char** argv)
我试过这样的:
pthread_create(&t, NULL, main_original, NULL);
编译器给我一个类型错误
invalid conversion from ‘int (*)(int, char**)’ to ‘void* ()(void)’
那么,调用 main_original 的正确方法是什么,以便它的参数能够很好地传递?
最佳答案
函数 pthread_create
只能调用具有以下签名的函数:
void *fn(void *)
即使您设法将指针转换为具有不同签名的函数并成功将其传递给 pthread_create
,您的程序也可能会崩溃,因为 pthread_create
将尝试以一种遵循平台对仅具有一个 void *
参数的函数的调用约定的方式设置堆栈/寄存器,这将导致您的函数处于不确定状态。
解决您的问题的方法是使用专门为被 pthread_create
调用而设计的包装函数,如下所示:
void *main_original_start_routine(void *arg)
{
main_original(argc, argv);
return NULL;
}
但是,这可能还不够,除非argc
和argv
是全局变量。您可能会发现您还需要以某种方式将这些值从您调用 pthread_create
的范围传递给此函数。这可以通过 pthread_create
的 void *arg
参数来完成,方法是创建一个包含您需要的状态的结构,并通过转换的 void 指针传递它:
struct main_original_context {
int argc;
char **argv;
};
void *main_original_start_routine(void *arg)
{
/* Convert the void pointer back to the struct pointer it
* really is. */
struct main_original_context *ctx = arg;
main_original(ctx->argc, ctx->argv);
return NULL;
}
int main(int argc, char **argv)
{
pthread_t t;
struct main_original_context ctx = {
argc,
argv
};
/* Pass a pointer to our context struct to the thread routine. */
pthread_create(&t, NULL, &main_original_start_routine, &ctx);
pthread_join(&t, NULL);
return 0;
}
但是请记住,在这种情况下,ctx
的生命周期只有 main
函数的持续时间。如果我们在其中创建 pthread 的函数在返回之前没有加入 pthread_join
(并使用于为线程提供上下文的结构无效),那么这将是不安全的。因此我们必须使用动态分配,并让线程负责释放任何动态分配的内存:
struct main_original_context {
int foo;
int bar;
};
void *foobar_start_routine(void *arg)
{
struct main_original_context *ctx = arg;
foobar(ctx->foo, ctx->bar);
/* Free memory we have been given responsibility for. */
free(ctx);
return NULL;
}
void asdf(int foo, int bar)
{
pthread_t t;
struct main_original_context *ctx;
/* Allocate memory. */
ctx = malloc(sizeof *ctx);
ctx->foo = foo;
ctx->bar = bar;
/* Assume `main_original_start_routine` is now responsible for freeing
* `ctx`. */
pthread_create(&t, NULL, &foobar_start_routine, ctx);
/* Now we can safely leave this scope without `ctx` being lost. In
* the real world, `t` should still be joined somewhere, or
* explicitly created as a "detached" thread. */
}
关于c - 使用 pthread_create 调用类型为 "int argc, char** argv -> int"的 C 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50703913/
目前我正在学习 C 并试图理解这些说明。它们真的不同吗? ++*argv *argv++ *(++argv) *(argv++) 谢谢! 最佳答案 后缀递增运算符的优先级高于指针取消引用运算符,而不是
我正在与在 Hostgator 共享主机上运行的 PHP CLI 的一个(也许)简单问题作斗争。一个简单的代码: 在我的本地机器上运行时以及其他几个 php 实例: php test.php arg
谁能解释一下原因 int main(int argc, const char * argv[]) { while (* argv) puts(* argv++); return 0 ;
从 K&R 的 C 书的第 5.10 章开始,argv 的概念被引入以允许命令行参数。 argv 是指向字符指针数组的指针。据此,以下代码如何检查提供的参数是否以连字符开头? (*++argv)[0]
我不明白 sys.argv 和 argv 之间的区别,网上没有任何东西给我我理解的概念。如果两者相同!我们什么时候使用 sys.argv 什么时候使用 argv ? 如果不是,sys.argv 是什么
我正在编写一个接受参数的 C 程序,char *argv[] 来决定运行哪个 exec()。我有 execlp(argv[1], argv[1], NULL) 可以正常工作。出于某种原因,execvp
char** argv 和 char* argv[] 有什么区别?在 int main(int argc, char** argv) 和 int main(int argc, char* argv[]
我目前有一个 python 脚本,可以在大型网络中完成一项非常有用的任务。我所做的是使用 lsof -iTCP -F 和其他一些选项来转储所有监听的 TCP 套接字。我能够得到 argv[0],这不是
为什么 argvs 的行为很奇怪?示例: 这将按预期工作,打印第一个参数的第一个字符。 printf("%c", *argv[1]); 但是,这将打印 ascii 表中的字符(又名“更大”,表示为数字
我做了一个小的重复异或加密器。您可以使用您选择的键对您选择的字符串进行异或运算,它可以选择将其输出到文件中。 无论何时使用单个单词(无空格)字符串和键运行程序,都没有问题。但是,只要字符串或键中有空格
我刚开始学习 C,想知道我应该在我的主要方法中使用其中的哪一个。有什么不同吗?哪个更常见? 最佳答案 由于您刚开始学习 C,我建议您首先真正尝试了解数组和指针之间的区别,而不是共同的东西。 在参数和数
所以我在编译器转换的函数中传递数组时在幕后阅读过 int myArray(int arr[]) 进入 int myArray(int *arr) 例如,大多数时候数组也会衰减为指针 arr[0] 与相
我正在编写一个小的 shell 程序,它接受一个命令并执行它。如果用户输入无效命令,则 if 语句返回 -1。如果命令正确,它就会执行命令,但是一旦它执行了命令,程序就会结束。我做错了什么是不执行它之
是否可以传入自定义参数列表? 与现实生活中的用例相比,更多是出于好奇,但例如,我可能希望在让 argparse 完成其工作之前将所有参数转换为小写。 最佳答案 Yes .只需传入要parse_args
我知道这个问题很基础,我也是新手,所以请帮我解决这个问题: 我有这个代码: int wmain(int argc, wchar_t *argv[]) { if (*argv[1] == L'-
这个问题在这里已经有了答案: Understanding slicing (38 个答案) 关闭 3 个月前。 我写了这段代码: #!/usr/bin/env python import sys i
我的程序获取主要参数,我的任务是检查用户是否在执行文件和参数之间输入了空格。 这是一个没有在 argv[0] 为 HW01 和 argv[1] 之间输入空格的人的例子/n: HW01/n 但是如果有人
我的 c 技能很生疏,所以如果这是一个愚蠢的问题,我深表歉意,但我什至没想过要寻找这个简单问题的答案。此代码编译时没有任何警告: #include int run_script( int argc,
这个问题在这里已经有了答案: Should I use char** argv or char* argv[]? (10 个答案) What does the 'array name' mean i
我有以下代码片段: int main(int argc, char *argv[]) { char line[MAXLINE]; long lineno = 0; i
我是一名优秀的程序员,十分优秀!