[java] Java 변수의 메모리 주소

아래 그림을 참조하십시오. new키워드를 사용하여 java에서 객체를 만들면 OS에서 메모리 주소를 얻습니다.

우리가 쓸 때 out.println(objName)“특별한”문자열을 출력으로 볼 수 있습니다. 내 질문은 :

  1. 이 결과는 무엇입니까?
  2. OS가 우리에게 제공 한 메모리 주소 인 경우 :

    a)이 문자열을 이진수로 어떻게 변환 할 수 있습니까?

    b) 하나의 정수 변수 주소를 어떻게 얻을 수 있습니까?

대체 텍스트



답변

클래스 이름과 System.identityHashCode () 는 ‘@’문자로 구분됩니다. 아이덴티티 해시 코드가 나타내는 것은 구현에 따라 다릅니다. 종종 개체의 초기 메모리 주소이지만 시간이 지남에 따라 VM에서 개체를 메모리에서 이동할 수 있습니다. 따라서 (간결하게) 아무것도 아닌 것에 의존 할 수 없습니다.

JVM이 객체를 구현하고 적절하게 보이는대로 자유롭게 움직일 수 있기 때문에 변수의 메모리 주소를 얻는 것은 의미가 없습니다 (가비지 수집 중에 객체가 움직일 수 있음).

Integer.toBinaryString () 은 이진 형식의 정수를 제공합니다.


답변

그것은 가능합니다 sun.misc.Unsafe: @ Peter Lawrey의 훌륭한 답변을보십시오-> 참조 주소를 얻는 방법이 있습니까?

printAddresses () 코드를 사용하여 :

    public static void printAddresses(String label, Object... objects) {
    System.out.print(label + ": 0x");
    long last = 0;
    int offset = unsafe.arrayBaseOffset(objects.getClass());
    int scale = unsafe.arrayIndexScale(objects.getClass());
    switch (scale) {
    case 4:
        long factor = is64bit ? 8 : 1;
        final long i1 = (unsafe.getInt(objects, offset) & 0xFFFFFFFFL) * factor;
        System.out.print(Long.toHexString(i1));
        last = i1;
        for (int i = 1; i < objects.length; i++) {
            final long i2 = (unsafe.getInt(objects, offset + i * 4) & 0xFFFFFFFFL) * factor;
            if (i2 > last)
                System.out.print(", +" + Long.toHexString(i2 - last));
            else
                System.out.print(", -" + Long.toHexString( last - i2));
            last = i2;
        }
        break;
    case 8:
        throw new AssertionError("Not supported");
    }
    System.out.println();
}

이 테스트를 설정했습니다.

    //hashcode
    System.out.println("Hashcode :       "+myObject.hashCode());
    System.out.println("Hashcode :       "+System.identityHashCode(myObject));
    System.out.println("Hashcode (HEX) : "+Integer.toHexString(myObject.hashCode()));

    //toString
    System.out.println("toString :       "+String.valueOf(myObject));

    printAddresses("Address", myObject);

출력은 다음과 같습니다.

Hashcode :       125665513
Hashcode :       125665513
Hashcode (HEX) : 77d80e9
toString :       java.lang.Object@77d80e9
Address: 0x7aae62270

결론 :

  • 해시 코드! = 주소
  • toString = class @ HEX (해시 코드)

답변

이것이 Object의 “toString ()”구현 결과입니다. 클래스가 toString ()을 재정의하면 완전히 다른 것을 인쇄합니다.


답변

입니다 메모리 주소가 아닌
이것은 클래스 명에 @ 해시 코드

어디

classname = 정규화 된 이름 또는 절대 이름 (예 : 패키지 이름 뒤에 클래스 이름)

hashcode = 16 진수 형식 (System.identityHashCode (obj) 또는 obj.hashCode ()는 10 진수 형식의 해시 코드를 제공합니다)


답변

Sunil이 말했듯 이 이것은 메모리 주소 가 아니며 해시 코드 일뿐입니다.

동일한 @ 컨텐츠를 얻으려면 다음을 수행하십시오.

해당 클래스에서 hashCode가 재정의되지 않은 경우 :

"@" + Integer.toHexString(obj.hashCode())

hashCode가 재정의되면 다음을 사용하여 원래 값을 얻습니다.

"@" + Integer.toHexString(System.identityHashCode(obj)) 

hashCode ()를 재정의하지 않으면 해시를 계산하는 데 메모리 주소가 사용되므로 메모리 주소와 혼동되는 경우가 많습니다.


답변

당신이 얻는 것은 Object 클래스의 toString () 메소드 또는 더 정확하게 uzay95가 지적한 identityHashCode ()의 결과입니다.

“새 키워드로 java에서 객체를 만들면 OS에서 메모리 주소를 얻습니다.”

Java에서 수행하는 모든 작업이 Java Virtual Machine에 의해 처리된다는 것을 인식해야합니다. 이 정보를 제공하는 것은 JVM입니다. 호스트 운영 체제의 RAM에서 실제로 발생하는 것은 전적으로 JRE의 구현에 달려 있습니다.


답변

이것은 java의 해시 코드에 대해 알고 유용합니다.

http://eclipsesource.com/blogs/2012/09/04/the-3-things-you-should-know-about-hashcode/