AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题

问题[debugging](unix)

Martin Hope
L_R
Asked: 2023-03-09 16:34:51 +0800 CST

GDB 无法下载 math.h 的调试信息

  • 5

我有一个使用math.h函数的简单时钟程序。我目前在Kubuntu 21.10,GCC版本是(Ubuntu 12.2.0-3ubuntu1) 12.2.0,GDB版本是(Ubuntu 12.1-3ubuntu2) 12.1。

程序源代码(虽然可能不需要):

#include <stdio.h>
#include <time.h>
#include <math.h>
#include <string.h>
#include <unistd.h>
#include "conio.h"
#include <sys/ioctl.h>
#include <stdlib.h>

#define PI 3.14159265358979323846264338327950288419716939937510
#define RAD_90 1.570796 // precomputed value of 90 degrees in radians
#define RAD_30 0.523599 // precomputed value of 30 degrees in radians
#define RAD_6 0.104720 // precomputed value of 6 degree in radians
#define RAD_1 0.017453 // precomputed value of 1 degree in radians

#define X 0 // x co-ordinate in array
#define Y 1 // y co-ordinate in array

int COLUMNS, ROWS;

#define CLOCK_RADIUS (COLUMNS/2)-1

#define FPS 24
#define MOVE_TO_HOME() (printf("\033[H"))
#define CLEAR_TERMINAL_SCREEN() (printf("\033[2J"))
#define cls() (CLEAR_TERMINAL_SCREEN())

void die(const char *s) {
    cls();
    printf("clock: error: %s: ", s);
    fflush(stdout);
    perror(NULL);
    fflush(stderr);
    exit(1);
}

char **output/*[ROWS][COLUMNS*2]*/;
struct tm *t = NULL;

void get_window_size(int *rows, int *cols) {;
    struct winsize ws;

    if(ioctl(STDOUT_FILENO, TIOCGWINSZ, &ws) == -1 || ws.ws_col == 0) {
        if(write(STDOUT_FILENO, "\x1b[999C\x1b[999B", 12) != 12) die("write");
        fflush(stdout);

        char buf[32];
        unsigned int i = 0;

        if(write(STDOUT_FILENO, "\x1b[6n", 4) != 4) die("write");
        printf("\r\n");
        fflush(stdout);

        while(i < (sizeof(buf)-1)) {
            if(read(STDIN_FILENO, &buf[i], 1) != 1) die("read");
            if(buf[i] == 'R') break;
            i++;
        }
        buf[i] = '\0';

        if((buf[0] != '\x1b') || (buf[1] != '[')) die("\\x1b[6n read failure");
        if(sscanf(&buf[2], "%d;%d", rows, cols) != 2) die("sscanf(146)");

        cls();
    } else {
        *cols = ws.ws_col;
        *rows = ws.ws_row;
    }
}

void print_char(char c, int x, int y) {
    if((x >= 0) && (y >= 0) && (x < COLUMNS) && (y < ROWS)) {
        output[y][x*2] = c;
    }
}

double deg_to_rad(int deg) {
    return deg*PI/180;
}

void clear_buffer() {
    for(int i = 0;i < ROWS;i++) {
        memset(output[i], ' ', COLUMNS*2);
    }
    output[ROWS-1][COLUMNS*2] = '\0';
}

void print_buffer() {
    for(int i = 0;i < ROWS;i++) {
        puts(output[i]);
    }
}

void print_circle(char body, int r, int center[]) {
    if(r == 0) {
        print_char(body, center[X], center[Y]);
        return;
    }

    int offset[2], prev_offset[2] = {-1, -1};
    double ang = 0, ang_leap;

    ang_leap = deg_to_rad((1*360)/(2*PI*r));

    if(ang_leap > RAD_1) {
        ang_leap = RAD_1;
    } else if(ang_leap == 0) {
        ang_leap = 0.0001;
    }

    while(ang <= RAD_90) {
        offset[X] = round(sin(ang)*r);
        offset[Y] = round(cos(ang)*r);

        if((offset[X] == prev_offset[X]) && (offset[Y] == prev_offset[Y])) {
            ang += ang_leap;
            continue;
        }

        print_char(body, center[X]+offset[X], center[Y]+offset[Y]); // 1st quadrant

        print_char(body, center[X]-offset[X], center[Y]+offset[Y]); // 2nd quadrant

        print_char(body, center[X]-offset[X], center[Y]-offset[Y]); // 3rd quadrant

        print_char(body, center[X]+offset[X], center[Y]-offset[Y]); // 4th quadrant

        prev_offset[X] = offset[X];
        prev_offset[Y] = offset[Y];

        ang += ang_leap;
    }
}

