TaskDelay와 printf 순서
131
작성한 질문수 1
1번 실습 파일에 printf 를 찍을 때 vTaskDelay를 하고나서 왜 Printf를 찍나여?
뭔가 의미상으론 태스크가 할일(Printf 찍는 것)을 하고 Delay에 빠지는게 맞는 것 같은데 왜 TaskDelay 이후에 printf를 찍는 지 궁금합니다.
vTaskDelay (pdMS_TO_TICKS (1000)); // 스스로 휴면상태에 들어감 Blocked로 다시 1000ms 후running
printf("b"); fflush(stdout); // 문자 'a' 출력
답변 2
0
안녕하세요. establers님!
태스크 실행 → 1초 대기(vTaskDelay) → 깨어난 후 “b” 출력 → 다시 대기.
printf 을 이용해서 시스템이 태스크를 어떻게 스케줄링하는지 확인하거나, 실행 주기를 측정하는 데 도움을 줄 수 있습니다.
0
안녕하세요, 인프런 AI 인턴입니다. establers님!
질문 주신 내용은 임베디드 프로그래밍에서 태스크 스케줄링과 관련이 있습니다. vTaskDelay() 함수는 FreeRTOS에서 주로 태스크가 주기적인 작업을 수행할 때 주기를 제어하기 위해 사용됩니다. 정확한 주기적인 수행을 보장하기 위해 vTaskDelay()를 태스크가 실행되기 시작할 때 호출하는 방식을 자주 사용합니다.
이유
주기적 시간 맞추기:
vTaskDelay()를 먼저 호출하면, 정확히 일정 시간이 지난 후에 태스크가 다시 실행됩니다. 이는 태스크의 수행 주기를 일정하게 맞추는 데 도움이 됩니다. 이를 통해 태스크가 처음 실행된 시점부터 몇 밀리초 후에 다시 실행되도록 맞출 수 있습니다.실시간 시스템 특성:
임베디드 환경에서는 일정 주기를 지키는 일이 중요합니다. 그래서 주기적인 작업을 먼저 지연시키고, 그다음 작업을 수행하는 방식으로 순서를 맞추기도 합니다.구현상의 편의성:
실질적으로 디버깅이나 로깅용으로printf를 사용하면서 주기를 조절하고자 하는 경우가 많습니다.printf가 실행된 이후 주기를 지키기보다는, 다음 주기를 준비하는 식으로 사용하는 것이죠.
관련하여 타 스레드에서 비슷한 질문이 논의된 적이 있습니다. 자세한 내용은 아래 링크에서 확인해 보실 수 있습니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
만약에 포팅을 할때 1년에 한번 잡는 치명적인 문제를 해결하는 코드가 들어갔다고 가정하면
0
57
2
STM32 포팅할 때 STM32 Project가 없음
0
148
2
FreeRTOS 멀티코어 지원안됨?
0
83
2
[소스코드 분석-configUSE_TIME_SLICING] TASK1,2의 우선순위가 동일할 때, configUSE_TIME_SLICING값 변경에 따른 출력 변화
0
82
2
포팅 부탁드립니다!
0
57
1
포팅 부탁드립니다. <NUCLEO-G071RB>
0
64
2
상호배제 후 되지를 않아서 질문드립니다.
0
59
1
수료증 발급 기준 수정 요청
1
69
1
재진입가능여부에 관한 질문
1
66
1
01_TASKMAN프로젝트 디버깅 모드 실패
1
76
2
그러면 malloc/free가 아닌 동적할당자를 써서 메모리를 할당했기떄문에
1
69
2
실행순서
1
74
2
uart 전송중에는 스위칭이 금지되나요?
1
71
2
스택오버플로우 실습 중 stack size 설정 질문
0
79
2
포팅 원합니다.
2
75
2
코루틴 실습질문
1
99
2
TODO 2번 문제
1
140
4
10. 선점형 커널 그림 설명중 우선순위가 반대인 경우에도 Task B가 먼저 수행되나요?
1
80
2
디버거모드에 진입이 안됩니다.
0
175
2
prvExampleTaskHook 함수 호출 부분에 대해 문의드립니다.
0
119
2
보드 STM32H735IG와 강의 호환 여부 문의
1
151
3
[ L152RE ] 원샷 소프트타이머 실행 잘 되시나요?
1
157
2
Deferred Interrupt Processing 샘플 예제 문의 드립니다.
1
119
2
포팅 서비스 부탁드립니다
1
122
2





