SS945
V2EX  ›  C

Linux 上 C 的程序遇到个异常退出问题,局部变量大小有限制??

  •  
  •   SS945 · Aug 6, 2024 · 4289 views
    This topic created in 643 days ago, the information mentioned may be changed or developed.
    #include <stdio.h>
    #include <stdlib.h>
    #include <unistd.h>
    #include <errno.h>
    #include <sys/types.h>
    #include <sys/wait.h>
    #include <signal.h>
    #include <sys/prctl.h>
    #include <string.h>
    #include <pthread.h>
    #include <liblx_api/lx_api.h>


    static void *client_check(void *arg)
    {
    printf("###### %s %d ######\n", __FUNCTION__, __LINE__);
    #define SZ_BUF 32768 /* 32*1024 */
    char post_data[SZ_BUF] = {0};
    char enc_msg[SZ_BUF + 16] = {0};
    unsigned char cipher_data[SZ_BUF] = {0};
    unsigned char cipher_str[SZ_BUF] = {0};
    unsigned char test[SZ_BUF] = {0};
    strcpy((char *)cipher_data, "AAAAAAAAAAAAAAAAA");
    strcpy((char *)cipher_str, "CCCCCCCCCCCCCCC");
    strcpy((char *)enc_msg, "DDDDDDDDDDDDDDDD");
    strcpy((char *)post_data, "EEEEEEEEEEEEEEE");
    strcpy((char *)test, "FFFFFFFFFFFFFFFFF");
    printf("###### %s %d ######\n", __FUNCTION__, __LINE__);

    return 0;
    }


    int main(void)
    {
    pthread_t tidp;
    printf("\n######## start #####\n");
    test_service(); //工作正常
    if (pthread_create(&tidp, NULL, client_check, NULL) != 0) //异常退出
    {
    LX_NGX_ERR("pthread_create error!\n");
    }

    printf("AAAAAAA hello world!!!\n");
    return 0;
    }


    上面的程序如果正常在 main 里面跑就是好的,但一放到 pthread_create 里面用线程跑就不行,放在 x86 上就可以,但放在我的板子里板就不行,这是什么鬼????
    7 replies    2024-08-06 16:43:23 +08:00
    rickc137
        1
    rickc137  
       Aug 6, 2024
    可能超线程资源限制了吧,用 gdb 能调试吗
    SS945
        2
    SS945  
    OP
       Aug 6, 2024
    @rickc137 目标板上没有 gdb ,头痛。
    sagaxu
        3
    sagaxu  
       Aug 6, 2024
    获取一下线程栈的大小看看有没有差别
    xiaozhaoz
        4
    xiaozhaoz  
       Aug 6, 2024   ❤️ 2
    pthread_init_attr()
    pthread_attr_getstack()
    看默认栈大小。

    不同的 libc 实现,线程栈大小不同,glibc 默认 2M 。
    ulimit -s 也会限制栈大小。

    可以统一通过 pthread_create 第二个参数设置栈大小。
    SS945
        5
    SS945  
    OP
       Aug 6, 2024
    @xiaozhaoz 确实。。。这板子只有 128K 。。。谢谢
    sujin190
        6
    sujin190  
       Aug 6, 2024
    都这么大内存了不堆上分配很容易遇到不可预测问题吧
    proxytoworld
        7
    proxytoworld  
       Aug 6, 2024
    32m 为什么不堆分配
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5453 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 68ms · UTC 01:19 · PVG 09:19 · LAX 18:19 · JFK 21:19
    ♥ Do have faith in what you're doing.