채널 공문 No.17 GetSignStrArray
1. GetSignStrray 설명
이 공문서는 주로 구분자의 문자열을 2차원 지침에 분할하여 저장하는 것이다.
1.1 먼저 공문 코드를 붙인다
#include "kernel/syspub.h"
int GetSignStrArray(char *s, char **m, const char *delimiters, char ***argvp)
{
char *t;
char *snew, *p, *q, *k;
int numtokens;
int i, j, l, f;
snew = s;
if ((t = (char *)calloc(strlen(snew) + 1, sizeof(char))) == NULL)
{
argvp = NULL;
numtokens = -1;
}
else
{
strcpy(t, snew);
numtokens = 0; /***** *****/
p = t;
for(;;)
{
q = strpbrk(p, delimiters);
if (q == NULL) break;
l = q - p;
for(j = 0, f = 0; j < l; j++)
if (p[j] == '\\') f++;
if (l > 0 && *(q - 1) == '\\' && f % 2 )
{
q++;
p = q;
continue;
}
q++;
p = q;
numtokens++;
}
if ((*argvp = calloc(numtokens + 1, sizeof(char * ))) == NULL)
{
free(t);
numtokens = -1;
}
else
{
strcpy(t, snew);
if (numtokens == 0) **argvp = t;
else
{
k = t;
*m = t;
p = k;
for(i = 0; i < numtokens;)
{
q = strpbrk(p, delimiters);
l = q - p;
for(j = 0, f = 0; j < l; j++)
if (p[j] == '\\') f++;
if (l > 0 && *(q - 1) == '\\' && f % 2)
{
q++;
p = q;
continue;
3}
*q = 0;
*((*argvp) + i) = k;
q++;
p = q;
k = p;
i++;
}
}
}
}
return numtokens;
}
1.2 매개 변수 설명
#include "kernel/syspub.h"
int GetSignStrArray(char *s, char **m, const char *delimiters, char ***argvp)
{
char *t;
char *snew, *p, *q, *k;
int numtokens;
int i, j, l, f;
snew = s;
if ((t = (char *)calloc(strlen(snew) + 1, sizeof(char))) == NULL)
{
argvp = NULL;
numtokens = -1;
}
else
{
strcpy(t, snew);
numtokens = 0; /***** *****/
p = t;
for(;;)
{
q = strpbrk(p, delimiters);
if (q == NULL) break;
l = q - p;
for(j = 0, f = 0; j < l; j++)
if (p[j] == '\\') f++;
if (l > 0 && *(q - 1) == '\\' && f % 2 )
{
q++;
p = q;
continue;
}
q++;
p = q;
numtokens++;
}
if ((*argvp = calloc(numtokens + 1, sizeof(char * ))) == NULL)
{
free(t);
numtokens = -1;
}
else
{
strcpy(t, snew);
if (numtokens == 0) **argvp = t;
else
{
k = t;
*m = t;
p = k;
for(i = 0; i < numtokens;)
{
q = strpbrk(p, delimiters);
l = q - p;
for(j = 0, f = 0; j < l; j++)
if (p[j] == '\\') f++;
if (l > 0 && *(q - 1) == '\\' && f % 2)
{
q++;
p = q;
continue;
3}
*q = 0;
*((*argvp) + i) = k;
q++;
p = q;
k = p;
i++;
}
}
}
}
return numtokens;
}
1.3 호출된 예시 프로그램
#include "kernel/syspub.h"
int main()
{
char Buf[51]="bankAcc|Na\\|me|123.45|1|";
char **arg=NULL;
char *m=NULL;
int num =0;
num = GetSignStrArray( Buf, &m, "|", &arg);
printf("[%s] [%d]
", m, num );
printf("[%s] [%s] [%s] [%s]
", arg[0], arg[1],arg[2], arg[3]);
free(m);
free(arg);
return 0;
}
/*** ***
/stdcop/xip/src/kernel/kpublib.1.1/sample>GetSignStrArray_samp
[bankAcc] [4]
[bankAcc] [Na\|me] [123.45] [1]
***************/
2. 프로그램을 볼 때의 의문점
문제는 왜 매개 변수 m를 입력해야 하고free를 입력해야 합니까?
이것은 프로그램 내용을 상세하게 분석해야 한다.프로그램 내부calloc는 Buf 크기와 같은 메모리를 가지고 있으며 메모리의 주소를 m에 부여합니다.그런 다음 구분자를'\0'으로 덮어씁니다.그리고arg[n]에 사용하도록 제공합니다.따라서 Buf의 메모리를 직접 사용하면 Buf의 메모리에 있는 내용이 수정될 수 있는지 보장할 수 없습니다.상수 문자열이면 정적 영역의 상수를 직접 수정하면 프로그램core가 발생합니다.
문제arg가 무엇입니까? 왜free(m) 이후에free(arg)가 필요합니까?
프로그램에서: if ((*argvp = calloc(numtokens + 1, sizeof(char * ))) == NULL)
*argvp는 바로 우리의 2차원 지침의 1차arg이다. 그래서 위의 코드는argvp에 메모리를 분배한 것과 같다. 이 메모리에 저장된 데이터는 *argvp 유형의 데이터이다.프로그램 중 * (*argvp) + i) = k;*(*argvp)에 값을 부여하는 것으로 간략하게 볼 수 있습니다.바로 *argvp에 저장된 원소(실제 지침)에 값을 부여하여 m이 신청한 메모리를 가리키게 하는 것이다. 앞에서 분석한 바와 같이 m메모리는 부등액의 연속적인 메모리로 나뉘어져 있고 각 단락의 주소는 현재 (*argvp)내의 원소의 값이다.따라서free(arg)는arg가 차지하는 메모리를 방출하고 내부에는arg[0]에서arg[n]까지의 바늘 요소를 저장한다.free(m)는arg[0]가 가리키는 메모리를 방출하는 것으로 *arg[0]로 이해할 수 있는 메모리입니다.
예 프로그램 프로그램에서 코드를 직접 사용합니다: printf("[%s] [%s] [%s] [%s]
", arg[0], arg[1],arg[2], arg[3]);
그러면 이것은 수조의 작성법입니다.arg는 도대체 지침입니까 아니면 수조입니까?
이 문제의 상세한 내용은 에서 두 장의 시간을 들여 토론했고 9장에서 수조와 10장에서 지침을 재론했다.이 프로그램에서 이렇게 쓴 신기한 점은 바늘을 사용하고 있다는 것을 똑똑히 알지 못하고arg가 2차원수조라고 생각하면 arg[0]와arg[1]의 길이가 다르다는 것을 발견할 수 있다는 것이다.그러나 2차원 그룹의 모든 1차원 그룹의 길이는 같지 않다. 이것은 2차원 그룹의 성명에서 실현될 수 없다. 왜냐하면arg[1], 즉arg+1의 이 1이 몇 비트 단위인지 모르기 때문이다.그래서 여기서 결론은 ARg는 하나의 지침이지 수조가 아니라 ARg 쓰기 방법에서 ARg+1*sizeof(char*) 등가를 ARg[1]로 썼다는 것이다.이런 문법은 이미지에서 하나의arg[][] 유형의 2차원 그룹을 얻어냈는데 작은 무상공으로 모의한 72묘기와 이곡동공의 묘미가 있다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSON
JSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다.
그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다.
저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.
", arg[0], arg[1],arg[2], arg[3]);
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.