void print_numbers(int r, int center[]) {
    /*
    *      deg_to_rad(360/NUM_OF_NUMBERS) = ang
    *   => deg_to_rad(360/12) = ang
    *   => ang = deg_to_rad(30)
    *
    *
    *      sin(ang) = P/H
    *   =  sin(ang)*H = P
    *
    *   => offset_x = sin(ang)*r
    *      offset_y = cos(ang)*r
    */

    int offset[2];

    for(int i = 1;i <= 12;i++) {
        offset[X] = round(sin(RAD_30*i)*r);
        offset[Y] = round(cos(RAD_30*i)*r);

        if(i >= 10) {
            print_char((i/10)+'0', center[X]+offset[X], center[Y]-offset[Y]);
            print_char((i%10)+'0', center[X]+offset[X]+1, center[Y]-offset[Y]);
        } else {
            print_char(i+'0', center[X]+offset[X], center[Y]-offset[Y]);
        }
    }
}

void print_hands(int r, int center[], struct tm t) {
    int len, offset[2];
    double ang, sin_value, cos_value;
    char body;

    // second hand
    body = '.';
    len = (r*80)/100;

    ang = t.tm_sec*RAD_6;

    sin_value = sin(ang);
    cos_value = cos(ang);

    for(int i = 0;i <= len;i++) {
        offset[X] = round(sin_value*i);
        offset[Y] = round(cos_value*i);

        print_char(body, center[X]+offset[X], center[Y]-offset[Y]);
    }

    // minute hand
    body = '*';
    len = (r*65)/100;

    ang = deg_to_rad((t.tm_min*6)/*+(t.tm_sec/10)*/); // seconds adjustement causes confusion

    sin_value = sin(ang);
    cos_value = cos(ang);

    for(int i = 0;i <= len;i++) {
        offset[X] = round(sin_value*i);
        offset[Y] = round(cos_value*i);

        print_char(body, center[X]+offset[X], center[Y]-offset[Y]);
    }

    // hour hand
    body = '@';
    len = (r*40)/100;

    ang = deg_to_rad((t.tm_hour*30)+(t.tm_min/2)+(t.tm_sec/120));

    sin_value = sin(ang);
    cos_value = cos(ang);

    for(int i = 0;i <= len;i++) {
        offset[X] = round(sin_value*i);
        offset[Y] = round(cos_value*i);

        print_char(body, center[X]+offset[X], center[Y]-offset[Y]);
    }
}

struct tm *get_time() {
    time_t seconds = time(NULL);

    if(seconds == -1) {
        perror("error while calling function time()");
        return NULL;
    }

    struct tm *tm = localtime(&seconds);

    if(tm == NULL) {
        perror("error while calling function localtime()");
        return NULL;
    }

    return tm;
}

int print_clock() {
    int center[] = {COLUMNS/2, ROWS/2};

    print_circle('.', CLOCK_RADIUS, center);
    print_numbers(CLOCK_RADIUS, center);

    t = get_time();
    if(t == NULL) {
        return 1;
    }

    print_hands(CLOCK_RADIUS, center, *t);

    print_char('@', center[X], center[Y]);

    return 0;
}

void print_centered(int col_size, char *str) {
    int str_len = strlen(str);
    int start_pos = col_size-(str_len/2);
    for(int i = 0;i < start_pos;i++) {
        printf(" ");
    }
    printf("%s", str);
}

int main() {
    get_window_size(&ROWS, &COLUMNS);
    if(ROWS > COLUMNS/2) {
        COLUMNS -= 2;
        COLUMNS /= 2;
        ROWS = COLUMNS;
    } else if(COLUMNS/2 > ROWS) {
        ROWS -= 2;
        COLUMNS = ROWS;
    }
    output = malloc(sizeof(char*)*ROWS);
    for(int i = 0;i < ROWS;i++) {
        output[i] = malloc(sizeof(char)*((COLUMNS*2)+1));
    }
    CLEAR_TERMINAL_SCREEN();

    while(!kbhit()) {
        MOVE_TO_HOME();

        clear_buffer();

        if(print_clock()) {
            return 1;
        }

        print_buffer();

        print_centered(COLUMNS, asctime(t));

        usleep((1000*1000)/FPS);
    }

    for(int i = 0;i < ROWS;i++) {
        free(output[i]);
    }
    free(output);

    return 0;
}

