Jump to content

Recommended Posts

Posted

For those that wanna implement Callbacks in java for better source control, or use bytecode manipulation for other ( evil ? ) purposes:

http://www.csg.is.titech.ac.jp/~chiba/javassist/tutorial/tutorial.html

 

For those that wanna learn code design and architecture to be able to make things like Phoenix-Engine easily:

http://www.javacamp.org/designPattern/

 

For those that wanna find or fix exploits in l2j based on race conditions and general thread synchronization issues:

http://www.javaworld.com/jw-10-1998/jw-10-toolbox.html

Posted

For those that wanna implement Callbacks in java for better source control, or use bytecode manipulation for other ( evil ? ) purposes:

http://www.csg.is.titech.ac.jp/~chiba/javassist/tutorial/tutorial.html

 

For those that wanna learn code design and architecture to be able to make things like Phoenix-Engine easily:

http://www.javacamp.org/designPattern/

 

callback is a highly not recommended thing to implement into l2j but anyway if someone wants to make web apps than its usefull... :)

Posted

callback is a highly not recommended thing to implement into l2j but anyway if someone wants to make web apps than its usefull... :)

 

If implemented correctly, they add absolutelly no overhead in the application. We are using them in our private svn and they work pretty well. Its a rework of the aionemu callback system, with the annotations removed. Saves you from applying 100 core patches and adds zero performance downgrade.

Posted

If implemented correctly, they add absolutelly no overhead in the application. We are using them in l2jsaver private svn and they work pretty well. Saves you from applying 100 core patches and adds zero performance downgrade.

 

Well it still creates a bunch of objects for nothing in many case(which increase the memory load), and on top of that it gives a really bad control over the source since you need to create an interface for most things separated.

 

The reason why people use callbacks are because they want an event notifier for web apps its not usefull for other things.

 

I know tho you picked to choose the callbacks from aion to the advice of a noob, but unless you want many many many small and useless objects for something that can be solved with a simple global task for example than you should not implement a callback. :)

Posted

We are probably talking about different things. I do not mean to hook interface lists inside functions in the source code and add objects that implement them. My callback system is based on javassist. It doesnt create any objects at all, it just applies the "patch" not in the source code, but on the bytecode when the JVM loads the class. For example.

 

public static void blabla()

{

 

System.out.println("hi1");

 

}

 

When the class containing that method gets loaded in the jvm, the jvm checks the javassist agent and if i have declared to do + testtest() inside blabla() , during class loading it manipulates and loads the following instead:

 

 

public static void blabla()

{

 

testtest();

System.out.println("hi1");

 

}

 

From then on, it juses the new class and voila, no extra objects, no extra memory, no extra cpu usage ;)

 

So the process of loading a class is :

 

New class requested ---> JVM gets the .class file in a byte[] array --> javassist agent transforms the class by patching --> ClassLoader loads the class and the application uses the patched one.

Posted

We are probably talking about different things. I do not mean to hook interface lists inside functions in the source code and add objects that implement them. My callback system is based on javassist. It doesnt create any objects at all, it just applies the "patch" not in the source code, but on the bytecode when the JVM loads the class. For example.

 

public static void blabla()

{

 

System.out.println("hi1");

 

}

 

When the class containing that method gets loaded in the jvm, the jvm checks the javassist agent and if i have declared to do + testtest() inside blabla() , during class loading it manipulates and loads the following instead:

 

 

public static void blabla()

{

 

testtest();

System.out.println("hi1");

 

}

 

From then on, it juses the new class and voila, no extra objects, no extra memory, no extra cpu usage ;)

 

 

But you know that a Java/Native call is in general 3 times slower than a Java/Java call right? :)

Posted

Its not a native call, why is it a native call ? o0 ? All it does is load a patched bytecode in the jvm. From then on JVM handles it like a normal class without knowing if its patched or not.

Posted

Its not a native call, why is it a native call ? o0 ? All it does is load a patched bytecode in the jvm.

 

Editing the byte code makes the code runs slower than if its in java and gets loaded into the jvm only without modifying.

 

This API allows you to read/write the bytecode on the fly which is not a good thing at all for l2j, not to mention its reflection based which is again a useless and really 1 of the worse ideas to ever use in l2j at high level. It makes understanding the code and coding harder and way more unfriendly.

 

