strcpy() 함수 질문
안녕하세요.
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
int main()
{
/*
strcpy() and strncpy()
*/
// 1
char dest[100] = ""; // make sure memory is enough
char source[] = "Start programming!";
//dest = source; // Error
//dest = "Start something"; // Error
strcpy(dest, source);
puts(dest);
return 0;
}
라는 코드에서 주석 처리된 "dest = source;"과 "dest = Start something;"의 오류가 "expression must be a modifiable lvalue"임을 확인했습니다.
이는 dest가 배열의 이름이며, 배열의 이름은 메모리 갖지 않기 때문에 나타나는 오류인가요?
또 strcpy() 함수를 사용하지 않고 배열 dest에 source의 문자열을 넣으려면 다음처럼 코드를 작성하면 될까요?
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
int main()
{
/*
strcpy() and strncpy()
*/
// 1
char dest[100] = ""; // make sure memory is enough
char source[] = "Start programming!";
for (int i = 0; i < strlen(source); i++)
dest[i] = source[i];
puts(dest);
return 0;
}
답변 1
2
안녕하세요, 질문&답변 도우미 Soobak 입니다.
네, 맞습니다.
dest = source; 에서 배열의 이름은 배열의 첫 번째 원소의 주소를 가리키지만, 포인터처럼 값을 변경할 수는 없습니다.
따라서, 배열에 다른 배열의 주소를 할당하는 것은 문법적으로 잘못되었습니다.
dest = "Start somthing"; 역시 배열의 이름에 리터럴 문자열의 주소를 할당하려고 시도하므로 문법적으로 허용되지 않습니다.
문자열 리터럴의 주소는 컴파일 시간에 메모리에 저장됩니다.
strcpy() 함수를 사용하지 않고 배열 dest 에 source 의 문자열을 넣는 방법으로, 질문자님께서 제안해주신 반복문을 사용하는 것은 가능합니다.
하지만, 문자열의 끝을 나타내는 널 문자('\0')도 함께 복사해야 합니다.
따라서, strlen(source) 대신에 strlen(source) + 1 을 사용하여 널 문자의 공간을 마련해주셔야 합니다.
Export template 안됨
1
18
2
완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.
1
54
3
main 함수에서 왜 int만 선언이 되는걸까요
1
56
2
8비트 2진수 변환시 왜 1을 더해야하나요?
1
54
2
혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?
1
49
1
프로토타입과 함수간의 인자 불일치
1
73
2
12.12 헤더 관련 질문
1
60
2
Visual Studio Community 2026 사용 문의
1
137
2
Q. 15:30, 부호가 있는 8비트 정수 질문
1
61
2
getchar(), putchar()
1
93
3
강의자리ㅛ
1
80
2
비주얼스튜디오코드로 공부해도 상관없나요?
1
113
2
소스파일안에 여러 파일
1
75
2
F5와 F7의 차이
1
76
2
c = TWO * (a+b); 에서 a와 b는?
1
58
2
; 세미콜론을 붙이는 기준에 문의
1
69
1
Step over 기능 문의
1
53
2
2.6 강의 따옴표 출력 규칙 문의
1
74
2
int main 함수 관련 오류 문의
1
67
2
13.4 words[0]
0
60
2
11.7 함수를 구현해 봤습니다.
1
62
2
11.6 직접 strcmp와 strncmp를 구현해 보았습니다.
1
65
2
11.6 my_strcat과 my_strncat을 구현해봤습니다.
1
53
2
11.6 fit_str함수를 구현해 봤습니다.
1
53
2





