Na minha rede de contantos dentro de Tecnologia (Basicamente todo mundo estagiario/Junior), quem trabalha como Desenvolvedor de software Utiliza uma das duas linguagens. Na minha sala tem cerca de 50 pessoas dessas acredito que metade trabalha com dados portanto usa python. umas 15 pessoas devem trabalhar com desenvolvimento Backend/fullstack e todas elas utilizam ou java ou C#.


Portanto acredito que sim são mercado que absorvem iniciantes. Acho que vale deixar claro que trabalham em Instituições bancarias e bolsa de valores, onde existe bastante coisa legada dessas linguagens então não sei como fica a proporção para um mercado de startups por exemplo

Startup realmente é uma curiosidade saber o uso do C# haha

E sobre legado, eu acredito que para essas duas linguagens dificilmente a pessoa cai em projetos com as versões mais recentes. Por se tratarem de grandes sistemas na maioria das vezes.

As empresas deveriam fazer atualizações de pelo menos 3 em 3 anos nos sistemas para a versão mais atual da linguagem que usam, mas com certeza deve haver um bom motivo para não fazerem isso. Seja financeiro ou de tempo.

> *com certeza deve haver um bom motivo para não fazerem isso. Seja financeiro ou de tempo.* Geralmente é um pouco dos dois (afinal, "_tempo é dinheiro_" não é um clichê à toa). Um cenário bem comum: o sistema atual está em constante uso e evolução, com novas funcionalidades sendo adicionadas, bugs sendo corrigidos, etc. Para atualizar a versão, seja da linguagem, framework, o que for, vai precisar parar alguém pra testar, e se for o caso, adaptar o código. Afinal, nem sempre a versão nova é retro-compatível. Ou então tem alguma novidade que precisa mudar o código pra valer a pena a mudança. São raros os casos em que vc só troca a versão e tudo funciona magicamente (a não ser em projetos muito simples). Enquanto alguém trabalha nesta adaptação para a nova versão, em paralelo o sistema continua existindo, com atualizações, correções, etc (que também precisarão ser adaptadas para a nova versão, o que toma mais tempo, e nesse tempo mais coisas vão sendo alteradas na versão atual, que precisarão ser atualizadas, etc). --- Na prática, ou decidem que não vale a pena atualizar a versão, ou fazem algo gradual, migrando somente partes do sistema, aos poucos, até que um dia quem sabe tudo esteja atualizado (ou então convivem com o "híbrido"). Dependendo do tamanho do sistema e das condições da empresa, não tem como fazer isso "de 3 em 3 anos". Se o sistema for pequeno, pode até valer a pena reescrever. Mas pra sistemas grandes, é inviável. Afinal, sistemas bem grandes só ficam deste tamanho após anos, então refazer tudo não é trabalho de algumas semanas ou meses. Sem contar que reescrever um sistema - qualquer sistema - [não é nada trivial](https://www.joelonsoftware.com/2000/04/06/things-you-should-never-do-part-i/). Não é incomum as empresas só decidirem mudar de versão quando a atual perde o suporte, ou se torna tão obsoleta e ruim que não vale mais a pena manter (em outras palavras, quando começa a dar prejuízo, olha aí o fator financeiro de novo). Ou quando os ganhos da nova versão são tão grandes e superiores que vale o transtorno da fase de transição - e muitas vezes é uma análise subjetiva. São raros os casos em que a empresa "para tudo" pra focar o time todo na migração. E também tem casos em que tudo está ótimo na versão atual, mesmo que haja uma mais nova. Nem tudo precisa estar na tecnologia do ano. Eu, por exemplo, atualmente tenho projetos que estavam no Java 8 e recentemente resolveram atualizar para o 11 :-) Cada caso é um caso, e analisar o contexto é mais importante do que se deixar levar pelo *hype*.