当我使用 编译程序并gcc clock.c -lm -g使用 运行它时gdb ./a.out,我允许gdb从https://debuginfod.ubuntu.com. 我在line 175(使用sin函数)处设置断点,然后输入step并看到此错误:

Breakpoint 1, print_hands (r=17, center=0x7fffffffda20, t=...) at clock.c:175
175             sin_value = sin(ang);
(gdb) step
__sin_fma (x=0.83775999999999995) at ../sysdeps/ieee754/dbl-64/s_sin.c:201
Download failed: Invalid argument.  Continuing without source file ./math/../sysdeps/ieee754/dbl-64/s_sin.c.
201     ../sysdeps/ieee754/dbl-64/s_sin.c: No such file or directory.

如我所见,它无法sin在此处下载功能的调试信息。我尝试在互联网上搜索类似问题,但找不到任何类似问题。

我的问题是什么gdb,我该如何纠正?

debugging
  • 1 个回答
  • 15 Views
Martin Hope
rgov
Asked: 2022-12-05 09:54:39 +0800 CST

将当前脚本的输出重定向到套接字

  • 5

我正在尝试调试在远程服务器上执行的 shell 脚本,我无法访问该脚本的标准输出。我可以将输出重定向到套接字吗?

debugging
  • 1 个回答
  • 23 Views
Martin Hope
somega
Asked: 2022-07-07 01:30:39 +0800 CST

用于检测应用程序执行逻辑中的错误的工具

  • 5

我想检测应用程序执行逻辑中的错误。例如:

  • 忘记调用free()返回的地址malloc()
  • 没有关闭由返回的文件句柄open()
  • 传递给的无效标志open()
  • 传递给的无效文件句柄poll()
  • write()调用了未打开写入的 fd
  • 将无效标志传递给open()例如 open("/etc/fstab", 4)
  • 调用close()无效的 fd
  • ...

我认为还有数百个。

也许该工具可以类似于ftraceor运行strace,但包含错误调用的内核日志也足够了。

debugging programming
  • 3 个回答
  • 796 Views
Martin Hope
user2239318
Asked: 2021-11-15 23:39:59 +0800 CST

星号调试扩展质量差的音频 - rtp 乱序

  • 0

FreePBX 16.0.10.34,或者直接Asterisk 11/16/18.6.0 都是一样的,所有使用一些SIP 电话的人都遇到了奇怪的音频问题,即语音音量不断变化,另一种方式是金属声音ecc。

Audio Codec: G711 or G729
Dial echo test > record pcap 
Wireshark > Voip > show call graph and get out of sequence notation


                                             ...........Receive......... .........Transmit..........
 BridgeId ChannelId ........ UpTime.. Codec.   Count    Lost Pct  Jitter   Count    Lost Pct  Jitter RTT....
 ===========================================================================================================

          105-0000013e       00:00:25 g729     1258     589K 46884   0.000   1242       0    0   0.003   0.006

电话制造商只是获取数据包日志并消失,我该如何调试这些问题?

尝试使用 ptime 20 强制编解码器 G711,将 JITTERBUFFER 添加到回显测试上下文中:

[app-echo-test]
include => app-echo-test-custom
exten => *43,1,Set(CONNECTEDLINE(name-charset,i)=utf8)
exten => *43,n,Set(CONNECTEDLINE(name,i)=Test Eco)
exten => *43,n,Set(CONNECTEDLINE(num,i)=*43)
exten => *43,n,Answer
exten => *43,n,Set(JITTERBUFFER(adaptive)=default)
exten => *43,n,Macro(user-callerid,)
exten => *43,n,Wait(1)
exten => *43,n,Background(demo-echotest,,,app-echo-test-echo)
exten => *43,n,Goto(app-echo-test-echo,1,1)

;--== end of [app-echo-test] ==--;

似乎使用它但没有结果:

