Programming/Java2014. 3. 13. 21:59
cpp 에서 virtual 로 테스트 해본건 아니라 확인이 필요함

class Parent {
String msg = "Parent 클래스";
public String getMsg() {return msg;}
}

class Child extends Parent {
String msg = "Child 클래스";
public String getMsg(){return msg;}
}

public class OverridingEx {

public static void main(String[] args)
{
// TODO Auto-generated method stub
Child cd = new Child();
System.out.println("cd : " + cd.getMsg());

Parent pt = new Child();
System.out.println("pt : " + pt.getMsg());

Parent ct = new Parent();
System.out.println("ct : " + ct.getMsg());
}
} 

결과는 cpp에서 하던 것과는 좀 다르게
Child() 객체를 Parent의 형으로 변환해주어도 실제 객체는 Parent로 인식하는 것이 아닌 Child로 인식을 한다.
cd : Child 클래스
pt : Child 클래스
ct : Parent 클래스 

이는 자바의 동적 바인딩(Dynamic binding)으로 인해
객체의 원형을 추적하여 원래 연결되어야 할 메소드를 호출하기 때문이다. 

[링크 : http://slsjyh.blog.me/30111917680]



+
기억이 잘 나지 않아 vs2008/cpp g++/cpp로 포팅 후 돌려보았는데
결과가 다르게 나왔다. 아무래도 타입에 따라서 형을 추적하는 수준에는 자바와 cpp에는 차이가 있어 보인다.

#include < iostream >
#include < string >

using namespace std;

string pmsg = "Parent 클래스";
string cmsg = "Child 클래스";

class Parent {
public:
	string getMsg()	{return pmsg;}
};

class Child:Parent {	
public:
	string getMsg()	{return cmsg;}
};

class OverridingEx {
public:
	static void main()
	{
		// TODO Auto-generated method stub
		Child *cd = new Child();
		cout << "cd : " + cd->getMsg() << endl;

		//Child *t = new Child();
		//Parent *pt = (Parent *)t;
		Parent *pt = (Parent *)(new Child());
		cout << "pt : " + pt->getMsg() << endl;

		Parent *ct = new Parent();
		cout << "ct : " + ct->getMsg() << endl;
	}
} ;

int main(int argc, char **argv)
{
		OverridingEx ex;// = new OverridingEx();
		ex.main();

        return 0;
}

cd : Child 클래스
pt : Parent 클래스
ct : Parent 클래스  

하지만 virtual로 가상함수를 만들어 오버로딩 시키면
java와 같이 제대로 동적 바인딩을 통해 실행을 할 수 있다.
class Parent {
public:
virtual string getMsg() {return pmsg;}
};

class Child:Parent {
public:
virtual string getMsg() {return cmsg;}
}; 

cd : Child 클래스
pt : Child 클래스
ct : Parent 클래스 

+
2013.03.14 추가
동적 바인딩은 인스턴스 변수와 스태틱 메소드에 대해서는 적용되지 않는다.
[링크 : http://haneulnoon.tistory.com/90]

'Programming > Java' 카테고리의 다른 글

java private constructor  (0) 2014.03.14
java abstract / interface & cpp virtual  (0) 2014.03.14
Java for문 내 변수는 매번 초기화 된다.  (0) 2014.03.13
Java array  (0) 2014.03.13
java string.intern()  (0) 2014.03.12
Posted by 구차니
프로그램 사용/eclipse2014. 3. 13. 19:52
eclipse로 java 공부하다 이상한 현상을 발견 -_-
public class Test {
public static void main(String args[])
{
for(String s: args)
System.out.println(s);
}
} 

 argument에 인자로 *을 넣어주면


이런게 나온다. 아마도 실행관련 설정이 eclipse에서 *과 치환되는거 같긴한데..
어떤 이유로 어디서 치환된건지 모르겠네...
.classpath
.project
.settings
bin
doc
src 


2014.05.08 추가
이클립스 버그이거나 JVM 문제일 것으로 생각된다.
2009년도에 있던 버그로 잠시 사라졌다 다시 부활.. -_-a

[링크 : http://stackoverflow.com/questions/15299154/wildcard-expansion-in-eclipse-run-configuration]
[링크 : https://bugs.eclipse.org/bugs/show_bug.cgi?id=212264]

'프로그램 사용 > eclipse' 카테고리의 다른 글

ECJ - Eclipse Compiler for Java  (0) 2014.03.25
eclipse JRE 설정하기  (0) 2014.03.20
eclipse JWT / SWING UI 디자이너  (0) 2014.03.10
eclipse JDT + javadoc  (0) 2014.03.10
eclipse auto indent  (0) 2014.03.07
Posted by 구차니
Programming/Java2014. 3. 13. 17:25
c 에서는 j가 초기값으로 4만 되고 for문에서 증가가 될 텐데
java에서는 허용을 안하는지 4만 계속 나오게 된다. 
 
public class Test {
public static void main(String args[])
{
for(int i = 0; i<10;i++)
{
int j = 4;
System.out.println(j++);
}
}
} 

4
4
4
4
4
4
4
4
4
4

굳이 하려면 이런식으로 for문 내의 초기화 문을 이용하면 되는데 타입이 하나만 할 수 있는 건 좀 아쉬운 듯..
public class Test {
public static void main(String args[])
{
for(int i = 0, j = 4; i<10;i++)
{
// int j = 4;
System.out.println(j++);
}
}
} 

---
음? 집에와서 vs2008로 cpp / c로 생성해서 해보니
둘다 j 값이 초기화 된다? 어?!?!?

게다가.. gcc도 안되네??! 헉?!?! 머지??!?!?!
원래 안되던 방법인가!?!? ㅠㅠ 


---
그러고 보니.. 이렇게 쓰려면.. static으로 해야지 증가했던거 같기도 하고.. 끄아아.. 
기억이 가물가물 하다 ㅠㅠ 

'Programming > Java' 카테고리의 다른 글

java abstract / interface & cpp virtual  (0) 2014.03.14
Java / cpp - 다형성(polymorphism) 차이점 (동적 바인딩?)  (0) 2014.03.13
Java array  (0) 2014.03.13
java string.intern()  (0) 2014.03.12
java bytecode decompiler - javap  (0) 2014.03.12
Posted by 구차니
Programming/Java2014. 3. 13. 17:18
선언
int array[][]; // c style
int[][] array; // java style
 
2차원 배열에서 1차원과 2차원 각각에 대한 인자갯수 확인
array.length;
array[0].length;

가변배열
int array[][] = new int[N][];

[링크 : http://stackoverflow.com/questions/13383692/for-each-loop-using-2d-array]
[링크 : http://docs.oracle.com/.../java/lang/System.html#arraycopy(java.lang.Object, int, java.lang.Object, int, int)
Posted by 구차니
프로그램 사용/VLC2014. 3. 13. 17:03
예전에 집에서 해본 거 같은데.. 기억이 안나네?

[링크 : http://www.videolan.org/doc/streaming-howto/en/ch04.html]
Posted by 구차니
embeded/AVR (ATmega,ATtiny)2014. 3. 13. 12:47
IM2와 IM1은 GND/IOVCC로 연결되면서 01로 고정된다.
그런 이유로 8bit Little Endian이 불가능 하다는 정도의 사소한(?) 단점이 생긴다.


그런데.. 16bit용 데이터 전송 타이밍 시트는 있지만.
18bit는 타이밍 시트가 존재하지 않고 이런것만 있는데.. 무슨 의미이려나?

그냥 1:1로 바로 전송하는 건가?

 
거상인 Atmega8과 연결하려고 해보니..
CS는 하나의 칩만 쓰니 HI로 놓고 하면 어찌어찌 18bit 모드로 사용이 가능할.. 지도?
[링크 : http://www.gersangin.com/shop/goods/goods_view.php?&goodsno=1092&category=025]

16모드라면 여유가 있다.

'embeded > AVR (ATmega,ATtiny)' 카테고리의 다른 글

Atmel AVR 라인트레이서 및 IR 관련 링크  (0) 2014.03.22
LM-324과 ST-1K 사용하기 2  (0) 2014.03.22
avr glcd (128x64) 예제  (0) 2014.03.12
CM04075 데이터 백업용  (0) 2014.02.20
Graphic LCD 지름예고  (0) 2014.02.09
Posted by 구차니
개소리 왈왈/수영2014. 3. 12. 23:44
자유영 숨쉬기
오른팔을 누르면서 고개를 동시에 돌려 숨쉬기
-> 고개를 먼저 돌리고 오른팔을 누르면서 숨쉬기
고개를 먼저 돌리고 숨을 내쉬면서 물밖으로 나온뒤 숨을 들이 마쉼으로서
여유롭게 호흡이 가능해짐

자유영 팔젓기
팔을 쭈욱 펴고 허벅지 까지 물을 밀어주고
물 밖으로 나오는 반동으로 팔꿈치만 꺽어 앞으로 팔을 되돌림
-> 속도 향상 및 추진력+물에 뜨는 시간 증가로 호흡이 유리해짐 


배영 숨쉬기
코로 내쉬고 입으로 들이 마시기 
코에 물이 안들어 오니 좋긴한데.. 여전히 타이밍 문제가.. ㅠㅠ


평영 팔젓기
8자 박수를 치듯
팔 아랫부분 전반적으로 추진에 이용됨으로 속도 향상 


접영 발차기
팔 내리고 -> 발차고(잠수) -> 웨이브(전진) -> 발차고(부상) -> 물 끌어 당기고(호흡) -> 팔 리턴 
전에는 못하던 발차기가 추가되어서 호흡이 용이해짐

'개소리 왈왈 > 수영' 카테고리의 다른 글

접영 업그레이드  (0) 2014.07.10
영법별 현재 상태  (0) 2014.06.13
헤딩한지.. 4일...차?  (0) 2014.03.02
접영 영업 업그레이드  (0) 2014.03.01
배영영업 업그레이드  (0) 2014.02.21
Posted by 구차니
Programming/Java2014. 3. 12. 21:19
intern()은 메모리 사용을 줄이기 위해 사용한다.

heap에 할당된 내용을
stack영역에 설정된(엄밀하게는 string pool) 변수들을 조회하여
중복내용이 있을 경우 heap의 메모리를 해제하고
string pool의 주소로 치환하여 사용하는 메모리를 줄여준다.

그렇기에 == 연산자를 통한 "동일객체" 비교시 동일한 객체로 인식될 수 있게 된다.
(하지만 변수들을 조회한다는 것 자체가 엄청난 부하...)

[링크 : http://ggaman.tistory.com/918]
[링크 : http://www.mimul.com/pebble/default/2008/01/02/1199269440000.html]
[링크 : http://docs.oracle.com/javase/7/docs/api/java/lang/String.html#intern()]

'Programming > Java' 카테고리의 다른 글

Java for문 내 변수는 매번 초기화 된다.  (0) 2014.03.13
Java array  (0) 2014.03.13
java bytecode decompiler - javap  (0) 2014.03.12
java static initialize  (0) 2014.03.12
java 1.5 이후 추가 for-each / varargs(autoboxing)  (0) 2014.03.11
Posted by 구차니
Programming/Java2014. 3. 12. 19:59
자바는 바이트 코드로 컴파일 된 후, 인터프리터로 실행되는데
컴파일된 class 파일을 덤프하는 자바 디 컴파일러가 javap로 기본 내장되어있다.
물론 출력이 오리지널 java 파일로 나오는건 아니니 디버깅 용도의 덤프수준..

C:\Program Files\Java\jdk1.7.0_51\bin>javap
Usage: javap <options> <classes>
where possible options include:
  -help  --help  -?        Print this usage message
  -version                 Version information
  -v  -verbose             Print additional information
  -l                       Print line number and local variable tables
  -public                  Show only public classes and members
  -protected               Show protected/public classes and members
  -package                 Show package/protected/public classes
                           and members (default)
  -p  -private             Show all classes and members
  -c                       Disassemble the code
  -s                       Print internal type signatures
  -sysinfo                 Show system info (path, size, date, MD5 hash)
                           of class being processed
  -constants               Show static final constants
  -classpath <path>        Specify where to find user class files
  -bootclasspath <path>    Override location of bootstrap class files 

[링크 : http://flowonweb.com/post/29756735269/java-bytecode]
[링크 : http://skyul.tistory.com/334]

'Programming > Java' 카테고리의 다른 글

Java array  (0) 2014.03.13
java string.intern()  (0) 2014.03.12
java static initialize  (0) 2014.03.12
java 1.5 이후 추가 for-each / varargs(autoboxing)  (0) 2014.03.11
JUnit 사용 예  (0) 2014.03.11
Posted by 구차니
Programming/Java2014. 3. 12. 18:18
정적 초기화 / static initalize는 
static member variable에 대한 초기화를 수행하는 루틴이다.

static 변수들의 경우 해당 클래스가 인스턴스화 되어 메모리에 올려지지 않더라도(힙에 할당)
스택에서 바로 실행이 되어야 하는 부분이므로
main문이 실행되기 전에 클래스 초기화를 하며 static에 상주하게 되며
static initialize block을 통해 조금은 더 복잡한 구문을 지원하게 된다. (try-catch등의 복잡한)

어떻게 보면.. 일종의 static 변수들에 대한 constructor 라고 볼 수 있으려나?

public class StaticTest4 {
static
{
System.out.println("Statis init1");
}

static String s = echo("string");
static
{
System.out.println("Statis init2");
}

static String echo(String s)
{
System.out.println(s);
return s;
}

public static void main(String[] args)
{
// TODO Auto-generated method stub
System.out.println("main");
StaticTest4 st4 = new StaticTest4();
}

}
 

결과는 main 문에 들어가기 전에 static 에 대한 초기화를 먼저 수행함을 볼 수 있다.
Static init1
string
Static init2
main 

[링크 : http://raoo.tistory.com/54]
[링크 : http://cafe.naver.com/hanbitria/15]

 This works well when the initialization value is available and the initialization can be put on one line. However, this form of initialization has limitations because of its simplicity. If initialization requires some logic (for example, error handling or a for loop to fill a complex array), simple assignment is inadequate. Instance variables can be initialized in constructors, where error handling or other logic can be used. To provide the same capability for class variables, the Java programming language includes static initialization blocks.
[링크 : http://docs.oracle.com/javase/tutorial/java/javaOO/initial.html


'Programming > Java' 카테고리의 다른 글

java string.intern()  (0) 2014.03.12
java bytecode decompiler - javap  (0) 2014.03.12
java 1.5 이후 추가 for-each / varargs(autoboxing)  (0) 2014.03.11
JUnit 사용 예  (0) 2014.03.11
java class default access modifier  (0) 2014.03.11
Posted by 구차니