Updated: October 28, 2024 |
Find the first occurrence of a character in a string
#include <string.h> char* strchr( char* s, int c ); char* strchr_isr( char* s, int c );
libc
Use the -l c option to qcc to link against this library. This library is usually included automatically.
The strchr() function finds the first occurrence of c (converted to a char) in the string pointed to by s. The terminating NUL character is considered to be part of the string.
The strchr_isr() function does the same thing, but avoids using special-purpose registers (e.g., sse2) that incur additional cost when their state is saved during context switches. The relative performance of a process using this first or second function can be better or worse depending on the frequency and sizes of string-copying operations, the specific target, and what other processes are doing. If string copying does not play a major role in the process's overall performance, which function is faster isn't so important. Otherwise, developers are strongly encouraged to do their own testing and select the correct function.
In this release, both strchr() and strchr_isr() are safe to call from an interrupt handler.
A pointer to the located character, or NULL if c doesn't occur in the string.
#include <stdio.h> #include <string.h> #include <stdlib.h> int main( void ) { char buffer[80]; char* where; strcpy( buffer, "video x-rays" ); where = strchr( buffer, 'x' ); if( where == NULL ) { printf( "'x' not found\n" ); } else { printf( "'x' found: %s\n", where ); } return EXIT_SUCCESS; }
Processes that register ISRs shouldn't use the NEON versions.
strchr() is ANSI, POSIX 1003.1; strchr_isr() is QNX Neutrino.
Safety: | |
---|---|
Cancellation point | No |
Interrupt handler | Yes |
Signal handler | Yes |
Thread | Yes |