henfredemars

joined 2 years ago
[–] henfredemars 8 points 2 years ago (1 children)

But it's Unix-like!

Uses a Linux VM for all the assignments anyway.

[–] henfredemars 4 points 2 years ago (1 children)

I swear there's at least one of these ladies in every restaurant I've attended in recent memory. Now I'm going to be imagining what their salad just told them.

[–] henfredemars 11 points 2 years ago

Somewhat, but it's just the "how's the weather?" of this community because most everyone is here from Reddit, so it's a starting point to me. I don't think Lemmy exists just to spite Reddit, and I participate in discussions having nothing to do with the subject.

[–] henfredemars 1 points 2 years ago

Lovely! They remind me of the vegan bean brownies my wife just made.

[–] henfredemars 7 points 2 years ago

QED, I think this response completely addresses my concerns. I often miss the social aspect of systems that involve people. I can't think of any further questions.

I reverse native binaries across a few different platforms for a living, but I'm just getting into Android. I will definitely take a look at those systems!

[–] henfredemars 4 points 2 years ago (1 children)

I have a love/hate relationship with desktop web apps on Linux. They are a great blessing in some ways because I get to run apps that just wouldn't be available to me otherwise because Linux typically isn't a priority for consumer-focused services. Often support exists as a convenient bonus because it came with the web app platform choice.

On the other hand, you get a web app, which looks nice (hopefully) but gobbles down your resources.

[–] henfredemars 31 points 2 years ago (3 children)

Underrated comment. I picked it because I had no idea what I was doing and it sounded all-encompassing and I wanted access to everything. I didn't even know what an instance was. I just picked it because it sounded like a good guess to get access to all of Lemmy.

[–] henfredemars 7 points 2 years ago

I'm seeing some very encouraging signs here. There's a lot of discussion about the platform itself on the platform (I'm looking at you Ham Radio nuts talking about talking on the radio...) but there's a fair chunk of people discussing links and topics of interest, the thing it needs most to survive. In other words, people are actually using it for its intended purpose and seeing some success in doing so.

The technical issues are actively being solved as the platform explodes in size practically overnight.

As for that ineffable quality of how the community feels? That has yet to be determined. The bots are on the way, and it's up to humans to choose how they will conduct themselves in the face of hostile bots and astroturfers who wish to sow discord.

[–] henfredemars 5 points 2 years ago (2 children)

Hello, and thank you for taking the time to compose this response.

I think that I may have conflated the choice of language with the choice of distribution. I believe the choice of language is independent of the choice to distribute apps as native or not, for at least Java because Java has solutions for AOT compilation not the least of which was actually used before in Android 5 according to another response, and it was used prior to Android 7 according to this resource.

For the sake of discussion, I propose that this existing AOT compiler for Android Java applications (used today in the hybrid solution) be run in its entirety on a server instead of on the user devices. I don't see a motivating reason to have the compiler on every user device to include a complex profile-guided optimization framework and hybrid JIT compiler (described in my third link in the original post) when we could ship the finished code and be done with it.

The benefit would be lower maintenance of the Android platform through a simpler design. (This benefit might shake out, but I get to that later.)

The migration process would consist of doing nothing for the typical app developer making this change quite cheap. The same languages would be supported as they are now. Indeed, this transition has already happened before and shows that this approach works, except with the build process happening on the device in earlier Android versions. I don't understand why Google did not go a step further and ship the binaries, instead choosing to take a step back and ship a JIT compiler with the AOT compiler. Why ship the intermediate bytecode representation and insist on a complex on-device build and optimization runtime?

From the responses that I have received so far, I think the true answer as to why distribution isn't native is likely composed of a combination of the following factors:

  • Android's heritage and if it ain't broke, don't fix it mindset (very respectable IMHO).
  • Android practically supports more platforms than arm64 even if not officially stated, such as Chromebooks and some x86 tablets. Shipping native would make this cross-arch support a lot more complicated.
  • Loose coupling between hardware and software platforms as a good design decision.
  • JIT performance can actually exceed AOT because more information is available at runtime.
  • Backwards compatibility is very important to Android, and the impacts of not shipping bytecode to these old versions could be profound or practically impossible depending on how far back we wish to consider.

I'm sure that I'm making further assumptions, and surely there are oddball apps out there that really depend on having dynamic optimization to be performant, but I suspect these apps are in the minority. At a glance, the current solution seems too complicated, but I think understanding the history of the platform and the selection of devices that are supported today mostly answers my original question. Briefly, arm64 is absolutely not the end of the story even if it's listed as the supported CPU architecture, and officially committing to just one now and forever could come home to roost.

[–] henfredemars 4 points 2 years ago

Thank you; I will definitely add this to my reading list.

[–] henfredemars 2 points 2 years ago (1 children)

Thank you for the insight, however, I think that my question is somewhat different because I'm interested in the implementation choice rather than the language choice. To answer your question, I don't think Android should switch to C/C++. Instead, I don't understand why Android goes to such great lengths to avoid compiling whatever language is in use in advance. Naively from the outside looking in it appears this would greatly simplify the platform.

For example, I think it would be an improvement to use Java but compile the whole thing to a native image in the cloud and distribute the compiled binaries. We already have Java AOT capabilities in Android, therefore this appears to be technically feasible. Only one ISA is targeted officially. It's not a great academic leap to think apps could be built off the phone instead to avoid the complex optimization problems.

I am ignoring Chromebooks a bit. I did not know that you could run Android apps on that platform and didn't think to consider it because I didn't see x86 listed on Wikipedia as an officially supported architecture.

[–] henfredemars 1 points 2 years ago

That's true! I forgot that Chromebooks were a major non-arm platform that Android supports in some sense. This is at least one way that they are benefiting from that design choice.

view more: ‹ prev next ›