c - 将字符指针转换为交换函数的 void 指针的问题

标签 c pointers void-pointers

我正在尝试交换 char * 字符串中的字符。我希望交换函数接受 void *[] 是通用的,但我得到了一个奇怪的行为,我不知道为什么。

我的主要内容:

int main(int argc, char *argv[])
{
    size_t n_bytes = 100;
    int bytes;
    char *my_input;
    int numeric = 0;

    my_input = (char *) malloc(n_bytes + 1);

    /* if -n option is set, sort numerically versus lexicographically. */
    if (argc > 1 && strcmp(argv[1], "-n") == 0) numeric = 1;
    while(getline(&my_input, &n_bytes, stdin) && strlen(my_input) > 1)
    {
        swap((void **) my_input, 0, 2);
    }

    free(my_input);
    return 0;
}

将函数与 printf-ing 交换以进行“调试”:

void swap(void *v[], int i, int j)
{
    void *temp;
    printf("i: %d j: %d\n", i, j);
    for(int x = 0; x < strlen(v); x++)
    {
        printf("%c\n", v[x]);
    }
    temp = v[i];
    v[i] = v[j];
    v[j] = temp;
    printf("first letter: %c", v[j]);
}

打印循环中出现的是用户输入的字符串的第一个字符(例如,如果 input ==“hello”,则打印的第一个字符将为“h”)。打印的其余部分始终是垃圾,而不是其余字符。打印 v[j] 中保存的内容的 printf 打印出交换的值,该值将是第一个字符的值。我猜我错过了一个明显的概念,但似乎无法弄清楚。

最佳答案

您正在处理“字符数组”,而不是“指向字符的指针数组”,对吗?

void swapChar(char *v, size_t i, size_t j)
{
    char temp;
    printf("i: %zu j: %zu\n", i, j);
    int x;
    for(x = 0; x < strlen(v); x++)
    {
        printf("%c\n", v[x]));
    }
    temp = v[i];
    v[i] = v[j];
    v[j] = temp;
    printf("first letter: %c\n", v[j]));
}

如果你想让它通用,你必须告诉它元素的大小:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void swap(char *v, size_t i, size_t j, size_t size)
{
    char *temp = malloc(size);
    memcpy(temp, v + i * size, size);
    memcpy(v + i * size, v + j * size, size);
    memcpy(v + j * size, temp, size);
    free(temp);
}

int main(int argc, char *argv[])
{
    char string[] = "Test string";
    swap(string, 0, 1, sizeof *string);
    puts(string);
    return 0;
}

但是通用版本无法“printf”任何内容,因为 swap() 不知道如何解释字节。例如,0000000011111111是一个short还是两个char?你还没有告诉它。

您还可以在 C11 中使用 _Generic 宏编写一些脏东西。如果您的程序不必严格遵守,您可以利用 typeof()

关于c - 将字符指针转换为交换函数的 void 指针的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35531249/

相关文章:

c - 在运行时永久转换 void 指针

void-pointers - 如何合并两个声明为 void 指针的数组?

c++ - 使用 void* 时如何不损坏地获取数据?

casting - 在 D 中传递带有泛型参数的函数指针

c - 遍历指向其他数组的数组

c - 关于如何使用指针将数组作为函数参数传递的代码片段的说明?

c - 如何保护 isr 和常规函数共享的全局变量?

android - Android NDK 中的 Openssl X509_set_pubkey() 崩溃

c - 如何使用C中的指针在结构类型数组中获取字符串输入

C: 指针混淆