목록⚙️Computer System/C (26)
코드네임 :

2/4 - 절반만..오늘 좀 2학년 계획 좀 대충 짜야겠음 (내일 나머지) 오ㅏ 동적할당은 다 까먹어서 진짜 흑흑 책 설명 + 채찍피티의 힘을 빌려 이해해보도록 하쟈 동적할당 -프로그램 실행중에 저장공간을 할당하기 - 처리할 데이터 종류나 수를 장담할 수 없다면 프로그램 실행 중 메모리를 동적할당 할때 : malloc 반환할 때 : free #include malloc함수의 반화값이 NULL 포인터인지 반드시 확인하고 사용!(479p의 9행처럼) -> NULL(0)은 메모리 부족을 뜻함(할당 실패) exit 함수 : 어느경우든 프로그램 바로 종료 (예외상황이 발생해 프로그램 종료시 인수로 1을 주고 호출 ( exit(1) )) malloc뒤에는 항상 free가 (사용끝난 저장공간은 반드시 반환) mall..
2/6 므ㅓ여 이거 처음 보는데 (아닐수도 내가 기억 못하는 걸수도 아니 일단 에타에 질문함... 2,3학년때 나오냐고.... 아니 나 진짜 처음 본단 말임 ㅜㅜ - 나온답니다 ㅎ 이중포인터 (**) 포인터의 주소는 이중포인터에 저장됨 **ppi : 첫번째 * = ppi가 가리키는 자료형이 포인터임을 뜻함, 두번째 * = ppi자신이 포인터임을 뜻함 (즉 **ppi는 ppi가 가리키는 포인터가 가리키는 값) (447p 아래부분에 자세한 설명) 1. 포인터를 변수명으로 쓰면 그 안의 값이 됩니다. 2. 포인터에 & 연산을 하면 포인터 변수의 주소가 됩니다. (포인터가 변수이므로 주소연산사 사용 가능) 3. 포인터 * 연산은 화살표를 따라갑니다. (그것이 가리키는 대상) 451p - 바꾸고자 하면 함수의 인..
2/4 - 어제 가족모임?이라 못햇듬 ㅠ 다차원 배열 2차원 초기화 시 행의 수 생략가능, 열의 수 생략불가 문자열은 항상 뒤에 '\0' null 문자까지 포함한다는 사실을 잊지 말것!! 아놔 자꾸 ==을 =으로 씀ㅣ;;; 제발;;;;';;;;;; 하 그리고 (i==j) || (i == (4-j)) 할 때 여기 있는 모든 괄호 쓰는 것도 제발 그만 까먹으셈ㅜㅜ 포인터 배열 같은 포인터가 많이 필요한 경우 배열명은 첫번째 요소의 주소 433p 포인터 배열의 초기화 : 문자열 시작 주소만 배열 요소에 저장 char 배열의 초기화 : 문자열 자체를 배열의 공간에 저장 440p 문제 2번!! [i][i]자너 441p 문제 - Wow.. 배열이 *pary[4]; 이런식으로 선언되었으면 index는 0~3만 가능한..
지역 변수 : 해당 함수나 블록 내에서만 쓸 수 있는 변수 전역 변수 : 전체 함수 안에서 쓸 수 있는 변수 코드블럭(해당 함수)내에 전역변수와 같은 이름의 지역변수를 선언하면 거기서는 전역변수를 사용할수 업따@@!! 자동 지역변수 (auto 사용, 생략 가능) : 해당 함수가 '호출'될 때마다 생성됨.(즉 호출될때마다 초기화된 값으로 나옴) 정적 지역변수 (static 사용) : 해당 함수가 '호출'될때, 저장된 마지막 값으로 나옴 (393p) ⬆️ 레지스터 변수 - 전역변수는 안됨 - 주소 구하기 불가 값을 복사해서 전달하기 (400p) main 함수의 a를 다른 함수에 복사해주면 해당 매개변수의 메모리공간이 새로 잡히면서 변수 a값을 전달 (401p) 402p 코드 데이터 공유 방식 값 복사 전달 ..

2/1 - 어제 놂 ㅋㅋ ㅜㅜ 문자열은 배열의 구조를 가지며, 첫번째 문자의 주소로 쓰임 주소로 접근해서 문자열을 바꾸지 말것!! (ex. *"apple"='t' (첫번째 문자를 t로 바꿔라) 350p 여기서 잠깐!이 뭔 말인지 모르겟거 -> 아냐!!!! 그 최적화 여부 확인하는 코드 써보니까 바로 이해 됨 ㅋㅋㅋ 같은 문자열이면 어디에 저장해도 주소가 같네영 (같은 문자열 상수를 여러번 사용할 때 하나의 문자열에만 메모리를 저장하고 그 주소를 공유) scanf는 공백문자, 탭문자, 개행문자\n 이전까지만 저장함 gets는 공백문자, 탭문자, 개행문자\n 이후까지도 저장함 fgets 함수는 gets와 똑같으나(\n의 처리방식은 다르다네요) 최대 배열 크기까지만 문자열 입력 ( 배열의 크기 확인 가능 ) ..
11/27 + 11/30 제어문자 printf("대문자 : %c %c", cap, '\n'); //여기선 걍"%c\n"이랑 똑같.. 그 대신 처음처럼 쓴다면 바로 아래 코드에서 제어할 수 있음 scanf("%c%c", &ch1, &ch2); //if 여기서 a만 입력한다면 ch1에는 'a', ch2에는 '\n'이 저장되어 printf("[%c%c]", ch1, ch2); // 출력 시 [a 엔터 ]가 뜬다 getchar, putchar - 문자 전용 입출력 함수 getchar()한번 더 써야해서 입력 버퍼(의 개행문자(\n)) 비우는 법 : getchar();를 써준다... ch = getchar(); //ch에 문자 '하나'를 입력받음 342p 3번, 도전 문제

1/25 - 포인터와 배열 ... 하 어렵다 배열명 = 첫번째 배열 요소의 주소값 주소 + 정수 == 주소 + (정수 * 주소를 구한 변수의 크기) 307p 문제1 반쯤 틀려서.. ㅜㅜ 배열명ary = 첫번째 배열요소 ary[0]의 주소 포인터 연산식 *(ary+1) = ary[1] (pa가 첫번째 배열요소의 시작 주소를 가리킨다면, (double *pa = ary; 이면)) pa + 2 = 세번째 배열 요소 시작 주소 pa[3] = *(pa+3) (double *pb = ary +2; 이면,) *pb = ary[2] pb - pa = ( pb 가 가리키는 시작주소 - pa가 가리키는 시작주소 ) / sizeof(double) 308p 문제2도 반쯤 틀림.. int ary[5] = {1,2,3,4,5};..
1/24 - 포인터 오늘부터 코드를 git 리포지토리에 연결하시오.. (했듬!!!) https://github.com/codenameVien/C_HONGONG 주소 = 메모리 공간의 '시작' 주소 %u : 부호없는 10진수 출력 %p : 16진수 출력 (주소 전용 변환 문자) int형 주소 : ㅇㅇ번지 ~ ㅇㅇ번지+3 (4바이트) double형 주소: ㅇㅇ번지 ~ ㅇㅇ번지+7 (8바이트) char형 주소: ㅇㅇ번지 (1바이트) pa = &a; 에서 만약 변수 a가 메모리 100번지부터 103번까지 할당되었다면 주소값 100이 pa에 저장됨. (시작 주소가 저장됨!!!!) *pa=10; == a=10; (*pa도 변수 a와 마찬가지로 = 의 왼쪽에 온다면 변수의 저장공간으로, 오른쪽에 온다면 pa가 가리키..