Search test library by skills or roles
⌘ K

About the test:

The Embedded C Test uses scenario-based MCQ questions to evaluate a candidate's ability to develop C/Embedded C drivers/ libraries and coding questions to evaluate hands-on C programming skills. The code-tracing MCQ questions evaluate Embedded C fundamentals (data types, variables, pointers), I/O Hardware Addressing, fixed-point arithmetic operations, accessing address spaces, Preprocessor directives and efficient application of object-oriented programming principles to firmware development.

Covered skills:

  • C basics (variables; data types; declarations; functions)
  • Pointers (with Arrays; Structures; Unions)
  • Embedded C basics (registers; directives; drivers)
  • Bit Operations (Packaging data; unpacking data; bit manipulations)
See all covered skills

9 reasons why
9 reasons why

Adaface Inbäddat C online -test is the most accurate way to shortlist Embedded Electronics Engineers



Reason #1

Tests for on-the-job skills

Det inbäddade C Online Assessment Test minskar det administrativa omkostnaden för att intervjua för många kandidater och sparar dyr tekniktid genom att filtrera bort okvalificerade kandidater.

AdaFACE Embedded C Test Screen Candidates för de typiska färdigheterna som rekryterare letar efter i en inbäddad mjukvaruutvecklare:

  • Kompetens i att skriva inbäddad C -kod för optimerad I/O -prestanda
  • Fast förståelse för datastrukturer, maskinnivåspråk, monteringsspråk och elektronisk programmerbar enhetsarkitektur
  • Bekanta med mikrokontroller och inbäddade processorer
  • C Basics (datatyper, variabler definitioner, lagringsklassspecifikationer)
  • Bit manipulationstekniker med bitvis operatörer
  • Arbeta med strukturer, bitfält, fackföreningar, bit extraktion och minneskartade perifera register
  • Pekare aritmetiska och vikten av pekardatatyper
  • Tolkning och användning av komplexa variabla definitioner som involverar en kombination av const pekare, const-data, flyktig const, pekare och icke-pekarevariabler
  • Skapa register från adressen
  • Definiera perifer adress
  • Implicit och uttrycklig gjutning
  • Vikt av flyktig under kompilatoroptimering
  • Förpackning och packning av data för överföring och lagring
  • anpassad och ojusterad datatillgång på strukturer
  • Använd felsökaren effektivt för att analysera och lösa buggar

Dessutom har testet kodande frågor för att utvärdera praktiska programmeringsförmågor.

Reason #2

No trick questions

no trick questions

Traditional assessment tools use trick questions and puzzles for the screening, which creates a lot of frustration among candidates about having to go through irrelevant screening assessments.

The main reason we started Adaface is that traditional pre-employment assessment platforms are not a fair way for companies to evaluate candidates. At Adaface, our mission is to help companies find great candidates by assessing on-the-job skills required for a role.

Why we started Adaface ->
Reason #3

Non-googleable questions

We have a very high focus on the quality of questions that test for on-the-job skills. Every question is non-googleable and we have a very high bar for the level of subject matter experts we onboard to create these questions. We have crawlers to check if any of the questions are leaked online. If/ when a question gets leaked, we get an alert. We change the question for you & let you know.

Dessa är bara ett litet urval från vårt bibliotek med 10 000+ frågor. De faktiska frågorna om detta Embedded C Test kommer att vara icke-googleable.

🧐 Question

Medium

Logic Black Box
Solve
Consider the following logic box. There are three inputs A, B, C and three outputs not A, not B and not C (not A = !A, not B = !B, not C = !C).

Is it possible to achieve the expected outputs from the inputs using:

- Only AND and OR gates
- Just two (2) NOT gates
- No NAND, NOR, XOR, or XNOR gates
 image

Medium

Memory Map
Memory Architecture
Solve
Review the following Embedded Systems code and memory map of 16-bit microcontroller:
 image
 image
Here are the specifications of the microcontroller:

- The stack grows from area D, whereas the program and static variables are stored in area C
- ‘int’ in the system is a 16-bit number
- There is no operating system and no memory protection
- The program is compiled and loaded into area C
Pick the correct statements:

A: first_var, second_var and input will be in area D
B: first_var and second_var will be in area C, input will be in area D
C: If the contents of 0x0010 at the start of the program is 7, the program will print 0 and exit
D: If the contents of 0x0010 at the start of the program is 42, the program will print 0 and exit
E: If the contents of 0x0010 at the start of the program is 42, the program will overflow the stack overwriting the program and static variables region
F: If the program overflows and overwrites the program and static variables region, arbitrary data is executed as if it is the program, causing unpredictable results

