Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.java.programmer > #8544
| From | Daniel Pitts <newsgroup.nospam@virtualinfinity.net> |
|---|---|
| Newsgroups | comp.lang.java.programmer |
| Subject | Re: JNI generic type of jobject |
| References | <j6etsu$lkf$1@online.de> <4e8afbde$0$2529$e4fe514c@news2.news.xs4all.nl> <C5Fiq.2704$x14.849@newsfe22.iad> <10625927.131.1317754868953.JavaMail.geo-discussion-forums@prfc6> |
| Message-ID | <DXIiq.1731$Gu.1318@newsfe14.iad> (permalink) |
| Date | 2011-10-04 12:15 -0700 |
On 10/4/11 12:01 PM, Lew wrote:
> Daniel Pitts wrote:
>>> Philipp Kraus wrote:
>>>> I use JNI calls for some Java classes. Some Java classes are generic
>>>> classes like:
>>>>
>>>> class mytestclass<T> {
>>>>
>>>> public native void mymethod();
>>>>
>>>> }
>>>>
>>>> The stub shows:
>>>>
>>>> JNIEXPORT void JNICALL Java_mytestclass_mymethod(JNIEnv* p_env, jobject
>>>> p_object)
>>>>
>>>> How can I get from the jobject which object type is the generic
>>>> parameter T? Because I would
>>>> like to create different codes if I do something like:
>>>>
>>>> mytestclass<int> x = new mytestclass<int>();
>>>> x.mymethod();
>>>>
>>>> mytestclass<String> x = new mytestclass<String>();
>>>> x.mymethod();
>>>
>> int is not a valid generic type parameter, as int is a primitive and
>> generic types must be Object types.
>>
>> Also, generics are not the same as C++ templates. There isn't different
>> code created for each concrete usage. Its all exactly the same code.
>>
>> If you are doing different behavior based on the compile time type, then
>> you need to do a little bit more work to implement the strategy pattern.
>>
>> class MyTestClass<T> {
>> private MyMethodStrategy<T> strategy;
>>
>> public mymethod() {
>> strategy.mymethod(this);
>> }
>> }
>>
>> interface MyMethodStrategy<T> {
>> void mymethod(MyTestClass<T> testClass);
>> }
>>
>>
>> class MyStringMethodStrategy implement MyMethodStrategy<String> {
>> public native void mymethod(MyTestClass<String> testClass);
>> }
>>
>>
>> class MyIntegerMethodStrategy implement MyMethodStrategy<Integer> {
>> public native void mymethod(MyTestClass<Integer> testClass);
>> }
>>
>>
>> Then you will have two different native methods to implement each strategy.
>
> Kudos for a great answer!
> +1
>
> This pattern or ones like it are frequent and very helpful in generics programming.
>
They also provide greater flexibility for pluggable (user-defined)
behavior. When applicable, I often replace protected methods with
strategy interfaces. Especially if any two protected methods are
independent of one another in the same class. Truth be told, I usually
don't create protected methods at all any more, unless they are in some
sort of adapter class for a "un-handled use-case" or some such.
Back to comp.lang.java.programmer | Previous | Next — Previous in thread | Find similar
JNI generic type of jobject Philipp Kraus <philipp.kraus@flashpixx.de> - 2011-10-04 14:23 +0200
Re: JNI generic type of jobject Silvio <silvio@moc.com> - 2011-10-04 14:28 +0200
Re: JNI generic type of jobject Philipp Kraus <philipp.kraus@flashpixx.de> - 2011-10-04 14:49 +0200
Re: JNI generic type of jobject Daniel Pitts <newsgroup.nospam@virtualinfinity.net> - 2011-10-04 07:53 -0700
Re: JNI generic type of jobject Philipp Kraus <philipp.kraus@flashpixx.de> - 2011-10-04 18:01 +0200
Re: JNI generic type of jobject Lew <lewbloch@gmail.com> - 2011-10-04 12:01 -0700
Re: JNI generic type of jobject Daniel Pitts <newsgroup.nospam@virtualinfinity.net> - 2011-10-04 12:15 -0700
csiph-web