They most often come from forgetting to include the header file that contains the function declaration, for example, this program will give an 'undeclared identifier' error:
Missing header
Copyint main() {
std::cout << "Hello world!" << std::endl;
return 0;
}
To fix it, we must include the header:
Copy#include <iostream>
int main() {
std::cout << "Hello world!" << std::endl;
return 0;
}
If you wrote the header and included it correctly, the header may contain the wrong include guard.
To read more, see http://msdn.microsoft.com/en-us/library/aa229215(v=vs.60).aspx.
Misspelled variable
Another common source of beginner's error occur when you misspelled a variable:
Copyint main() {
int aComplicatedName;
AComplicatedName = 1; /* mind the uppercase A */
return 0;
}
Incorrect scope
For example, this code would give an error, because you need to use std::string:
Copy#include <string>
int main() {
std::string s1 = "Hello"; // Correct.
string s2 = "world"; // WRONG - would give error.
}
Use before declaration
Copyvoid f() { g(); }
void g() { }
g has not been declared before its first use. To fix it, either move the definition of g before f:
Copyvoid g() { }
void f() { g(); }
Or add a declaration of g before f:
Copyvoid g(); // declaration
void f() { g(); }
void g() { } // definition
stdafx.h not on top (VS-specific)
This is Visual Studio-specific. In VS, you need to add #include "stdafx.h" before any code. Code before it is ignored by the compiler, so if you have this:
Copy#include <iostream>
#include "stdafx.h"
The #include <iostream> would be ignored. You need to move it below:
Copy#include "stdafx.h"
#include <iostream>
Feel free to edit this answer.
Hi CS50 gang!
I'm really enjoying the course, but my brain hurts already at week 2. I've noticed an error when compiling a programme in C when I try to declare a variable inside a FOR loop in C (example below).
I just move my variable declaration to above the FOR loop, but I have two questions about this:
-
Why does this happen? Is it because the loop tries to declare the variable each time it iterates?
-
Does it cause problems to declare the variable (int letter_count) above the loop, like I have done in the example below? Or is there a better convention for declaring variables?
int letter_count = 0;
//loop to break text string into chars
for (int i = 0, n = strlen(text); i < n; i++)
{
//check if char i is lower or upper and increment letter-count by 1 if true
if (isupper(text[i]) || islower(text[i]))
{
letter_count++;
}
printf("%c", text[i]);
}Thank you!
Videos
They most often come from forgetting to include the header file that contains the function declaration, for example, this program will give an 'undeclared identifier' error:
Missing header
Copyint main() {
std::cout << "Hello world!" << std::endl;
return 0;
}
To fix it, we must include the header:
Copy#include <iostream>
int main() {
std::cout << "Hello world!" << std::endl;
return 0;
}
If you wrote the header and included it correctly, the header may contain the wrong include guard.
To read more, see http://msdn.microsoft.com/en-us/library/aa229215(v=vs.60).aspx.
Misspelled variable
Another common source of beginner's error occur when you misspelled a variable:
Copyint main() {
int aComplicatedName;
AComplicatedName = 1; /* mind the uppercase A */
return 0;
}
Incorrect scope
For example, this code would give an error, because you need to use std::string:
Copy#include <string>
int main() {
std::string s1 = "Hello"; // Correct.
string s2 = "world"; // WRONG - would give error.
}
Use before declaration
Copyvoid f() { g(); }
void g() { }
g has not been declared before its first use. To fix it, either move the definition of g before f:
Copyvoid g() { }
void f() { g(); }
Or add a declaration of g before f:
Copyvoid g(); // declaration
void f() { g(); }
void g() { } // definition
stdafx.h not on top (VS-specific)
This is Visual Studio-specific. In VS, you need to add #include "stdafx.h" before any code. Code before it is ignored by the compiler, so if you have this:
Copy#include <iostream>
#include "stdafx.h"
The #include <iostream> would be ignored. You need to move it below:
Copy#include "stdafx.h"
#include <iostream>
Feel free to edit this answer.
Consider a similar situation in conversation. Imagine your friend says to you, "Bob is coming over for dinner," and you have no idea who Bob is. You're going to be confused, right? Your friend should have said, "I have a work colleague called Bob. Bob is coming over for dinner." Now Bob has been declared and you know who your friend is talking about.
The compiler emits an 'undeclared identifier' error when you have attempted to use some identifier (what would be the name of a function, variable, class, etc.) and the compiler has not seen a declaration for it. That is, the compiler has no idea what you are referring to because it hasn't seen it before.
If you get such an error in C or C++, it means that you haven't told the compiler about the thing you are trying to use. Declarations are often found in header files, so it likely means that you haven't included the appropriate header. Of course, it may be that you just haven't remembered to declare the entity at all.
Some compilers give more specific errors depending on the context. For example, attempting to compile X x; where the type X has not been declared with clang will tell you "unknown type name X". This is much more useful because you know it's trying to interpret X as a type. However, if you have int x = y;, where y is not yet declared, it will tell you "use of undeclared identifier y" because there is some ambiguity about what exactly y might represent.
Hello, I'm new to programming and while coding my example program I ran into an issue that I've been trying to figure out how to resolve. When print_Menu_Info(); executes and it tries to execute print_Customer_Table(&c); I encounter the error in the title.
sales.c:101:24: error: use of undeclared identifier 'c'
Even though the line is being declared in line 12.
struct customer c = empty_customer;
#include <stdio.h>
#include <stdlib.h>
#include "sales.h"
int main(void)
{
menu_update();
return 0;
}
void menu_update(void){
struct customer c = empty_customer;
float f = 0.00;
int i = 0;
while (1) {
cls();
print_Menu_Info();
switch(get_User_Input()){
case 1:
printf("Customer First Name: ");
scanf("%s",c.first_Name);
break;
case 2:
printf("Customer Last Name: ");
scanf("%s",c.last_Name);
break;
case 3:
printf("Customer Amount: ");
scanf("%f",&f);
c.amount = f;
break;
case 4:
printf("Customer Card Number: ");
scanf("%s",c.card_Number);
break;
case 5:
printf("Customer Card Expiration Month: ");
scanf("%i",&i);
c.card_Expiration_Month = i;
break;
case 6:
printf("Customer Card Expiration Year: ");
scanf("%i",&i);
c.card_Expiration_Year = i;
break;
case 7:
printf("Sales Person: ");
scanf("%s",c.sales_Person);
break;
case 8:
print_Customer_Table(&c);
break;
case 9:
c = empty_customer;
break;
case 10:
exit(0);
default:
printf("Incorrect action ID!\n");
break;
}
}
}
void cls(void){
printf("\033c");
}
int get_User_Input(){
int a = 0;
char line[32];
printf("Please input an action ID: ");
if (fgets(line, sizeof(line), stdin) != NULL) {
sscanf(line, "%i", &a);
cls();
}
return a;
}
void print_Customer_Table(struct customer *cp){
printf(
"1. Customer First Name: %s\n"
"2. Customer Last Name: %s\n"
"3. Customer Amount: $%.2f\n"
"4. Customer Card Number: %s\n"
"5. Customer Card Expiration Month: %i\n"
"6. Customer Card Expiration Year: %i\n"
"7. Sales Person: %s\n",
cp->first_Name,
cp->last_Name,
cp->amount,
cp->card_Number,
cp->card_Expiration_Month,
cp->card_Expiration_Year,
cp->sales_Person);
}
void print_Menu_Info(void){
print_Customer_Table(&c);
printf(
"If you would like to update a value type the value you would like to update(1-7)\n"
"If you would like to send this as a email type 8\n"
"If you would like to clear all customer data type 9\n"
"If you would like to exit this program type 10\n");
} and sales.h
#define NAME_LEN_MAX 128
#define CARD_NUM_LEN_MAX 16
struct customer {
char first_Name[NAME_LEN_MAX + 1];
char last_Name[NAME_LEN_MAX + 1];
float amount;
char card_Number[CARD_NUM_LEN_MAX + 1];
int card_Expiration_Month;
int card_Expiration_Year;
char sales_Person[NAME_LEN_MAX + 1];
};
const static struct customer empty_customer = {{""},{""},0.00,{""},0,0,{""}};
void print_Customer_Table(struct customer *cp);
void print_Menu_Info(void);
void cls(void);
int get_User_Input();
void menu_update(void);I'm having difficulty figuring out why it won't recognize this function passing parameters, in the int main function. I'm trying to pass the computeoffSet function, and it doesn't like the parameters passed within it. Calls them an undeclared identifier, and I believe I have them declared above. I would appreciate some advice on the problem, for which I'd be grateful.
#include <iostream>
#include <iomanip>
using namespace std;
int getMonth()
{
int usermonth;
cout << "Enter a month number: ";
cin >> usermonth;
return usermonth;
}
int getYear()
{
int useryears;
cout << "Enter year: ";
cin >> useryears;
return useryears;
}
int leapCheck(int month, int years)
{
if(month == 2)
{
if((years % 400 == 0) || (years % 4== 0 && years % 100 != 0))
return 29;
else
return 28;
}
}
int calcDays(int month, int years)
{
int userday = 0;
{
if(month == 1 || month == 3 || month == 5 || month == 7 || month == 8 || month == 10 || month == 12)
return userday + 31;
else
return userday + 30;
}
return userday;
}
int computeoffSet(int month, int years)
{
int offset = 0;
for(int y = 0; y < 1753; y++)
offset = (offset + 365 + calcDays(month, years)) % 7;
for (int m = 1; m < month; m++)
offset = (offset + calcDays(month, years)) % 7;
return offset;
}
void display(int month, int years, int offset)
{
int numDays = calcDays(month, years);
cout << " Su Mo Tu We Th Fr Sa";
int position = 6;
while(position != offset)
{
cout << " ";
position += 1;
if(position > 6)
position = position - 7;
}
for(int count = 1; count <= numDays; count++)
{
cout << setw(4) << count;
position += 1;
if(position == 7)
position = position - 7;
if(position == 6)
cout << endl;
}
if(position < 6)
cout << endl;
}
int main()
{
int userMonth = getMonth();
int offset = computeoffSet(usermonth, useryears);
int userYears = getYear();
display(userMonth, offset, userYears);
return 0;
}
Your posts seem to contain unformatted code. Please make sure to format your code otherwise your post may be removed.
Read our guidelines for how to format your code.
I am a bot, and this action was performed automatically. Please contact the moderators of this subreddit if you have any questions or concerns.
Please indent the code with 4 spaces so that Reddit displays it more nicely formatted.
int offset = computeoffSet(usermonth, useryears);
int userYears = getYear();
C and then C++ were designed for single pass compilation with little or no backpatching. Essentially, when something is used in the code it must already have been declared. Earlier in the same translation unit.
Also note that C++ is a case-sensitive language.
int total = 0;
for (int i= 0; word[i] != '\0'; i++)
;
{
char c = word[i];
if (isalpha(c))
total += POINTS[get_index(c)];
}
return total;
}
int get_index(char c)
{
return tolower(c) - 'a';When I compile the code I get undeclared identifier 'i'. But when declare it I get declaration shadows a variable in the global scope [-Werror,-Wshadow]. Please help
Undeclared identifier but is declared
No, it isn't. Your identifier is defined, not declared. This is a common source of confusion. Declaration of an identifier means to give it a unique signature that can be referred to in the following code lines. Definition means to give it a certain value/implementation. A definition implies declaration for the following code.
At least an identifiers complete declaration must have been seen before first usage.
That said you can simply put a declaration for your function before main()
HIDE int call1(int a,int b);
or just change your code to
HIDE int call1(int a,int b) {
int r;
r= a+b;
return r;
}
HIDE int main() {
int x = 10;
int z = 5;
int c;
c=call1(x,z);
}
and put the definition (which actually implies the declaration) before main() to have a forward declaration for your function.
I'm going to cite the current standards section 3.1 here
3.1 Declarations and definitions [basic.def]
1 A declaration (Clause 7) may introduce one or more names into a translation unit or redeclare names introduced by previous declarations. If so, the declaration specifies the interpretation and attributes of these names. A declaration may also have effects including:
— a static assertion (Clause 7),
— controlling template instantiation (14.7.2),
— use of attributes (Clause 7), and
— nothing (in the case of an empty-declaration)....
or try this
HIDE int call1(int a,int b); // pre define
HIDE int main(){
int x = 10;
int z = 5;
int c;
c = call1(x,z);
}
HIDE int call1(int a,int b)
{
int r;
r = a+b;
return r;
}
Ive done some research and everyone that seemed to have this problem already didn't declare the variable outside of the loops or if statements that they were used it. I made sure to do it before and I cant seem to get this darn thing working.
Its mostly practice so if anyone can tell me why Id appreciate it!
I get the error Errors
error C2143: syntax error : missing ';' before 'type' Line 0
and
error C2065: 'CountTotal' : undeclared identifier (This one comes up 4 times) Line 10
Now this is driving me crazy. It doesn't work in my compiler, but it works on the website compiler. Ive been trying to fix this for two days. Any ideas? I'm using Microsoft visual express c++ 2011
http://ideone.com/5ifRPT
Hi,
So I'm very new to programming and am currently undertaking the Harvard CS50 course. Attempting lab 2, I have come across the following error:
scrabble.c:17:34: error: use of undeclared identifier 'word'
for (int i = 0, len = strlen(word); i < len; i++)
This error is confusing the heck out of me, as there are lines of code beneath this one that are unaffected.
The top of my code (prior to line 17) introduces the identifier as int compute_score(string word);. But for some reason, the "word" on line 17 is unaffected by the declaration, while lines of code beneath it that also include "word" are colored orange correspondingly. The "word" on line 17 is for some reason, uncolored.
Sorry if this makes little sense, half asleep trying to do this and am beating myself up a bit.
Thanks.