There are high chance to get a really huge memory usage and even out of memory errors if the numbers of classes that needs to be loaded into the class pool even if the API try to reduce it.

 

it created instances "for ever" (imho until you replace the jar) so basically even if you use something rarely it leaves an instance there without allowing the garbage collector to get it since its blocked from it to keep the object for later usage.

 

The class loader of it is in general useless the current way of l2j is much better.

 

1 advantage i can say is you can modify the source on runtime but that can be done with other much better ways also(altho you would need a strong pc for it).

Posted
Editing the byte code makes the code runs slower than if its in java and gets loaded into the jvm only without modifying.

 

Where did you get that ? I tested two big loops of printing a string. One with the code in the class normally, the other way with an empty function that gets patched on runtime. The miliseconds that both loops took, to complete were approximatelly the same.

Posted

Where did you get that ?

 

Its a general fact a method call happens much faster if its a java/java call than if its a java from bytecode call ok thats not a real problem for you(i looked into other API not into what you use).

 

What i posted above at the reply 22 is what i found on your api so far.

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • wtf is your website lol ai slop
    • who have this files? or info about cached packets?
    • Hi maxcheaters, i am trying to bring back an old server ( L2Revenge) but with my own ideas, i only liked how it was and made the gameplay based on that just putting my own ideas.   So practicly is a PTS C6 with an extender that i work lately    Exp / SP is x45 adena is x200 and drops x5  so safe is +3 , max is unlimited and rate is 65% for both mage and fighter weapons I created a system that you can get on the levels the gear you need based on farm but for S grade theres a little farm to get some armor Tokens to unseal them. As you remember L2Revenge had olympiad / Tournament gear. So people abused them and had S grades that way just couldnt enchant them. So i made to be wearable only if u are nobless. That way i cancel this "exploit".  The server gives opportunity to solo and clans , epic gear ( epic weapons) or armors can be bought with raid tokens and you can craft them or get them with various ways Regarding Buffs: 24 buff slots no changes asked. Cov/Pony/Cat , siren - renewal - champion out of buffer , if u make the char as main roll u can use them or use the offline buffer system to sell them and get adenas. their time is 20 mins so that way we see again the " 1kk for rene/siren" or rec = song  Regarding armors: they are dropped ( parts ) from 3 only raids , rest lvl 76+ raids drop recipes , so crafting takes place (so if u are solo u can craft them )  there are 3 armors each armor have its purpose: Revenge Armors - Example for light ( its a glass cannon , high damage , less atk speed and less pdef ) - they mostly modify your base stats, so useable on sieges or off tank chars Titanium Armors - A little bit of balanced of all  Epic Armor - Daggers/Enchanters/Healers mostly but u can always combine your build    Regarding weapons: can be dropped from Monastery of Silence monsters or get them from NPC with Raid Tokens its like a 5% better than S grades and the S/A Activates at +4  Regarding retail gear: you need to unseal only S grades for a great amount of armor tokens all weapons on any grade need Soul crystals that are sold for adenas  stage 13 crystals are expensive or dropped from raids Regarding fun: There is a squash event a Fortress vs Fortress pvp event an RB Event at weekends and from Monday - Wednesday Tournament ( Olympiad is closed monday/tuesday/wednesday)  at tournament you can practice 1vs1 like olympiad but pots/ss allowed , gear allowed is only olympiad or tournament , each win of match gives u 5 glits at 100 glits u can be hero till restart Olympiad works the same way regarding gear allowance but works only thursday to friday and you win monthly hero Auction with Raid Tokens is activated Event medals from events can be exchanged for various items i try to make the oldschool with a little bit of new school systems Not planing to open it anytime soon as i still develop and make corrections to extender , looking forward to meet people that actually played this and are hyped to help on testing / development   P.S is c5 into interlude ( theres no akamanah / nor PI aswell , no lifestones) forgot to mention
    • Announcement – L2 Relic Server Opening Soon! We’re excited to share some great news! Our team has been working hard behind the scenes, and we’re nearly ready to launch our brand-new Lineage server this winter. The journey is just about to begin – so prepare yourselves! Gather your friends, sharpen your skills, and get ready to experience an epic adventure. Stay tuned for more details, updates, and the official beta-opening date. This winter, history will be written once again… are you ready?   Developed by https://dailyhost.eu/
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock