프로그램 오류로 인해 운영 체제에 의해 프로세스가 종료되면 프로세스가 코어를 덤프합니다. 이런 일이 발생하는 가장 일반적인 이유는 프로그램이 NULL 또는 메모리 영역 외부의 일부 값과 같은 유효하지 않은 포인터 값에 액세스하기 때문입니다. 이 프로세스의 일부로 운영 체제는 발생한 상황을 분석할 수 있도록 정보를 파일에 기록하려고 시도합니다.
이 코어는 다음과 같이 프로그램을 진단하고 디버깅하는 데 사용할 수 있습니다.
기본적으로 코어는 /proc/sys/kernel 디렉터리에 덤프됩니다. 커널을 디버깅하려면 프로그램을 -g 옵션으로 컴파일해야 합니다. 코어가 있으면 gdb -
$ gdb nameOfExecutable core
를 실행하세요. 이렇게 하면 gdb에서 코어가 열리고 이제 디버깅을 계속할 수 있습니다. gdb 사용 방법을 모르는 경우 다음 링크를 사용하여 자세히 알아볼 수 있습니다: https://www.ibm.com/developerworks/library/l-gdb/
위 내용은 C/C++에서 코어를 디버깅하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!