Medium

Multi-tasking
Multi-tasking
Solve
Review the following Embedded Systems code:
 image
Here’s the specification for the program:
- first_var and second_var are global variables shared among several threads
- first_lock and second_lock are mutex locks that protect access to first_var and second_var
- Reads and writes to variables first_var and second_var are not guaranteed to be atomic
- No locks must be acquired unnecessarily
- Acquire second_var lock first before acquiring first_var lock by any thread that is going to use both first_var and second_var
Assume that if a thread attempts to acquire a lock it already holds, then it is immediately granted the lock. Pick the correct statements:

A: The provided code does not meet the specification completely since second_lock is not acquired before acquiring first_lock for procedure 'foo'

B: Replacing foo with logic of foo1 makes sure locks are not acquired unnecessarily and  second_lock is acquired before acquiring first_lock

C: Replacing foo with logic of foo1 makes sure second_lock is acquired before acquiring first_lock but there are cases when second_lock is acquired unnecessarily (when first_var < input)

D: Replacing foo with logic of foo2 makes sure locks are not acquired unnecessarily

E: Replacing foo with logic of foo2 is optimized version of foo1 but there are cases when second_lock is still acquired unnecessarily (when first_var value changes from the time ‘res’ value is computed and by the first_lock is acquired again.

Medium

Memory Allocation
Solve
Check the following three C functions:
 image
Which among these will likely cause issues with pointers?

Medium

Pointers and Structs
Solve
What is the output of the following C code?
 image

Medium

Strings
Strings
Solve
What is the output of the following C code?
 image

Easy

Registration Queue
Logic
Solve
We want to register students for the next semester. All students have a receipt which shows the amount pending for the previous semester. A positive amount (or zero) represents that the student has paid extra fees, and a negative amount represents that they have pending fees to be paid. The students are in a queue for the registration. We want to arrange the students in a way such that the students who have a positive amount on the receipt get registered first as compared to the students who have a negative amount. We are given a queue in the form of an array containing the pending amount.
For example, if the initial queue is [20, 70, -40, 30, -10], then the final queue will be [20, 70, 30, -40, -10]. Note that the sequence of students should not be changed while arranging them unless required to meet the condition.
⚠️⚠️⚠️ Note:
- The first line of the input is the length of the array. The second line contains all the elements of the array.
- The input is already parsed into an array of "strings" and passed to a function. You will need to convert string to integer/number type inside the function.
- You need to "print" the final result (not return it) to pass the test cases.

For the example discussed above, the input will be:
5
20 70 -40 30 -10

Your code needs to print the following to the standard output:
20 70 30 -40 -10

Medium

Longest Road
logic
hashmaps
Solve
A startup company E-Motors is building driverless automated cars. The car contains a sensor that checks the road quality for the next N meters to decide the optimal speed at which the cars should move. We are given recorded data by the sensor in the form of an array, where each element of the array is the rating given to 1 meter of the road in sequence. 

The rating given by the sensor is from 1 to 100, where 100 represents the road with the best condition, and any rating above 60 is optimal. Find the longest stretch of road in meters that is categorized as optimal by the sensor.

The input is an array of "strings" which needs to be converted from string to integer/number inside the function.

Medium

Visitors Count
Strings
Solve
A manager hires a staff member to keep a record of the number of men, women, and children visiting the museum daily. The staff will note W if any women visit, M for men, and C for children. You need to write code that takes the string that represents the visits and prints the count of men, woman and children. The sequencing should be in decreasing order. 
Example:

Input:
WWMMWWCCC

Expected Output: 
4W3C2M

Explanation: 
‘W’ has the highest count, then ‘C’, then ‘M’. 
⚠️⚠️⚠️ Note:
- The input is already parsed and passed to a function.
- You need to "print" the final result (not return it) to pass the test cases.
- If the input is- “MMW”, then the expected output is "2M1W" since there is no ‘C’.
- If any of them have the same count, the output should follow this order - M, W, C.
🧐 Question🔧 Skill

Medium

Logic Black Box
3 mins
Embedded Systems
Solve

Medium

Memory Map
Memory Architecture
3 mins
Embedded Systems
Solve

Medium

Multi-tasking
Multi-tasking
2 mins
Embedded Systems
Solve

Medium

Memory Allocation
2 mins
C
Solve

Medium

Pointers and Structs
2 mins
C
Solve

Medium

Strings
Strings
2 mins
C
Solve

Easy

Registration Queue
Logic
30 mins
Coding
Solve

Medium

Longest Road
logic
hashmaps
25 mins
Coding
Solve

Medium

Visitors Count
Strings
30 mins
Coding
Solve
🧐 Question🔧 Skill💪 Difficulty⌛ Time
Logic Black Box
Embedded Systems
Medium3 mins
Solve
Memory Map
Memory Architecture
Embedded Systems
Medium3 mins
Solve
Multi-tasking
Multi-tasking
Embedded Systems
Medium2 mins
Solve
Memory Allocation
C
Medium2 mins
Solve
Pointers and Structs
C
Medium2 mins
Solve
Strings
Strings
C
Medium2 mins
Solve
Registration Queue
Logic
Coding
Easy30 minsSolve
Longest Road
logic
hashmaps
Coding
Medium25 minsSolve
Visitors Count
Strings
Coding
Medium30 minsSolve
Reason #4

1200+ customers in 75 countries

customers in 75 countries
Brandon

Med AdaFace kunde vi optimera vår första screeningprocess med upp till 75%, vilket frigör dyrbar tid för både anställningschefer och vårt Talent Acquisition Team lika!


Brandon Lee, Folkchef, Love, Bonito

Reason #5

Designed for elimination, not selection

The most important thing while implementing the pre-employment Embedded C Test in your hiring process is that it is an elimination tool, not a selection tool. In other words: you want to use the test to eliminate the candidates who do poorly on the test, not to select the candidates who come out at the top. While they are super valuable, pre-employment tests do not paint the entire picture of a candidate’s abilities, knowledge, and motivations. Multiple easy questions are more predictive of a candidate's ability than fewer hard questions. Harder questions are often "trick" based questions, which do not provide any meaningful signal about the candidate's skillset.

Reason #6

1 click candidate invites

Email invites: You can send candidates an email invite to the Embedded C Test from your dashboard by entering their email address.

Public link: You can create a public link for each test that you can share with candidates.

API or integrations: You can invite candidates directly from your ATS by using our pre-built integrations with popular ATS systems or building a custom integration with your in-house ATS.

invite candidates
Reason #7

Detailed scorecards & comparative results

Reason #8

High completion rate

Adaface tests are conversational, low-stress, and take just 25-40 mins to complete.

This is why Adaface has the highest test-completion rate (86%), which is more than 2x better than traditional assessments.

test completion rate
Reason #9

Advanced Proctoring


Vilka frågor ingår för äldre inbäddade C -ingenjörer?

Frågorna till ledande kandidater är baserade på avancerade inbäddade C -ämnen som:

  • Betydelse av strukturer i perifera registeråtkomst
  • Erfarenhet med standard C och inbäddade C -bibliotek
  • Utveckla inbäddade drivrutiner från början med information från databladet (GPIO -drivrutiner, Timers -drivrutiner, UART -drivrutiner)
  • Möjlighet att arbeta utan tredjepartsbibliotek eller rubrikfiler
  • Analysera chipdokumentationen
  • avkoppling av I/O från realtidsbehandling för att undvika svarstid överkörningar
  • Realtidssystemdesignkoncept, nedbrytning av funktioner och identifiering av viktiga tjänster
  • Strukturerad avbrottshantering

Dessutom kommer kodningsfrågan att vara av högre svårighetsnivå jämfört med Junior Embedded C -test.

What roles can I use the Embedded C Test for?

  • Embedded Electronics Engineer
  • Embedded Software Engineers C
  • Embedded C Engineers
  • Firmware Engineers - Embedded C
  • Electronic & Electrical Engineers
  • Software Testing Specialists - Microcontrollers
  • Senior Embedded C Engineers

What topics are covered in the Inbäddat C online -test?

Datatyper
Nummersystem (hex, decimal och binär)
Variabler
Förklaringar
Operatörer
Funktioner
Vänner
Pekare
Union
Enum
Matriser (med pekare)
Strukturer (med pekare)
Gjutning
Register
Fackföreningar
Bitområden
Kval
Konst och flyktig
MCU perifera register
Nummersystem (hex, decimal och binär)
Lagringskurser
Rubrikfiler
Förbehandlar
Villkorlig sammanställning
Makron
Länken och lokalisering
Testning och validering
I/O -prestanda
Avbryta
Singapore government logo

Anställningscheferna ansåg att de genom de tekniska frågor som de ställde under panelintervjuerna kunde berätta vilka kandidater som hade bättre poäng och differentierade med dem som inte gjorde så bra. Dom är mycket nöjd med kvaliteten på kandidater som är kortlistade med AdaFace -screening.


85%
minskning av screeningstiden

Embedded C Online Test FAQs

Kan jag utvärdera C -kodningskunskaper och inbäddade C -färdigheter i samma test?

Ja. Du kan granska vårt standard C Online-test för att få en känsla av vilken typ av frågor som kommer att användas för att utvärdera C. Det slutliga testet Kommer att ha MCQ -frågor för att utvärdera C, inbäddade C och kodande frågor för att utvärdera C -kodningskunskaper.

Kan jag utvärdera C ++ och inbäddad C i samma test?

Ja. Du kan granska vårt standard C ++ online-test för att få en känsla av vilken typ av frågor som kommer att användas för att utvärdera C ++. Det sista testet kommer att ha MCQ -frågor för att utvärdera C ++, inbäddade C och kodande frågor för att utvärdera C/C ++ kodningskunskaper.

Kan jag kombinera flera färdigheter till en anpassad bedömning?

Ja absolut. Anpassade bedömningar ställs in baserat på din arbetsbeskrivning och kommer att innehålla frågor om alla måste-ha färdigheter du anger.

Har du några anti-cheating eller proctoring-funktioner på plats?

Vi har följande anti-cheating-funktioner på plats:

  • Icke-Googleable-frågor
  • IP -proctoring
  • webbproctoring
  • webbkamera proctoring
  • Detektion av plagiering
  • säker webbläsare

Läs mer om proctoring -funktionerna.

Hur tolkar jag testresultat?

Det främsta att tänka på är att en bedömning är ett eliminationsverktyg, inte ett urvalsverktyg. En kompetensbedömning är optimerad för att hjälpa dig att eliminera kandidater som inte är tekniskt kvalificerade för rollen, den är inte optimerad för att hjälpa dig hitta den bästa kandidaten för rollen. Så det ideala sättet att använda en bedömning är att bestämma en tröskelpoäng (vanligtvis 55%, vi hjälper dig att jämföra) och bjuda in alla kandidater som gör poäng över tröskeln för nästa intervjurundor.

Vilken erfarenhetsnivå kan jag använda detta test för?

Varje AdaFace -bedömning anpassas till din arbetsbeskrivning/ idealisk kandidatperson (våra ämnesexperter kommer att välja rätt frågor för din bedömning från vårt bibliotek med 10000+ frågor). Denna bedömning kan anpassas för alla erfarenhetsnivåer.

Får varje kandidat samma frågor?

Ja, det gör det mycket lättare för dig att jämföra kandidater. Alternativ för MCQ -frågor och ordningen på frågor randomiseras. Vi har anti-cheating/proctoring -funktioner på plats. I vår företagsplan har vi också möjlighet att skapa flera versioner av samma bedömning med frågor om liknande svårighetsnivåer.

Jag är kandidat. Kan jag prova ett träningstest?

Nej. Tyvärr stöder vi inte övningstester just nu. Du kan dock använda våra exempelfrågor för övning.

Vad är kostnaden för att använda detta test?

Du kan kolla in våra prisplaner.

Kan jag få en gratis provperiod?

Plattformen är helt självbetjänande, så här är ett sätt att gå vidare:

  • Du kan registrera dig gratis för att få en känsla för hur det fungerar.
  • Den kostnadsfria provperioden inkluderar en provbedömning (Java/JavaScript) som du hittar i din instrumentpanel när du registrerar dig. Du kan använda den för att granska kvaliteten på frågorna och kandidaternas upplevelse av ett konversationstest på Adaface.
  • För att granska kvaliteten på frågorna kan du också granska våra offentliga frågor för 50+ färdigheter här.
  • När du är övertygad om att du vill testa det med riktiga bedömningar och kandidater kan du välja en plan enligt dina krav.

Jag flyttade precis till en betald plan. Hur kan jag begära en anpassad bedömning?

Här är en snabbguide om hur man begär en anpassad bedömning på Adaface.

customers across world
Join 1200+ companies in 75+ countries.
Prova det mest kandidatvänliga utvärderingsverktyget idag.
g2 badges
Ready to use the Adaface Embedded C Test?
Ready to use the Adaface Embedded C Test?
chatta med oss
logo
40 min tests.
No trick questions.
Accurate shortlisting.
Villkor Integritet Förtroende

🌎 Välj ditt språk

English Norsk Dansk Deutsche Nederlands Svenska Français Español Chinese (简体中文) Italiano Japanese (日本語) Polskie Português Russian (русский)
ada
Ada
● Online
Previous
Score: NA
Next
✖️