In computer programming, scope is an enclosing context where values and expressions are associated. The scope resolution operator helps to identify and specify the context to which an identifier refers, particularly by specifying a namespace. The specific uses vary across different programming languages with the notions of scoping. In many languages, the scope resolution operator is written ::. In some languages, notably those influenced by Modula-3, modules are objects, and scope resolution within modules is a special case of usual object member access, so the usual method operator . is used for scope resolution. Other languages, notably C++ and Ruby, feature both scope resolution and method access, which interact in various ways; see examples below.
C++
class A ; namespace B // namespace B int A::i = 4; // scope operator refers to the integer i declared in the class A int x = B::j; // scope operator refers to the integer j declared in the namespace B
In PHP, the scope resolution operator is also called Paamayim Nekudotayim, which means “double colon” in Hebrew. The name "Paamayim Nekudotayim" was introduced in the Israeli-developed Zend Engine 0.5 used in PHP 3. Although it has been confusing to many developers who do not speak Hebrew, it is still being used in PHP 7, as in this sample error message: $ php -r :: Parse error: syntax error, unexpected T_PAAMAYIM_NEKUDOTAYIM
A similar error can also occur where no scope resolution operator is present. For example, attempting to check whether a constant is empty triggers this error: $ php -r 'define; if echo "empty";' Parse error: syntax error, unexpected ')', expecting T_PAAMAYIM_NEKUDOTAYIM
As of PHP 5.4, error messages concerning the scope resolution operator still include this name, but have clarified its meaning somewhat: $ php -r :: Parse error: syntax error, unexpected '::'
There are other less obvious ways to trigger the error, for example by attempting to use the following invalid PHP expression: $ php -r static const $a=1 Parse error: syntax error, unexpected end of file, expecting ::
Ruby
In Ruby, scope resolution can be specified using namespaces. module Example Version = 1.0 class << self # We are accessing the module's singleton class def hello "Hello #" end end end #/Example Example::hello # => "Hello world" Example.hello "hacker" # => "Hello hacker" Example::Version # => 1.0 Example.Version # NoMethodError
This illustrates the difference between the message operator and the scope operator in Ruby
We can use both ::hello and.hello, because hello is a part of Example's scope and because Example
responds to the message hello.
We can't do the same with ::Version and.Version, because Version is within the scope of Example, but
Example can't respond to the message Version, since there is no method to respond with.