gpt4 book ai didi

c - 边界检查字符串指针以获取 C 函数中的返回值

转载 作者:太空宇宙 更新时间:2023-11-04 01:02:24 25 4
gpt4 key购买 nike

<分区>

这是其中一个“我知道有更好的方法”的问题。

下面的代码来 self 正在做的一个更大的项目,将十六进制值转换为二进制字符串的辅助函数隐藏在代码深处。

本质上,我想确保*return_string指向的char数组有足够的空间容纳函数生成的二进制字符串。

就目前而言,如果我没有分配足够的内存,我会得到一个 SIGABRT。如果我只返回 -1 会优雅得多。

我所做的研究告诉我,我正在尝试做的事情有点棘手,因为实际上没有办法通过指针对空数组进行边界检查。

由于我不明白的原因,如果我使用普通宏:

#define ARRAYSIZE(arr) (sizeof(arr)/sizeof(arr[0]))

*return_string 上,我总是得到相同的值。我是 C 的新手 - 我确信我在这里遗漏了一些基本的东西。

无论如何,这是代码。大家有什么推荐的?谢谢!

(仅供引用 - 我知道正如所写,我没有分配足够的内存)

(仅供引用 - 我也知道这不是最快的十六进制到二进制转换的实现。O(n) 对于这个特定应用程序已经足够了)

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

int hex_string_to_bin_string(char *return_string, size_t bin_length, const char *input);

int main(int argc, const char * argv[]) {

char return_string1[12];
char return_string2[12];
char return_string3[12];

char input1[8] = "0x4708";
char input2[8] = "4708";
char bad_input[8] = "47Q8";

fprintf(stderr, "answer should be:\t\t\t 0100011100001000\n");

//test string 1
if(hex_string_to_bin_string(return_string1, 16, input1) < 0 ) {

fprintf(stderr, "FAILED return string 1\n");

} else {

fprintf(stderr, "return string 1:\t\t\t %s\n", return_string1);
}

//test string 2
if(hex_string_to_bin_string(return_string2, 16, input2) < 0 ) {

fprintf(stderr, "FAILED return string 2\n");

} else {

fprintf(stderr, "return string 2:\t\t\t %s\n", return_string2);
}

//test bad input
if(hex_string_to_bin_string(return_string3, 16, bad_input) < 0) {
fprintf(stderr, "PASSED bad character test\n");
}

else {

fprintf(stderr, "FAILED bad character test\n");
}

return 0;
}

int hex_string_to_bin_string(char *return_string, size_t bin_length, const char *input) {

/*
0 - 0000
1 - 0001
2 - 0010
3 - 0011
4 - 0100
5 - 0101
6 - 0110
7 - 0111
8 - 1000
9 - 1001
A - 1010
B - 1011
C - 1100
D - 1101
E - 1110
F - 1111
*/

//check input to make sure length is good
if(strlen(input) == 0 ) {

return -1;
}

//check for leading '0x' and strip if necessary
if(input[0] == '0' && input[1] == 'x') {
input += 2;
}

//loop through input and replace
int i;

char bits[5];

for(i=0; i<strlen(input); i++) {

switch(input[i]) {

case '0': {

if( snprintf(bits, sizeof(bits), "0000") < 0) {

return -1;
}

break;
}
case '1': {

if( snprintf(bits, sizeof(bits), "0001") < 0) {

return -1;
}

break;
}
case '2': {

if( snprintf(bits, sizeof(bits), "0010") < 0) {

return -1;
}

break;
}
case '3': {

if( snprintf(bits, sizeof(bits), "0011") < 0) {

return -1;
}

break;
}
case '4': {

if( snprintf(bits, sizeof(bits), "0100") < 0) {

return -1;
}

break;
}
case '5': {

if( snprintf(bits, sizeof(bits), "0101") < 0) {

return -1;
}

break;
}
case '6': {

if( snprintf(bits, sizeof(bits), "0110") < 0) {

return -1;
}

break;
}
case '7': {

if( snprintf(bits, sizeof(bits), "0111") < 0) {

return -1;
}

break;
}
case '8': {

if( snprintf(bits, sizeof(bits), "1000") < 0) {

return -1;
}

break;
}
case '9': {

if( snprintf(bits, sizeof(bits), "1001") < 0) {

return -1;
}

break;
}
case 'A': {

if( snprintf(bits, sizeof(bits), "1010") < 0) {

return -1;
}

break;
}
case 'B': {

if( snprintf(bits, sizeof(bits), "1011") < 0) {

return -1;
}

break;
}
case 'C': {

if( snprintf(bits, sizeof(bits), "1100") < 0) {

return -1;
}

break;
}
case 'D': {

if( snprintf(bits, sizeof(bits), "1101") < 0) {

return -1;
}

break;
}
case 'E': {

if( snprintf(bits, sizeof(bits), "1110") < 0) {

return -1;
}

break;
}
case 'F': {

if( snprintf(bits, sizeof(bits), "1111") < 0) {

return -1;
}

break;
}

default: {

return -1;
}
}

if(i == 0) {
snprintf(return_string, bin_length+1, "%s", bits);
}

else {
snprintf(return_string, bin_length+1, "%s%s", return_string, bits);
}
}

return 0;
}

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com