sing SIP RTP Video TOS bits 136 in TCLASS field.   == Using SIP RTP Video CoS mark 4
    -- Executing [*43@from-internal:1] Set("PJSIP/101-00000143", "CONNECTEDLINE(name-charset,i)=utf8") in new stack
    -- Executing [*43@from-internal:2] Set("PJSIP/101-00000143", "CONNECTEDLINE(name,i)=Test Eco") in new stack
    -- Executing [*43@from-internal:3] Set("PJSIP/101-00000143", "CONNECTEDLINE(num,i)=*43") in new stack
    -- Executing [*43@from-internal:4] Answer("PJSIP/101-00000143", "") in new stack
       > 0x7fc0940e4a80 -- Strict RTP learning after remote address set to: 10.7.208.157:50248
       > 0x7fc0941034e0 -- Strict RTP learning after remote address set to: 10.7.208.157:50246
       > 0x7fc0940e4a80 -- Strict RTP qualifying stream type: audio
       > 0x7fc0940e4a80 -- Strict RTP switching source address to 10.168.5.201:39519
    -- Executing [*43@from-internal:5] Set("PJSIP/101-00000143", "JITTERBUFFER(adaptive)=default") in new stack
    -- Executing [*43@from-internal:6] Macro("PJSIP/101-00000143", "user-callerid,") in new stack
    -- Executing [s@macro-user-callerid:1] Set("PJSIP/101-00000143", "TOUCH_MONITOR=1636707571.457") in new stack
    -- Executing [s@macro-user-callerid:2] Set("PJSIP/101-00000143", "AMPUSER=101") in new stack
    -- Executing [s@macro-user-callerid:3] Set("PJSIP/101-00000143", "HOTDESCKCHAN=101-00000143") in new stack
    -- Executing [s@macro-user-callerid:4] Set("PJSIP/101-00000143", "HOTDESKEXTEN=101") in new stack
    -- Executing [s@macro-user-callerid:5] Set("PJSIP/101-00000143", "HOTDESKCALL=0") in new stack
    -- Executing [s@macro-user-callerid:6] ExecIf("PJSIP/101-00000143", "0?Set(HOTDESKCALL=1)") in new stack
    -- Executing [s@macro-user-callerid:7] ExecIf("PJSIP/101-00000143", "0?Set(CALLERID(name)=)") in new stack
    -- Executing [s@macro-user-callerid:8] GotoI    sing SIP RTP Video TOS bits 136 in TCLASS field.   == Using SIP RTP Video CoS mark 4
    -- Executing [*43@from-internal:1] Set("PJSIP/101-00000143", "CONNECTEDLINE(name-charset,i)=utf8") in new stack
    -- Executing [*43@from-internal:2] Set("PJSIP/101-00000143", "CONNECTEDLINE(name,i)=Test Eco") in new stack
    -- Executing [*43@from-internal:3] Set("PJSIP/101-00000143", "CONNECTEDLINE(num,i)=*43") in new stack
    -- Executing [*43@from-internal:4] Answer("PJSIP/101-00000143", "") in new stack
       > 0x7fc0940e4a80 -- Strict RTP learning after remote address set to: 10.7.208.157:50248
       > 0x7fc0941034e0 -- Strict RTP learning after remote address set to: 10.7.208.157:50246
       > 0x7fc0940e4a80 -- Strict RTP qualifying stream type: audio
       > 0x7fc0940e4a80 -- Strict RTP switching source address to 10.168.5.201:39519
    -- Executing [*43@from-internal:5] Set("PJSIP/101-00000143", "JITTERBUFFER(adaptive)=default") in new stack
    -- Executing [*43@from-internal:6] Macro("PJSIP/101-00000143", "user-callerid,") in new stack
    -- Executing [s@macro-user-callerid:1] Set("PJSIP/101-00000143", "TOUCH_MONITOR=1636707571.457") in new stack
    -- Executing [s@macro-user-callerid:2] Set("PJSIP/101-00000143", "AMPUSER=101") in new stack
    -- Executing [s@macro-user-callerid:3] Set("PJSIP/101-00000143", "HOTDESCKCHAN=101-00000143") in new stack
    -- Executing [s@macro-user-callerid:4] Set("PJSIP/101-00000143", "HOTDESKEXTEN=101") in new stack
    -- Executing [s@macro-user-callerid:5] Set("PJSIP/101-00000143", "HOTDESKCALL=0") in new stack

更改了 PBX Asterisk 16.13.0(相同的物理电话)但相同的行为:

                                             ...........Receive......... .........Transmit..........
 BridgeId ChannelId ........ UpTime.. Codec.   Count    Lost Pct  Jitter   Count    Lost Pct  Jitter RTT....
 ===========================================================================================================

          101-00000144       00:00:34 ulaw     1744     917K 52608   0.000   1727       0    0   0.003   0.006
audio debugging
  • 1 个回答
  • 189 Views
Martin Hope
YorSubs
Asked: 2021-10-06 12:56:11 +0800 CST

