For one thing, bar
should be called Bar
to be idiomatic…
Ideally, you should compile from the directory above Main.java, like this:
javac -d out foo/Main.java foo/Bar.java
That will create a directory called «out» containing another directory «foo», which will contain Main.class and Bar.class. So from the parent directory again, you could run:
java -cp out foo.Main
The source locations don’t have to match the package structure. You could just call javac from the directory containing Main.java
and Bar.java
like this:
javac -cp out Main.java Bar.java
(And then run it in the same way as before) However, it’s generally a much better idea to structure your source code according to packages.
You may well find it easier to use an IDE (Eclipse or NetBeans, for example) which will handle all the compilation etc for you. If you do want to build a real project from the command line, you should probably look into using a full build system such as Ant or Maven.
(Note that you’d get the same error on Linux as on Windows, if you tried to compile in the same way.)
Symbols and Symbol Table
Before diving into the details of the “cannot find a symbol” error, here is a brief introduction to symbols and symbol tables in Java. A symbol refers to an identifier in the compilation process in Java. All the identifiers used in the source code are collected into a symbol table in the lexical analysis stage. The symbol table is a very significant data structure created and maintained by the compilers to store all the identifiers and their information.
This information is entered into the symbol tables during lexical and syntax analysis which is then used in multiple phases of compilation.
From classes, variables, interfaces to methods, all of them require an identifier for declaration. During the code generation process, when these identifiers are encountered in the source code, the compiler checks for them in the symbol tables and the stored information is then used to verify the declarations, the scope of a variable, and verifying that the expression is semantically correct or not.
The compilation process usually does not go as smooth as you would think. Errors are inevitable in any development stage and one of the very commonly occurring errors during the compilation process is Java “cannot Find Symbol” Error. In this article, we will be discussing the reasons behind the occurrence of Java cannot find symbol errors and how you can resolve them.
As the name suggests, the Java cannot find symbol error occurs when a required symbol cannot be found in the symbol table. Although there can be various reasons behind this, it points to one fact the Java compiler was unable to find the symbol and its details associated with a given identifier.
As there are a variety of Java compilers available, many of them use slightly different terminologies, because of that, you can also find the “cannot find symbol” error termed as the “symbol not found” or “cannot resolve symbol” error. Besides the name, there is simply no difference between these errors.
Structure of Java Cannot Find Symbol Error
The compiler output a specific error message with the cannot find symbol error.
It contains the following two fields that indicate the missing symbol and its location:
- Symbol: The name and type of the identifier you are looking for.
- Location: The particular class in which that identifier has been referenced.
Causes of Java Cannot Find Symbol Error
We will be discussing the following most common causes of the cannot find symbol error during compilation,
- misspelt identifiers
- Undeclared variables
- Out of scope references to variables and methods
- The unintentional omission of import statements
Misspelt identifier names
This is the most common and most occurring reason behind the Java cannot find symbol error. Misspelling an existing variable, class, interface, package name or a method causes the “cannot find symbol error” as the compiler cannot recognize the symbol and identifies it as an undeclared variable. Java identifiers are also case-sensitive, so even a slight variation of an existing variable will result in this error.
See code example below:
1. public class MisspelledMethodNameExample { 2. static int findLarger(int n1, int n2) { 3. if (n1 > n2) return n1; 4. if (n2 > n11) return n2; 5. if (n2 == n11) return -1; 6. } 7. 8. public static void main(String... args) { 9. int value = findlarger(20, 4); // findlarger ≠ findLarger 10. System.out.println(value); 11. } 12. }
MisspelledMethodNameExample.java:9: error: cannot find symbol int value = Fibonacci(20); ^ symbol: method findLarger(int, int) location: class MisspelledMethodNameExample
It can be easily resolved by correcting the spelling of the function in line 9.
Undeclared variables
When the Java compiler come across an identifier used in the code but it cannot be found in the symbol table, the “cannot find symbol” error is shown. The only reason behind the absence of a variable from the symbol table is that it is not declared in the code. Some new programming languages do not require explicit declaration of variables but it is mandatory in Java to always declare a variable before it is used or referenced in the source code.
The code snippet below demonstrates an undeclared variable in the code. In this case, the identifier sum on line 7, causes the Java “cannot find symbol error”.
See code example below:
1. public class UndeclaredVariableExample 2. { 3. public static void main(String... args) { 4. int num1 = 5; 5. int num2 = 10; 6. int num3 = 43; 7. sum = (num1 + num2 + num3) // sum is not declared 8. System.out.println(sum); 9. } 10. }
UndeclaredVariableExample.java:7: error: cannot find symbol sum = (num1 + num2 + num3); ^ symbol: variable sum location: class UndeclaredVariableExample UndeclaredVariableExample.java:8: error: cannot find symbol System.out.println(sum); ^ symbol: variable sum location: class UndeclaredVariableExample 2 errors
Declaring this variable by specifying the appropriate data type can easily resolve the error.
See this corrected code below,
1. public class UndeclaredVariableExample 2. { 3. public static void main(String args) { 4. int num1 = 5; 5. int num2 = 10; 6. int num3 = 43; 7. 8. int sum = (num1 + num2 + num3); 9. System.out.println(sum); 10. } 11. }
Out of scope variable
When a Java code attempts to access a variable declared out of scope such as in a non-inherited scope the compiler will result in issuing the “cannot find symbol” error. This commonly happens when you attempt to access a variable declared inside a method or a loop, from outside of the method.
See this code example below where the “cannot find symbol” error has occurred when the counter variable which is declared inside a for loop is attempted to be accessed from out of the loop.
See code below:
1. public class OutOfScopeExample 2. { 3. public static void main(String args) { 4. 5. for (int counter = 0; counter < 100; counter++) 6. { … } 7. 8. System.out.println(“Even numbers from 0 to 100”) 9. if (counter mod 2 == 0) 10. { 11. System.out.println(counter); 12. } 13. } 14. }
OutOfScopeVariableExample.java:9: error: cannot find symbol if (counter mod 2 == 0) ^ symbol: variable counter location: class OutOfScopeVariableExample OutOfScopeVariableExample.java:12: error: cannot find symbol System.out.println(counter); ^ symbol: variable counter location: class OutOfScopeVariableExample 2 errors
I can be easily resolved by just moving the if block inside the for loop (local scope).
See this code example,
1. public class OutOfScopeExample 2. { 3. public static void main(String... args) { 4. 5. for (int counter = 0; counter < 100; counter++) 6. { 7. System.out.println(“Even numbers from 0 to 100”) 8. if (counter mod 2 == 0) 9. { 10. System.out.println(counter); 11. } 12. } 13. } 14. }
Missing import statement
Java allows you to use built-in classes or any imported libraries in your code to save your time by reusing the code but it requires importing them properly using the import statements at the start. Missing the import statement in your code will result in the cannot find symbol error.
java.util.Math class is utilized in the code given below but it is not declared with the “import” keyword, resulting in the “cannot find symbol error”.
See code below:
1. public class MissingImportExample { 2. 3. public static void main(String args) 4. { 5. double sqrt19 = Math.sqrt(19); 6. System.out.println("sqrt19 = " + sqrt19); 7. } 8. }
MissingImportExample.java:6: error: cannot find symbol double sqrt19 = Math.sqrt(19); ^ symbol: class Math location: class MissingImportExample
Adding the missing import statement can easily solve the issue, see code below:
1. import java.util.Math; 2. 3. public class MissingImporExample { 4. 5. public static void main(String args) 6. { 7. double sqrt19 = Math.sqrt(19); 8. System.out.println("sqrt19 = " + sqrt19); 9. } 10. }
Miscellaneous reasons
We have covered some of the main causes of the “cannot find symbol” Java error but occasionally it can also result due to some unexpected reasons. One such case is when attempting to create an object without the new keyword or an accidental semicolon at the wrong place that would terminate the statement at an unexpected point.
Also Read: Functional Interfaces In Java
Some other causes for the cannot find symbol error may include when you forget to recompile the code or you end up using the dependencies with an incompatible version of Java. Building a project with a very old JDK version can also be a reason as well as mistakenly redefining platform or library classes with the same identifier.
Conclusion
We have discussed that the “cannot find symbol Java” error is a Java compile-time error which is encountered whenever an identifier in the source code is not identified by the compiler. Similar to any other compilation error, it is very significant to understand the causes of this error, so that you can easily pinpoint the issue and address it properly.
Once you can discover the reason behind the error, it can be easily resolved as demonstrated by various examples in this article.
Содержание
- How to Resolve The Cannot Find Symbol Error in Java
- Introduction to Symbol Tables
- Cannot Find Symbol Error
- What Causes the Cannot Find Symbol Error
- Cannot Find Symbol vs Symbol Not Found vs Cannot Resolve Symbol
- Cannot Find Symbol Error Examples
- Undeclared variable
- Ошибка компиляции “Не найти символ”
- 1. Обзор
- 2. Ошибки времени компиляции
- 3. Ошибка “не может найти символ”
- 3.1. Что может вызвать ошибку «не может найти символ»?
- 4. Опечатка
- 5. Сфера применения экземпляра
- 6. Неопределенные переменные
- 7. Переменный охват
- 8. Недействительное использование методов или полей
- 9. Импорт пакетов и классов
- 10. Неправильный импорт
- 11. Заключение
- The “Cannot find symbol” Compilation Error
- Symbols and Symbol Table
- Cannot Find Symbol Error
- Structure of Java Cannot Find Symbol Error
- Causes of Java Cannot Find Symbol Error
- Misspelt identifier names
- Undeclared variables
- Out of scope variable
- Missing import statement
- Miscellaneous reasons
- Conclusion
How to Resolve The Cannot Find Symbol Error in Java
Table of Contents
Introduction to Symbol Tables
Symbol tables are an important data structure created and maintained by compilers to store information associated with identifiers [1] in a given source code. This information is entered into the symbol tables during lexical and syntax analysis and is used in the later phases of compilation. As the declarations of classes, interfaces, variables, and methods are processed, their identifiers are bound to corresponding entries in the symbol tables. When uses of these identifiers are encountered in the source code, the compiler looks them up in the symbol tables and relies on this information for things such as verifying that a variable has been declared, determining the scope of a variable, and verifying that an expression is semantically correct with type checking. Symbol tables are also used for code generation and optimization [2].
A simplified representation of a symbol table entry (or simply, a symbol) in Java has the following format: . Given a global variable declaration like final double ratio; the corresponding symbol would then be .
Cannot Find Symbol Error
As its name implies, the cannot find symbol error refers to a symbol which cannot be found. While there are multiple ways and reasons this can occur, they all boil down to the fact that the Java compiler is unable to find the symbol associated with a given identifier.
The message produced by the compiler for the cannot find symbol error includes two additional fields:
- “symbol”—the name and type of the referenced identifier; and
- “location”—the specific class in which the identifier has been referenced.
What Causes the Cannot Find Symbol Error
The most common triggers for the cannot find symbol compile-time error include:
- missing variable and method declarations;
- out-of-scope references to variables and methods;
- misspelled identifiers; and
- omitted import statements.
Cannot Find Symbol vs Symbol Not Found vs Cannot Resolve Symbol
As different Java compilers use slightly different terminology, the cannot find symbol error can also be found under the terms symbol not found and cannot resolve symbol . Besides the naming, there is no difference between what these terms stand for.
Cannot Find Symbol Error Examples
Undeclared variable
When the Java compiler encounters a use of an identifier which it cannot find in the symbol table, it raises the cannot find symbol error. Consequently, the most common occurrence of this error is when there is a reference to an undeclared variable. Unlike some other languages that don’t require explicit declaration of variables [3], or may allow declaring a variable after it has been referenced (via hoisting [4]), Java requires declaring a variable before it can be used or referenced in any way.
Fig. 1(a) shows how an undeclared variable, in this case the identifier average on line 9, results in two instances of the cannot find symbol error, at the positions where they appear in the code. Declaring this variable by specifying its data type (or, alternatively, inferring its type with the var keyword in Java 10+) resolves the issue (Fig. 1(b)).
Источник
Ошибка компиляции “Не найти символ”
Просмотрите, что такое ошибки компиляции, а затем конкретно объясните, что такое ошибка «не может найти символ» и как она вызвана.
Автор: baeldung
Дата записи
1. Обзор
В этом учебнике мы рассмотрим, что такое ошибки компиляции, а затем конкретно объясним, что такое ошибка «не может найти символ» и как она вызвана.
2. Ошибки времени компиляции
Во время компиляции компилятор анализирует и проверяет код на многие вещи; типы ссылок, слепки типов и объявления методов, чтобы назвать несколько. Эта часть процесса компиляции важна, так как на этом этапе мы получим ошибку компиляции.
В основном существует три типа ошибок времени компиляции:
- У нас могут быть синтаксисные . Одна из наиболее распространенных ошибок, которые может сделать любой программист, это забыть поставить заоколонку в конце заявления; некоторые другие забывают импорт, несоответствие скобки, или опуская заявление о возвращении
- Далее, естьошибки проверки типов. Это процесс проверки безопасности типов в нашем коде. С помощью этой проверки мы убеждаемся, что у нас есть последовательные типы выражений. Например, если мы определяем переменную типа int , мы никогда не должны назначать двойной или Струнные значение для него
- Между тем, существует вероятность того, что компилятор . Это очень редко, но это может произойти. В этом случае хорошо знать, что наш код не может быть проблемой, но что это скорее внешняя проблема
3. Ошибка “не может найти символ”
Ошибка “не может найти символ” возникает в основном, когда мы пытаемся использовать переменную, которая не определена или объявлена в нашей программе.
Когда наш код компилирует, компилятор должен проверить все идентификаторы, которые у нас есть. Ошибка “не может найти символ” означает, что мы ссылаясь на то, что компилятор не знает о .
3.1. Что может вызвать ошибку «не может найти символ»?
Действительно, есть только одна причина: Компилятор не смог найти определение переменной, на которую мы пытаемся ссылаться.
Но, Есть много причин, почему это происходит. Чтобы помочь нам понять, почему, давайте напомним себе, из чего состоит Java-код.
Наш исходный код Java состоит из:
- Ключевые слова: правда, ложь, класс, в то время как
- Буквально: цифры и текст
- Операторы и другие не-альфа-токены: -,/,
- Идентификаторы: основные , Читатель , Я , toString и так далее.
- Комментарии и белое пространство
4. Опечатка
Наиболее распространенные вопросы связаны с орфографией. Если мы вспомним, что все идентификаторы Java чувствительны к случаям, мы можем видеть, что:
все это будет по-разному способы неправильно ссылаться на Стрингбилдер класс.
5. Сфера применения экземпляра
Эта ошибка также может быть вызвана при использовании чего-то, что было объявлено вне сферы действия класса.
Допустим, у нас есть Статья класс, который вызывает generateId метод:
Но, мы объявляем generateId метод в отдельном классе:
С помощью этой настройки компилятор даст ошибку “не может найти символ” для generateId на линии 7 Статья обрезок. Причина в том, что синтаксис строки 7 подразумевает, что generateId метод объявляется в Статья .
Как и во всех зрелых языках, существует несколько способов решения этой проблемы. Но, один из способов было бы построить ИдГенератор в Статья класса, а затем вызвать метод:
6. Неопределенные переменные
Иногда мы забываем объявить переменную. Как мы видим из фрагмента ниже, мы пытаемся манипулировать переменной мы не объявили, в данном случае, текстовые :
Мы решаем эту проблему, объявляя переменную текстовые типа Струнные :
7. Переменный охват
Когда переменная декларация выходит из сферы действия в момент, когда мы пытались использовать ее, это вызовет ошибку во время компиляции. Обычно это происходит, когда мы работаем с петлями.
Переменные внутри цикла недоступны за пределами цикла:
если заявление должно идти внутри для петли если нам нужно изучить символы больше:
8. Недействительное использование методов или полей
Ошибка “не может найти символ” также произойдет, если мы используем поле в качестве метода или наоборот:
Теперь, если мы попытаемся сослаться на тексты поле, как если бы это был метод:
то мы увидим ошибку.
Это потому, что компилятор ищет метод под названием тексты , которого нет.
Вообще-то, есть getter метод, который мы можем использовать вместо этого:
Ошибка работы на массиве, а не элемент массива также является проблемой:
И так забывает новые ключевое слово, как в:
9. Импорт пакетов и классов
Другая проблема заключается в том, чтобы забыть импортировать класс или пакет. Например, с помощью Список объект без импорта java.util.List :
Этот код не будет компилироваться, так как программа не знает, что Список ош
10. Неправильный импорт
Импорт неправильного типа, из-за завершения IDE или автоматической коррекции также является общей проблемой.
Подумайте о ситуации, когда мы хотим использовать даты в Java. Много раз мы могли бы импортировать неправильный Дата класс, который не предоставляет методы и функции, как другие классы даты, которые нам могут понадобиться:
Чтобы получить год, месяц или день для java.util.Date , мы также должны импортировать Календарь класса и извлечь информацию оттуда.
Просто ссылаясь на getDate () из java.util.Date не будет работать:
Вместо этого мы используем Календарь объект:
Однако, если мы импортировали Местное класса, нам не нужен дополнительный код, который предоставляет нам информацию, в которой мы нуждаемся:
11. Заключение
Компиляторы работают над фиксированным набором правил, которые являются специфическими для языка. Если код не придерживается этих правил, компилятор не может выполнить процесс преобразования, что приводит к ошибке компиляции. Когда мы сталкиваемся с ошибкой компиляции “Не может найти символ”, ключ должен определить причину.
Из сообщения об ошибке мы можем найти строку кода, где происходит ошибка, а какой элемент неправильный. Зная наиболее распространенные проблемы, вызывающие эту ошибку, сделает ее решение очень легко и быстро.
Источник
The “Cannot find symbol” Compilation Error
Table of Contents
Symbols and Symbol Table
Before diving into the details of the “cannot find a symbol” error, here is a brief introduction to symbols and symbol tables in Java. A symbol refers to an identifier in the compilation process in Java. All the identifiers used in the source code are collected into a symbol table in the lexical analysis stage. The symbol table is a very significant data structure created and maintained by the compilers to store all the identifiers and their information.
This information is entered into the symbol tables during lexical and syntax analysis which is then used in multiple phases of compilation.
From classes, variables, interfaces to methods, all of them require an identifier for declaration. During the code generation process, when these identifiers are encountered in the source code, the compiler checks for them in the symbol tables and the stored information is then used to verify the declarations, the scope of a variable, and verifying that the expression is semantically correct or not.
The compilation process usually does not go as smooth as you would think. Errors are inevitable in any development stage and one of the very commonly occurring errors during the compilation process is Java “cannot Find Symbol” Error. In this article, we will be discussing the reasons behind the occurrence of Java cannot find symbol errors and how you can resolve them.
Cannot Find Symbol Error
As the name suggests, the Java cannot find symbol error occurs when a required symbol cannot be found in the symbol table. Although there can be various reasons behind this, it points to one fact the Java compiler was unable to find the symbol and its details associated with a given identifier.
As there are a variety of Java compilers available, many of them use slightly different terminologies, because of that, you can also find the “cannot find symbol” error termed as the “symbol not found” or “cannot resolve symbol” error. Besides the name, there is simply no difference between these errors.
Structure of Java Cannot Find Symbol Error
The compiler output a specific error message with the cannot find symbol error.
It contains the following two fields that indicate the missing symbol and its location:
- Symbol: The name and type of the identifier you are looking for.
- Location: The particular class in which that identifier has been referenced.
Causes of Java Cannot Find Symbol Error
We will be discussing the following most common causes of the cannot find symbol error during compilation,
- misspelt identifiers
- Undeclared variables
- Out of scope references to variables and methods
- The unintentional omission of import statements
Misspelt identifier names
This is the most common and most occurring reason behind the Java cannot find symbol error. Misspelling an existing variable, class, interface, package name or a method causes the “cannot find symbol error” as the compiler cannot recognize the symbol and identifies it as an undeclared variable. Java identifiers are also case-sensitive, so even a slight variation of an existing variable will result in this error.
See code example below:
It can be easily resolved by correcting the spelling of the function in line 9.
Undeclared variables
When the Java compiler come across an identifier used in the code but it cannot be found in the symbol table, the “cannot find symbol” error is shown. The only reason behind the absence of a variable from the symbol table is that it is not declared in the code. Some new programming languages do not require explicit declaration of variables but it is mandatory in Java to always declare a variable before it is used or referenced in the source code.
The code snippet below demonstrates an undeclared variable in the code. In this case, the identifier sum on line 7, causes the Java “cannot find symbol error”.
See code example below:
Declaring this variable by specifying the appropriate data type can easily resolve the error.
See this corrected code below,
Out of scope variable
When a Java code attempts to access a variable declared out of scope such as in a non-inherited scope the compiler will result in issuing the “cannot find symbol” error. This commonly happens when you attempt to access a variable declared inside a method or a loop, from outside of the method.
See this code example below where the “cannot find symbol” error has occurred when the counter variable which is declared inside a for loop is attempted to be accessed from out of the loop.
See code below:
I can be easily resolved by just moving the if block inside the for loop (local scope).
See this code example,
Missing import statement
Java allows you to use built-in classes or any imported libraries in your code to save your time by reusing the code but it requires importing them properly using the import statements at the start. Missing the import statement in your code will result in the cannot find symbol error.
java.util.Math class is utilized in the code given below but it is not declared with the “import” keyword, resulting in the “cannot find symbol error”.
See code below:
Adding the missing import statement can easily solve the issue, see code below:
Miscellaneous reasons
We have covered some of the main causes of the “cannot find symbol” Java error but occasionally it can also result due to some unexpected reasons. One such case is when attempting to create an object without the new keyword or an accidental semicolon at the wrong place that would terminate the statement at an unexpected point.
Also Read: Functional Interfaces In Java
Some other causes for the cannot find symbol error may include when you forget to recompile the code or you end up using the dependencies with an incompatible version of Java. Building a project with a very old JDK version can also be a reason as well as mistakenly redefining platform or library classes with the same identifier.
Conclusion
We have discussed that the “cannot find symbol Java” error is a Java compile-time error which is encountered whenever an identifier in the source code is not identified by the compiler. Similar to any other compilation error, it is very significant to understand the causes of this error, so that you can easily pinpoint the issue and address it properly.
Once you can discover the reason behind the error, it can be easily resolved as demonstrated by various examples in this article.
Shaharyar Lalani is a developer with a strong interest in business analysis, project management, and UX design. He writes and teaches extensively on themes current in the world of web and app development, especially in Java technology.
Источник
When a user refers to a variable that hasn’t been declared in the application, the “can’t find symbol” error occurs. To put it another way, the compiler isn’t aware of the variable’s declaration. For example:
class HelloCodeunderscored { public static void main( String args[] ) { int x = 15; int y =1 4; // result is not declared. It will show an error. result = x * y; } }
What are possible solutions to this problem?
If you ever encounter this issue, you should review the code for the following scenarios:
- Make sure you’ve declared the variable, for example, int i = 15;. If int has not been written, the error may show.
- Also, see if the defined variable is outside the code, for example, if it is not a member of the HelloCodeunderscored class.
- Make sure you’re using the right case. If you declare a variable as var but access it as Var, it is an example of such a scenario.
- Numbers, dollar signs, and hyphens are not allowed in identifier values; check for them.
Errors in Compilation Time
The compiler examines and checks the code for various things during compilation, including reference types, type casts, and method declarations, to mention a few. This stage of the compilation process is crucial since it is here that we will encounter a compilation mistake.
Compile-time mistakes can be divided into three categories:
Syntax errors
One of the most common programming errors is failing to use a semicolon at the end of a statement; other typical errors include forgetting imports, mismatching parentheses, and omitting the return statement.
Type-checking errors
This is a method of ensuring that our code is type-safe. With this check, we provide that the kinds of expressions are consistent. If we define a variable of type int, we should never assign a value of type double or String to it.
Compiler will crash
Meanwhile, there’s a chance the compiler will crash. It is exceptionally uncommon, but it does happen. In this scenario, it’s good to know that the issue isn’t with our code but with something else.
Compilers follow a set of rules that are specific to each language. If a code doesn’t follow these requirements, the compiler won’t be able to convert it, resulting in a compilation error. The key to resolving the “Cannot find symbol” compilation problem is to figure out what’s causing it.
We may deduce the line of code where the problem occurred and which element is incorrect from the error message. Knowing the most common causes of this mistake will make it easier and faster to resolve.
Symbol Tables: An Overview
Compilers construct and maintain symbol tables, which are significant data structures for storing information related to identifiers in source code. This information is placed into symbol tables during lexical and syntactic analysis and subsequently used in the compilation process.
The identifiers of classes, interfaces, variables, and methods are bound to correspond entries in the symbol tables when the declarations are processed. When these identifiers appear in source code, the compiler looks them up in the symbol tables. It uses that information to confirm that a variable has been declared, establish the variable’s scope, and do type checking to ensure that an expression is semantically correct.
Symbol tables are also employed in the creation and optimization of code. The following is a simplified representation of a symbol table entry (or simply a symbol) in Java:
<symbol name (identifier), type, scope, [attributes]>
The comparable notation for a global variable declaration, such as final double ratio, would be <ratio, double, global, [final]>.
Error: Cannot Find Symbol
As the name implies, the cannot locate symbol error refers to a symbol that you cannot find. While there are a variety of causes for this, they all boil down to the Java compiler being unable to locate the symbol associated with a given identifier.
Two more fields are included in the compiler’s message for the cannot locate symbol error:
“symbol” refers to the name and type of the referenced identifier. On the other hand, “location” refers to the class where the identifier is used.
What causes the symbol cannot be found error?
The following are the most typical causes of the cannot locate symbol compile-time error:
- Variable and method declarations missing,
- References to variables and methods being out of scope
- misspelled identifiers, and
- omitted import statements.
Symbol Not Found vs. Cannot Find Symbol vs. Cannot Resolve Symbol
The cannot find symbol issue can also be encountered under the words symbol not found and cannot resolve symbol, as different Java compilers use somewhat different wording. Apart from the names, there is no difference between the meanings of these phrases.
Examples of “Cannot Find Symbol Error.”
Some of these “Cannot find symbol error” are as follows:
Handling an undeclared variable
The cannot find symbol error is raised when the Java compiler encounters an identifier it can’t find in the symbol table. As a result, the most common cause of this error is when a reference to an undeclared variable is made. Unlike some other languages, which don’t require explicit variable declarations or may enable declaring a variable after it’s been referenced (through hoisting ), Java requires that a variable be declared before being used or referenced in any form.
Figure (a) shows how an undeclared variable, in this case, the identifier average on line 9, causes two instances of the cannot find symbol error at the code’s locations. Figure (b) resolves the issue by declaring this variable with its data type (or inferring its kind with the var keyword in Java 10+).
Figure (a)
package codeunderscored; public class CodeUndeclaredVariable { public static void main(String... args) { int x = 16; int y = 20; int z = 42; averageResults = (x + y + z) / 3.0; // averageResults is not declared System.out.println(averageResults); } }
Figure (b)
package codeunderscored; public class UndeclaredVariable { public static void main(String... args) { int x = 16; int y = 20; int z = 42; double averageResults = (x + y + z) / 3.0; System.out.println(averageResults); } }
Dealing with an Out of scope variable
The compiler throws the cannot find symbol error when a Java application tries to access a variable declared in a separate (non-inherited or non-overlapping) scope. The effort to try and have access to the variable counter on lines 17 and 18 in Figure (a), which is only available within the statement declared on line 11, demonstrates this. Figure (b) indicates that moving the counter variable outside the for loop resolves the problem.
Figure (a)
package codeunderscored; import java.util.Arrays; import java.util.List; public class CodeOutOfScopeVariable { public static void main(String... args) { final List<String> strings = Arrays.asList("Hello", "Codeunderscored"); final String searchFor = "Codeunderscored"; for (int counter = 0; counter < strings.size(); counter++) { if (strings.get(counter).equals(searchFor)) { break; } } if (counter < strings.size()) { System.out.println("The word " + searchFor + " was found at index " + counter); } else { System.out.println("The word " + searchFor + " wasn't found"); } } }
Figure (b)
package codeunderscored; import java.util.Arrays; import java.util.List; public class CodeOutOfScopeVariable { public static void main(String... args) { final List<String> strings = Arrays.asList("Hello", "Codeunderscored"); final String searchFor = "Codeunderscored"; int counter; for (counter = 0; counter < strings.size(); counter++) { if (strings.get(counter).equals(searchFor)) { break; } } if (counter < strings.size()) { System.out.println("The word " + searchFor + " was found at index " + counter); } else { System.out.println("The word " + searchFor + " wasn't found"); } } }
Figures (a) & (b): Error and resolution for not being able to discover a symbol for an out-of-scope variable.
Method name misspelled
A cannot locate symbol error is caused by misspelling an existing method or any valid identifier. Because Java identifiers are case-sensitive, any change of an existing variable, method, class, interface, or package name, as shown in Figure (b), will result in this error.
Figure (a)
package codeunderscored; public class CodeMisspelledMethodName { static int fibonacci(int n) { if (n == 0) return 0; if (n == 1) return 1; return fibonacci(n - 1) + fibonacci(n - 2); } public static void main(String... args) { int fibResult = Fibonacci(20); // Fibonacci ≠ fibonacci System.out.println(fibResult); } }
Figure (b)
package codeunderscored; public class CodeMisspelledMethodName { static int fibonacci(int n) { if (n == 0) return 0; if (n == 1) return 1; return fibonacci(n - 1) + fibonacci(n - 2); } public static void main(String... args) { int fibResult = fibonacci(20); System.out.println(fibResult); } }
Error Figure (a) and resolution Figure (b): Cannot find the symbol for a misspelled method name
An import statement is missing
Using classes, whether from the Java platform or a library, necessitates appropriately importing them using the import statement. If you don’t, the Java compiler will complain about a symbol that can’t be found. The java.util package is used in the code sample in Figure (a). The cannot locate symbol issue arises because the list class was created without specifying the necessary import. The problem is solved by adding the missing import statement line 4 in Figure (b).
Figure (a)
package codeunderscored; import java.util.Arrays; public class CodeMissingImportList { private static final List<String> CONSTANTS = Arrays.asList("A", "B", "C"); public static void main(String... args) { System.out.println(CONSTANTS); } }
Figure (b)
package codeunderscored; import java.util.Arrays; import java.util.List; public class CodeMissingImportList { private static final List<String> CONSTANTS = Arrays.asList("A", "B", "C"); public static void main(String... args) { System.out.println(CONSTANTS); } }
Figure (a) Error and resolution (b): Cannot find the symbol for missing import
Examples that aren’t as common
The fundamental cause of the Java error cannot locate the symbol is sometimes found in unexpected or hidden areas. It is the case when a sentence is prematurely terminated by an unintentional semicolon Figure (a) or when object creation is attempted without a correct constructor invocation, which must include the new keyword Figure 6.
Figure (a)
package codeunderscored; public class CodeLoopScope { public static void main(String... args) { int start = 1, end = 10; for (int i = start; i <= end; i++); { System.out.print(i == end ? i : i + ", "); } } }
Figure (b)
package codeunderscored; public class CodeLoopScope { public static void main(String... args) { int start = 1, end = 10; for (int i = start; i <= end; i++) { System.out.print(i == end ? i : i + ", "); } } }
Unable to locate a symbol for a prematurely stopped loop Figure (a) error and Figure (b) resolution
Figure (a)
package codeunderscored; public class CodeObjectCreation { public static void main(String... args) { String s = String("Hello Codeunderscored!"); System.out.println(s); } }
Figure (b)
package codeunderscored; public class CodeObjectCreation { public static void main(String... args) { String s = new String("Hello Codeunderscored!"); System.out.println(s); } }
Figure (a) Error and Figure (b) Resolution for Cannot Find Symbol Constructor Call
Other reasons for the problem “can’t find symbol” include:
Here are a few instances where the “Cannot detect symbol” appears unexplainable until you investigate further.
Inability to find symbol ‘var’:
You’re presumably trying to compile source code with an older compiler or an older—source level that employs local variable type inference (i.e., a var declaration). In Java 10, the var was introduced. Check your JDK version, build files, and IDE settings (if this happens in an IDE).
You’re not compiling or recompiling anything
New Java programmers occasionally don’t grasp how the Java toolchain works or haven’t set up a repeatable “build process,” such as utilizing an IDE, Ant, Maven, Gradle, etc. In this case, the programmer may end up chasing his tail, looking for an imaginary fault that is caused by improper recompilation of the code, and so on.
Another example is when you compile and run a class with (Java 9+) java SomeClass.java. You’re likely to get “Cannot resolve symbol” errors referring to the 2nd class if the class depends on another class that you haven’t compiled (or recompiled). The other source file(s) are not compiled automatically. In addition, the new “compile and execute” mode of the java command isn’t suited for launching programs with multiple source code files.
Incorrect dependencies
If you use an IDE or a build tool that manages the build path and project dependencies, you may have made a mistake with the dependencies; for example, you may have left out a dependency or chosen the incorrect version. Check the project’s build file if you’re using a build tool (Ant, Maven, Gradle, etc.). Further, examine the project’s build path setup if you’re using an IDE.
An issue with a previous build
It’s possible that a previous build failed, so a JAR file was created with missing classes. You would usually note such failure if you were using a build tool. If you acquire JAR files from someone else, you’ll have to rely on them constructing correctly and catching mistakes.
Use tar -tvf when you need to list the suspected JAR files contents if you suspect this.
Problems with Android
When programming for Android and seeing “Cannot discover symbol” issues linked to R, keep in mind that the context.xml file defines the R symbols. Check that your context.xml file is valid and in the right location and that the R class file for it has been generated and compiled. Because Java symbols are case sensitive, the corresponding XML ids are as well.
Other symbol problems on Android are most frequently caused by the factors mentioned above, such as missing or inaccurate dependencies, wrong package names, methods or fields that don’t exist in a specific API version, spelling/typing issues, and so on.
Problems with the IDE
People have reported occasions when their IDE becomes confused, and the compiler in the IDE cannot detect a class that already exists… or vice versa. If the IDE is set up with the incorrect JDK version, it can happen.
If the IDE’s caches become out of sync with the file system, it can happen.
There are IDE-specific solutions to this. The latter could be a problem in the IDE. For example, there is a typical case of how Eclipse incorrectly handled a Maven “test” tree. That particular bug, it appears, was fixed a long time ago.
Homoglyphs
It’s possible to have identifiers that appear the same but aren’t because they contain homoglyphs if you use UTF-8 encoding for your source files. You can circumvent this by limiting the source file encoding to ASCII or Latin-1 and utilizing Java uxxxx escapes for additional characters.
Hidden System classes
We’ve seen situations when the compiler complains that substring is an unknown symbol, such as this.
String s = ... String s1 = s.substring(1);
It turns out that the programmer had written their version of String, which lacked substring operations. It has been done with System, Scanner, and other classes in the past.
Overall, don’t use the same names as common library classes when defining your classes! You can also use fully qualified names to remedy the situation. In the preceding example, the programmer may have written:
java.lang.String s = ... java.lang.String s1 = s.substring(1);
What should I do about these errors?
- In general, you should start by determining what triggered the compilation mistake.
- Examine the line in the file that the compilation error notice refers to.
- Determine which symbol the error message is referring to.
- Figure out why the compiler says it can’t find the symbol; check the section above!
- Then you consider what your code is trying to communicate.
- Subsequently, try to figure out what changes you need to make to your source code to get it to do what you want.
It’s worth noting that not every “correction” is accurate. Consider the following:
for (int i = 1; i < 10; i++) { for (j = 1; j < 10; j++) { ... } }
Assume the compiler says for j, “Cannot find symbol.” There are several ways we could “correct” this:
- We suppose we could edit the inner for to for (int j = 1; j< 10; j++) – which would be correct.
- Alternatively, we could put a declaration for j before the inner or outer for loops, which would probably be correct.
- In the inner for loop, we could also change j to i, and that would be incorrect! and so forth. To discover the proper remedy, you must first understand what your code is attempting to accomplish.
Example: how erroneous variable scoping can result in a “Cannot find symbol” error
List<String> stringsVar = ... for (int i = 0; i < stringsVar.size(); i++) { if (stringsVar.get(i).equalsIgnoreCase("fnord")) { break; } } if (i < strings.size()) { ... }
For i in the if statement, this will result in a “Cannot find symbol” problem. Even though we earlier declared i, it only applies to the for statement and its body. The if statement’s reference to i cannot see that declaration of I because it is not within the project’s scope. A suitable correction would be to place the if statement within the loop or declare I before the loop begins.)
Example: an apparently strange “Cannot find symbol” issue caused by a typo
for (int i = 0; i < 100; i++); { System.out.println("i is " + i); }
It will result in a compilation error in the println call, indicating that i is missing. But (as you point out), we did declare it!
The issue is the semicolon (;) that appears before the {. In that instance, a semicolon is an empty statement according to the Java language syntax. The for loop’s body is therefore made up of the empty statement. So here’s what that code actually means:
for (int i = 0; i < 100; i++); // The previous and following are separate statements!! { System.out.println("i is " + i); }
The preceding declaration of i in the for statement is out of scope in the block. That is because the {…} block is not the body of the for loop.
Example: A “Cannot find symbol” error produced by a typo
int tmp = ... int res = tmp(a + b);
The tmp in the tmp(…) phrase is incorrect, despite the earlier declaration. The compiler will look for a tmp method, but it will not locate one. The previously specified tmp is in the variables namespace, not the methods namespace. In one of the examples we saw, the programmer had forgotten to include an operator. This is what he wanted to write:
If you’re compiling from the command line, there’s another reason why the compiler might not discover a symbol. It’s possible that you just neglected to build or recompile another class.
For instance, suppose you have two classes, Secondary and Primary, and Secondary utilizes Primary. If you’ve never compiled Primary before and run javac Secondary.java, the compiler will likely fail because it can’t find the symbol Primary.
Compile Secondary and Primary together, for example, with javac Secondary.java Primary.java or javac *.java. Better still, utilize a Java build tool such as Ant, Maven, Gradle, etc.
Conclusion
The cannot find symbol error, also known as a symbol not found and cannot resolve symbol, is a Java compile-time error that occurs when the compiler cannot figure out what an identifier in the source code refers to. As with every other compilation fault, it’s critical to figure out what’s causing it, isolate the problem, and fix it effectively.
This error is mainly caused by referring to undeclared variables and methods, such as by misspelling them or failing to import their associated package. As seen in this article, once a problem has been identified, resolving it is relatively simple.
I am getting error like cannot find symbol for import and @ . How to resolve it ?
1 create or replace and compile java source named «AddressTypeDbProcedure» as
2 import javax.xml.bind.annotation.XmlAccessType;
3 import javax.xml.bind.annotation.XmlAccessorType;
4 import javax.xml.bind.annotation.XmlElement;
5 import javax.xml.bind.annotation.XmlSeeAlso;
6 import javax.xml.bind.annotation.XmlType;
7 public class AddressType {
8 @XmlElement(name = «StreetAddress»)
9 protected String streetAddress;
10 public String getStreetAddress() {
11 return streetAddress;
12 }
13 public void setStreetAddress(String value) {
14 this.streetAddress = value;
15 }
16* };
17 /
Warning: Java created with compilation errors.
SQL> show errors;
Errors for JAVA SOURCE «AddressTypeDbProcedure»:
LINE/COL ERROR
——— ——————————————————————
0/0 AddressTypeDbProcedure:1: cannot find symbol
0/0 6 errors
0/0 location: package javax.xml.bind.annotation
0/0 import javax.xml.bind.annotation.XmlAccessType;
0/0 ^
0/0 AddressTypeDbProcedure:2: cannot find symbol
0/0 symbol : class XmlAccessorType
0/0 location: package javax.xml.bind.annotation
0/0 import javax.xml.bind.annotation.XmlAccessorType;
0/0 ^
0/0 AddressTypeDbProcedure:3: cannot find symbol
LINE/COL ERROR
——— ——————————————————————
0/0 symbol : class XmlElement
0/0 location: package javax.xml.bind.annotation
0/0 import javax.xml.bind.annotation.XmlElement;
0/0 ^
0/0 AddressTypeDbProcedure:4: cannot find symbol
0/0 symbol : class XmlSeeAlso
0/0 location: package javax.xml.bind.annotation
0/0 import javax.xml.bind.annotation.XmlSeeAlso;
0/0 ^
0/0 AddressTypeDbProcedure:5: cannot find symbol
0/0 symbol : class XmlType
LINE/COL ERROR
——— ——————————————————————
0/0 location: package javax.xml.bind.annotation
0/0 import javax.xml.bind.annotation.XmlType;
0/0 ^
0/0 AddressTypeDbProcedure:7: cannot find symbol
0/0 symbol : class XmlElement
0/0 location: class AddressType
0/0 @XmlElement(name = «StreetAddress»)
0/0 ^
0/0 symbol : class XmlAccessType
SQL>
Vinodh