#掉过的坑#C语言写Python扩展,PyMem_Malloc崩溃的问题

在C语言中编写Python扩展时遇到崩溃问题,原因是未正确包含头文件,导致编译器错误地将PyMem_Malloc的返回值视为32位整数并进行符号扩展,最终在memcpy时引发非法地址访问。解决方案是确保在源文件中包含或显式声明PyMem_Malloc返回类型为void*。
摘要由CSDN通过智能技术生成

问题描述

C写python扩展,在执行208行之前拨错。黄色小箭头表示“This is the next statement will be executed”,所以问题出在memcpy这行,然而这是C标准库的函数,不太可能出问题。尝试自己写了一个函数,代替memcpy,报错一样,所以问题不在这里。
在这里插入图片描述
在这里插入图片描述

找Bug

但是同一个project中也有其他.c文件使用了memcpy,是没有问题的。

到汇编代码看看,非法访问的地址是怎么产生的。
在这里插入图片描述
报错的地方是上面这里,访问寄存器r15所存的地址报错,r15的地址非法。
在这里插入图片描述
在寄存器监视器中,可以看到r15的值,0x000000001DF42200,; 在64位机器上,16G内存,编译

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用C语言实现SCHED_FIFO算法的代码示例: ```c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sched.h> #include <errno.h> #define STACK_SIZE 1024*1024 void* thread_function(void* arg); int main() { int thread_id; pthread_t thread; pthread_attr_t attr; struct sched_param param; int policy; void* stack; // 分配线程栈 stack = malloc(STACK_SIZE); if (stack == NULL) { perror("malloc"); exit(EXIT_FAILURE); } // 初始化线程属性 if (pthread_attr_init(&attr) != 0) { perror("pthread_attr_init"); exit(EXIT_FAILURE); } // 设置线程栈 if (pthread_attr_setstack(&attr, stack, STACK_SIZE) != 0) { perror("pthread_attr_setstack"); exit(EXIT_FAILURE); } // 设置调度策略为SCHED_FIFO policy = SCHED_FIFO; if (pthread_attr_setschedpolicy(&attr, policy) != 0) { perror("pthread_attr_setschedpolicy"); exit(EXIT_FAILURE); } // 设置线程优先级 param.sched_priority = 50; if (pthread_attr_setschedparam(&attr, &param) != 0) { perror("pthread_attr_setschedparam"); exit(EXIT_FAILURE); } // 创建线程 if (pthread_create(&thread, &attr, &thread_function, NULL) != 0) { perror("pthread_create"); exit(EXIT_FAILURE); } // 等待线程结束 if (pthread_join(thread, NULL) != 0) { perror("pthread_join"); exit(EXIT_FAILURE); } // 销毁线程属性 if (pthread_attr_destroy(&attr) != 0) { perror("pthread_attr_destroy"); exit(EXIT_FAILURE); } free(stack); exit(EXIT_SUCCESS); } void* thread_function(void* arg) { // 打印线程信息 printf("Thread running.\n"); printf("Thread priority: %d\n", sched_get_priority_min(SCHED_FIFO)); printf("Thread policy: %d\n", sched_getscheduler(0)); // 让线程休眠5秒钟 sleep(5); printf("Thread finished.\n"); return NULL; } ``` 在以上示例中,我们使用了pthread库来创建线程,设置线程属性和等待线程结束。在主函数中,我们首先分配线程栈,然后初始化线程属性。接着,我们设置线程栈和调度策略为SCHED_FIFO,并设置线程优先级为50。然后,我们创建线程,等待线程结束,销毁线程属性,释放线程栈,并退出程序。 在线程函数中,我们打印线程信息,让线程休眠5秒钟,然后打印线程结束信息并返回NULL。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值