bash 调试选项?

  • 0

在我看来(如果我错了,请纠正我)bash 在错误消息方面非常糟糕,这些错误消息可以正确地告诉您脚本中的问题出在哪里。例如,我经常会得到“第 953 行的错误 EOF”。这真正意味着fi在第 127 行有一个缺失。或者,另一个经典是“-bash: line 60: syntax error near unexpected token '('”。这真正意味着我已将我的函数重新声明mything() {}为别名在第 739 行alias mything=,除此之外,bash 错误指向没有实际问题的第 60 行(所以我花了一段时间才在第 739 行找到罪魁祸首)。

我试图将最热门的“bash 调试”工具加载到 VS Code 中,但我无法让它工作(我按 F5 运行,然后出现一个框,上面写着“选择调试器”,所以我选择了 bash 调试,但没有任何反应) . 我尝试了一个允许交互式运行代码的在线工具,并说它可以帮助调试,但这也没有帮助。我做了一些 PowerShell,它在报告问题根源方面做得更好。是否有方法(工具或 github 或在线上的脚本分析工具可以扫描脚本以查找函数和别名被重新声明为同名的问题以及其他类似的测试)使我们能够更好地调试 bash 脚本?

bash debugging
  • 1 个回答
  • 79 Views
Martin Hope
user3840170
Asked: 2020-02-04 04:23:23 +0800 CST

如何找到获取符号堆栈跟踪所需的 dbgsym 包?

  • 2

我在 Debian 系统上有一个核心文件。我想获得从该核心转储生成符号堆栈跟踪所需的所有调试符号包的完整列表。

我可以通过什么方式生成这样的列表?

debian debugging
  • 2 个回答
  • 486 Views
Martin Hope
dnk8n
Asked: 2019-06-18 23:49:45 +0800 CST

我有一个挂起的选项卡完成,是否可以使用 strace 来找出发生了什么?

  • 2

在我的示例中,我开始输入sudo su dkay... <tab>... 并且该命令在选项卡完成之前挂起大约一分钟sudo su dkayton。

我被建议使用 strace 来找出发生了什么。

关于如何将制表符完成的底层命令传递给 strace 的任何想法?

我尝试了什么:

我top在一个 shell 中运行以监视进程。sudo su dkay然后我在另一个外壳中立即点击标签。

然后,我尽可能快地复制了 bash 进程的 PID,这导致sudo strace -pXXX -tfo /tmp/strace.log了第三个 shell,其中 XXX 是复制的 PID。

它仍然设法捕获超过 2mb 的日志。我重复了两次,第二次更成功。

我正在寻找一种更自动的方式来完成这项工作。

autocomplete debugging
  • 1 个回答
  • 293 Views
Martin Hope
Jack Chen
Asked: 2019-06-11 06:19:39 +0800 CST

关于调试陷阱的问题

  • 0

我有一个脚本如下:

function dbgtrap {
echo "badvar is $badvar" 
}

badvar=0

function some_func {
    badvar=1
    badvar=2
    badvar=3
}

set -o functrace

trap dbgtrap DEBUG
    some_func
trap - DEBUG    # turn off the DEBUG trap

获取脚本后,我得到了输出:

badvar is 0
badvar is 0
badvar is 0
badvar is 1
badvar is 2
badvar is 3

我期待的东西像:

badvar is 0
badvar is 1
badvar is 2
badvar is 3

输出的前两行来自哪里?

shell-script debugging
  • 1 个回答
  • 658 Views
Martin Hope
Tom Hale
Asked: 2019-05-04 01:54:12 +0800 CST

在 zsh 中的 stderr 以外的其他地方直接输出 xtrace

  • 7

在 zsh 中,是否可以将跟踪输出从set -x( set -o xtrace) 定向到 stderr 以外的文件描述符?

我正在寻找一种等效的$BASH_XTRACEFD方法或一种方法来模拟相同的行为。

zsh debugging
  • 2 个回答
  • 440 Views
Martin Hope
don_crissti
Asked: 2019-01-07 11:19:30 +0800 CST

有什么方法可以使用 sed 实现“详细模式”或“调试模式”?

  • 21

有没有办法gnu sed详细说明正在运行的内容和完成的内容?
我想要一个类似“调试模式”的东西,这样我就可以看到 - 对于每一行输入 - 在脚本运行之前和之后的保持空间和模式空间的内容等。

sed debugging
  • 1 个回答
  • 13423 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve