You are not logged in.
Hello,
I'm looking for a decent general alternative to Java.
I know Python is a great language, but is it still worth learning for like f.e. web development or is python more focussed on AI?
Or are there reasons for not using Python and maybe something else, like f.e. Golang?
Thx
Last edited by chrisdb (2019-04-28 19:31:37)
Failure is success in progress. 
A.E.
Offline

It depends on what you are trying to do. It would be easier for us to help you if you said why you are looking for a Java alternative.
Responsible Coder, Python Fan, Rust enthusiast
Offline
Python is great for processing and visualizing data in science and as a glue language. I suppose that is also how it became so dominant in AI research. But it is also a nice general purpose programming language. Web development also works, but perhaps JavaScript, TypeScript, PHP, etc. would be better for that.
Go is more for servers and other applications where a lot of parallel processing has to happen. It may be great for Google, but apart from that its popularity seems to be declining.
I would also learn C, at least the basics of it. It teaches you so much about how a computer really works at the hardware level and is still quite popular, e.g. the Linux kernel or embedded systems. It is also a very small language, so it will not take you months to learn. On the TIOBE index (https://www.tiobe.com/tiobe-index/) it ranks #2 behind Java and before Python, so that tells you something.
Offline
I just want to expand my knowledge by learning something different than Java and just want to be sure I don't invest in something which doesn't have a certain future.
I would also learn C, at least the basics of it. It teaches you so much about how a computer really works at the hardware level and is still quite popular, e.g. the Linux kernel or embedded systems.
I thought C wasn't recommended anymore in favour of c++
Failure is success in progress. 
A.E.
Offline
I thought C wasn't recommended anymore in favour of c++
20 years ago, C++ was supposed to take over and C was considered old hat. But in recent years, C has become very popular again, while C++ has lost mind share.
I think this is because there are many languages like C++ for writing GUI apps, while there is no real alternative to C for "twiddling bits". Arduino uses C which probably helped a lot too. Plus, C++ is huge compared to C; too much to keep in your head all at once. Finally, computers are so much faster today, so GUIs can be done in Python too without causing performance problems.
C++ is interesting with its templates and STL, but I think it is in the same category as Common Lisp now: intellectually stimulating to learn, but of limited practical use.
Offline
chrisdb wrote:I thought C wasn't recommended anymore in favour of c++
20 years ago, C++ was supposed to take over and C was considered old hat. But in recent years, C has become very popular again, while C++ has lost mind share.
I think this is because there are many languages like C++ for writing GUI apps, while there is no real alternative to C for "twiddling bits". Arduino uses C which probably helped a lot too. Plus, C++ is huge compared to C; too much to keep in your head all at once. Finally, computers are so much faster today, so GUIs can be done in Python too without causing performance problems.
C++ is interesting with its templates and STL, but I think it is in the same category as Common Lisp now: intellectually stimulating to learn, but of limited practical use.
Interesting...
So how would you go about using a rest server in C?
Are there any existing frameworks in C for this?
Last edited by chrisdb (2019-04-06 11:18:21)
Failure is success in progress. 
A.E.
Offline

So how would you go about using a rest server in C?
The same as you would in any other language. Connect to the appropriate server (using "connect") and read and write (using "read" and "write" ... and likely "select").
Are there any existing frameworks in C for this?
Probably. And they probably suck. But if you want to learn C, ditch the word "framework" and learn about a few useful libraries.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
chrisdb wrote:So how would you go about using a rest server in C?
The same as you would in any other language. Connect to the appropriate server (using "connect") and read and write (using "read" and "write" ... and likely "select").
chrisdb wrote:Are there any existing frameworks in C for this?
Probably. And they probably suck. But if you want to learn C, ditch the word "framework" and learn about a few useful libraries.
Ok I meant writing a REST service 
Failure is success in progress. 
A.E.
Offline

Ok, then replace 'connect' with 'bind' and 'listen'. All the same still applies.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline

If you don't want to start from scratch, there is e.g. libmicrohttpd to create embedded web servers. If you search on github, you'll probably find some projects that use it to implement a REST service or even a REST service library.
Edit: Hey. A language discussion thread without mentioning Rust as the future for web applications? Blasphemy! (that is sarcasm, btw) Seriously, it might not be a bad choice, though.
Last edited by progandy (2019-04-06 13:32:41)
| alias CUTF='LANG=en_XX.UTF-8@POSIX ' |
Offline

Perhaps this will highlight why I suggested ditching the word "framework". In language ecosystems with "frameworks" you often need to chose between different frameworks that combine dozens of libraries. So you can use the framework that is good at A and bad at B, or the other that is good at B but can't do A. Programmers who use "frameworks" are then often compelled to do everything that framework's way - often frameworks are more of a cult than a software tool.
In C, people generally talk about libraries, and the libraries you use are determined by your goals. If you need to listen on a internet socket, the standard libraries are more than sufficient with functions including socket, bind, listen, accept, read, write, etc. If you want to specifically interact with http/web clients, there are libraries that help out there as noted above. If you intent to exchange data between client and server in json, there are json parsing libraries available. If your server will need a database, there are libs for sqlite, mariadb, mongo, etc, etc, etc.
Frameworks are like kits for building model airplanes: you are given the parts and are expected to build exactly what that framework was intended to build. You may get to chose colors or some minor details, but that kit only builds one kind of thing. The various libraries available for languages like C is more comparable to legos: you pick and chose which legos you need to build what you want.
---
On another note, while I love C, if your goal is web application development, it may not be the most reasonable choice. C is great for web servers, and can certainly provide web "apps", but there are other languages more suited to the web app role. PHP is worth knowing, but python may really be the best choice for these goals. Sadly there you do get back into the world of "frameworks" like flask, bottle, cherrypy, etc. Some of these are quite good - but they are still a bit cultish in design.
Every language has it's strengths.  For example, java's strength is in allowing introductory programming classes to focus on topics of design and algorithms without the student actually learn to program in a language that they should ever use in the real world 
Last edited by Trilby (2019-04-06 13:31:04)
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
I am not sure if I would trust C for web applications, with its propensity for buffer overflows and all that. But then again you don't have to make every little programming experiment accessible to the whole Internet, so behind a firewall it might be fine.
Edit: Hey. A language discussion thread without mentioning Rust as the future for web applications? Blasphemy! (that is sarcasm, btw) Seriously, it might not be a bad choice, though.
The Rust hype and the Go hype seem to have gone to the same place, wherever that may be. /dev/null I guess. 
Offline

I am not sure if I would trust C for web applications, with its propensity for buffer overflows and all that.
That's not a propensity of the language, but of programmers who write in it without realizing it will do what it is told and nothing more when said programmers are used to languages / compilers that engage in far too much hand-holding.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline

That's not a propensity of the language, but of programmers who write in it without realizing it will do what it is told and nothing more when said programmers are used to languages / compilers that engage in far too much hand-holding.
Don't forget external effects like deadlines that may make you rush and forget validating your values here or there.
| alias CUTF='LANG=en_XX.UTF-8@POSIX ' |
Offline

Sure, but blaming that on the language is still not justified. Being absent minded with scissors can be quite dangerous, but I'd bet that few people here have only those kindergarten safety scissors in their homes - in fact, I'd bet few people have those style of scissors at all! Despite being pretty safe, they're not very useful.
Last edited by Trilby (2019-04-06 14:07:47)
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
Morn wrote:I am not sure if I would trust C for web applications, with its propensity for buffer overflows and all that.
That's not a propensity of the language, but of programmers who write in it without realizing it will do what it is told and nothing more when said programmers are used to languages / compilers that engage in far too much hand-holding.
Possibly, but I think when somebody comes from Java one should point out the pitfalls of manual memory management. C is wonderful if you can trust your input data. Which is not really the case for network applications in particular.
Even by 1960s/1970s programming standards, the idea in C that a string is simply a pointer into memory without a maximum length, just something you read from until you encounter a zero, was pretty silly. Literally the single bad design decision that launched a million buffer overflows.
Offline

That cannot cause a buffer overflow. Using a fixed region of memory and copying an unknown length of data into it can - this is just as true in any language as it is in C and it's really a bit of a strawman - a competant C programmer would not do this.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
On another note, while I love C, if your goal is web application development, it may not be the most reasonable choice. C is great for web servers, and can certainly provide web "apps", but there are other languages more suited to the web app role.
Trilby, I'm interested to know what your view is on C++?
Failure is success in progress. 
A.E.
Offline

Probably quite similar to Morn's, though he managed to state it quite tactfully. Every language has strengths and weaknesses, but frankly, C++ seems to consolidate the weakness of many with very few strengths.
If you want to be "close to the metal" and have more control (and responsibility) for every detail for systems programming, use C.  If you want a powerful language that still lets you have a higher level of abstraction with a good ecosystem of libs and frameworks for things like "app" development, use python.  If you want a language that will suck at all of these tasks, use C++ 
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline

Sure, but blaming that on the language is still not justified. Being absent minded with scissors can be quite dangerous, but I'd bet that few people here have only those kindergarten safety scissors in their homes - in fact, I'd bet few people have those style of scissors at all! Despite being pretty safe, they're not very useful.
Hey!
I've got a nice set that do either wavy, crinkly or straight. They're brilliant 
Offline
That's not a propensity of the language, but of programmers who write in it without realizing it will do what it is told and nothing more when said programmers are used to languages / compilers that engage in far too much hand-holding.
Sure, but blaming that on the language is still not justified. Being absent minded with scissors can be quite dangerous, but I'd bet that few people here have only those kindergarten safety scissors in their homes - in fact, I'd bet few people have those style of scissors at all! Despite being pretty safe, they're not very useful.
Are you a die-hard C fanatic? The presented view has been repeatedly debunked by showing that even experienced C programmers write vulnerable code. We are humans and we do make mistakes, especially in mundane and recurring tasks. Tools (including compilers, runtimes) that do the verification for us are a step in the right direction, and their performance overhead is being continuously minimized.
That cannot cause a buffer overflow. Using a fixed region of memory and copying an unknown length of data into it can - this is just as true in any language as it is in C and it's really a bit of a strawman - a competant C programmer would not do this.
True, a competent C programmer would not do this. At least today, because now everybody knows about these types of errors and security vulnerabilities they can introduce. In the distant past, maybe even some experienced C programmers knew about it. Still, by the presence of such functions (strcpy) in the standard library we can infer that (back then) experienced C programmers decided that it was good idea and it would be broadly useful (and you just said it isn't). Hell, the C standard library is full of things that today we would think of them as extremely stupid, e.g. localtime returning value in global buffer thus being thread unsafe. And I agree with Morn that null terminated strings was a sad and silly mistake.
Python is great for processing and visualizing data in science and as a glue language. I suppose that is also how it became so dominant in AI research. But it is also a nice general purpose programming language. Web development also works, but perhaps JavaScript, TypeScript, PHP, etc. would be better for that.
Python's dominance in AI is relatively recent (10 years?), I think scientists mostly used MATLAB, R etc. before (of course, I have no data to support that). And as far as I know, Python had some share of web development world shortly after the start of the century. JavaScript and PHP have some flaws (there must be some reason why people tend to joke about them...), I personally would state that Python is actually better for web development! I never understood why node.js would be beneficial besides using a huge JS workforce for backend. Don't know about TypeScript.
Offline

I'm convinced. Lets go rewrite the linux kernel and coreutils in Java.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline

I will say one thing of my adventures in C++, it helped me learn to write better C code through better use of structs  to provide some of the benefits that C++ provides in classes. 
Now, I tend to write most things that are speed critical in C, almost everything else in Python.  Java is reserved for Android programming.
Nothing is too wonderful to be true, if it be consistent with the laws of nature -- Michael Faraday
The shortest way to ruin a country is to give power to demagogues.— Dionysius of Halicarnassus
---
How to Ask Questions the Smart Way
Offline

I'm convinced. Lets go rewrite the linux kernel and coreutils in Java.
A weak argument to support a weak stance.
Nobody suggested to rewrite an entire kernel of millions of LOC in such an abstract language.
However it may not be a bad idea to consider migrating some certain parts of the kernel to Rust.
I remember a video, that can be found on YouTube labelled "The tragedy of systemd" in which the speaker also mentions the common problems with C on a side note.
Inofficial first vice president of the Rust Evangelism Strike Force
Offline

I don't believe in the "one glove fits all" approach. Use the right tools for the right job. Some of my preferences:
Web: Node.js, ASP.NET Core, Go
Cross-platform UI: QT (C++)
Scripting: TypeScript, Bash, Python
Kernel, drivers, console apps, integrated devices: C
Mobile apps: Java, Swift
ML, science: Python
Last edited by karabaja4 (2019-04-08 09:05:18)
Offline