Whitepaper de TRON
Introduction
1.1 Vision
TRON est un projet ambitieux dédié à la mise en place d'un Internet véritablement décentralisé et à ses
infrastructures. Le protocole TRON, l'un des plus grands systèmes d'exploitation basés sur blockchain au monde.
monde, offre une prise en charge publique blockchain d'un débit élevé, d'une évolutivité élevée et d'une haute disponibilité pour
toutes les applications décentralisées (DApps) de l'écosystème TRON. L'acquisition en juillet 2018 de
BitTorrent a encore consolidé le leadership de TRON dans la poursuite d'un écosystème décentralisé.
1.2 Contexte
L’introduction du Bitcoin en 2009 a révolutionné la perception qu’avait la société du secteur financier traditionnel. système à la suite de la Grande Récession (2007-2008). Comme les hedge funds centralisés et les banques effondré à cause de la spéculation sur des dérivés financiers opaques, la technologie blockchain a fourni un grand livre universel transparent à partir duquel chacun pourrait glaner des informations sur les transactions. Le les transactions ont été sécurisées cryptographiquement à l'aide d'un mécanisme de consensus Proof of Work (PoW), évitant ainsi les problèmes de double dépense.
Fin 2013, le livre blanc Ethereum proposait un réseau dans lequel des smart contract et un La machine virtuelle Turing-complete Ethereum (EVM) permettrait aux développeurs d'interagir avec le réseau via DApps. Cependant, alors que les volumes de transactions en Bitcoin et Ethereum ont culminé en 2017, il ressortait des faibles délais de traitement des transactions et des frais de transaction élevés que les crypto-monnaies comme Bitcoin et Ethereum dans leur état actuel n'étaient pas évolutives pour une utilisation généralisée. adoption. Ainsi, TRON a été fondée et envisagée comme une solution innovante à ces problèmes urgents. défis d’évolutivité.

1.3 Historique Le TRON DAO a été créé en juillet 2017 à Singapour. En décembre 2017, TRON avait a lancé son protocole open source. Le Testnet, Blockchain Explorer et Web Wallet étaient tous lancé en mars 2018. TRON Mainnet a été lancé peu de temps après en mai 2018, marquant le Sortie d'Odyssey 2.0 comme étape technique. En juin 2018, TRON a déclaré son indépendance avec la création du bloc Genesis, ainsi que l'acquisition de BitTorrent en juillet 2018. Dans En octobre 2018, TRON a lancé la machine virtuelle TRON (TVM), un ensemble complet d'outils pour les développeurs, et système de support 360. La feuille de route TRON consiste à combiner les 100 millions d’utilisateurs de BitTorrent avec le réseau TRON via Project Atlas, ainsi qu'en encourageant la communauté des développeurs à lancer de nouvelles DApp passionnantes sur le réseau TRON1. 1 V1.0 est disponible à https://tron.network/static/doc/white_paper_v_1_0.pdf
1.4 Terminologie
Adresse/portefeuille Une adresse ou un portefeuille composé d'identifiants de compte sur le réseau TRON est généré par un paire de clés, composée d'une clé privée et d'une clé publique, cette dernière étant dérivée de la première grâce à un algorithme. La clé publique est généralement utilisée pour le chiffrement de la clé de session, la signature vérification et cryptage des données qui pourraient être déchiffrées par une clé privée correspondante.
IBI Une interface binaire d'application (ABI) est une interface entre deux modules de programme binaires ; habituellement l'un de ces modules est une bibliothèque ou une fonctionnalité du système d'exploitation, et l'autre est un module exécuté par l'utilisateur. programme.
API Une interface de programmation d'application (API) est principalement utilisée pour le développement des clients utilisateurs. Avec API support, les plateformes d'émission token peuvent également être conçues par les développeurs eux-mêmes.
Actif Dans les documents de TRON, l'actif est le même que token, qui est également désigné par TRC-10 token.
Points de bande passante (BP) Pour assurer le bon fonctionnement du réseau, les transactions du réseau TRON utilisent BP comme carburant. Chaque compte obtient 5 000 BP quotidiens gratuits et davantage peut être obtenu en gelant TRX pour BP. TRX et TRC-10 Les transferts token sont des transactions normales coûtant à BP. Déploiement et exécution de contrats intelligents les transactions consomment à la fois du BP et de l’énergie.
Bloquer Les blocs contiennent les enregistrements numériques des transactions. Un bloc complet est constitué du nombre magique, taille de bloc, en-tête de bloc, compteur de transactions et données de transaction.
Bloquer la récompense Les récompenses de production de blocs sont envoyées sur un sous-compte (adresse/portefeuille). Les super représentants peuvent réclamez leurs récompenses sur Tronscan ou directement via l'API.
En-tête de bloc Un en-tête de bloc fait partie d'un bloc. Les en-têtes de bloc TRON contiennent le hash du bloc précédent, le Racine Merkle, horodatage, version et adresse du témoin.Portefeuille froid Le portefeuille froid, également appelé portefeuille hors ligne, maintient la clé privée complètement déconnectée de tout réseau. Les portefeuilles froids sont généralement installés sur des appareils « froids » (par exemple des ordinateurs ou des téléphones portables). rester hors ligne) pour assurer la sécurité de la clé privée TRX.
DApp Une application décentralisée est une application qui fonctionne sans partie de confiance centrale. Une candidature qui permet une interaction/des accords/une communication directe entre les utilisateurs finaux et/ou les ressources sans intermédiaire.
gRPC gRPC (gRPC Remote Procedure Calls) est un système d'appel de procédure à distance (RPC) open source 2 initialement développé chez Google. Il utilise HTTP/2 pour le transport, Protocol Buffers comme interface langage de description et fournit des fonctionnalités telles que l'authentification, le streaming bidirectionnel et le flux contrôle, liaisons bloquantes ou non bloquantes, annulation et délais d'attente. Il génère liaisons client et serveur multiplateformes pour de nombreuses langues. Scénarios d'utilisation les plus courants inclure des services de connexion dans une architecture de style microservices et la connexion d'appareils mobiles, et clients de navigateur vers les services backend.
Portefeuille chaud Le portefeuille chaud, également connu sous le nom de portefeuille en ligne, permet d'utiliser la clé privée de l'utilisateur en ligne. sensibles aux vulnérabilités potentielles ou à l’interception par des acteurs malveillants.
JDK Java Development Kit est le SDK Java utilisé pour les applications Java. C'est le cœur de Java développement, comprenant l'environnement d'application Java (bibliothèque de classes JVM+Java) et Java outils.
KhaosDB TRON a une KhaosDB dans la mémoire complète du nœud qui peut stocker toutes les chaînes nouvellement créées générées dans un certain laps de temps et aide les témoins à quitter rapidement leur propre chaîne active dans une nouvelle chaîne principale. Voir 2.2.2 Stockage d'état pour plus de détails.
NiveauDB LevelDB a été initialement adopté dans le but principal de répondre aux exigences de R/W rapide et de développement. Après avoir lancé le Mainnet, TRON a mis à niveau sa base de données vers une base de données entièrement personnalisée on répondait à ses propres besoins. Voir 2.2.1 Stockage Blockchain pour plus de détails.
Racine de Merkle Une racine Merkle est le hash de tous les hash de toutes les transactions incluses dans le cadre d'un bloc dans un blockchain. réseau. Voir 3.1 Preuve de participation déléguée (DPoS) pour plus de détails. 2 https://en.wikipedia.org/wiki/GRPC

Réseau de test public (Shasta) Une version du réseau fonctionnant dans une configuration à nœud unique. Les développeurs peuvent se connecter et tester fonctionnalités sans se soucier de la perte économique. Les token Testnet n'ont aucune valeur et tout le monde peut demandez plus au robinet public.
RPC
3
En informatique distribuée, un appel de procédure à distance (RPC) se produit lorsqu'un programme informatique provoque un
procédure (sous-programme) à exécuter dans un espace d’adressage différent (généralement sur un autre ordinateur sur
un réseau partagé), qui est codé comme s'il s'agissait d'un appel de procédure normal (local), sans le
programmeur codant explicitement les détails de l’interaction à distance.
Évolutivité L'évolutivité est une fonctionnalité du protocole TRON. C'est la capacité d'un système, d'un réseau ou d'un processus à gérer une quantité croissante de travail ou son potentiel d’être élargi pour s’adapter à cette croissance.
SOLEIL SUN a remplacé drop en tant que plus petite unité de TRX. 1 TRX = 1 000 000 SOLEIL.
Débit Le débit élevé est une fonctionnalité du réseau principal TRON. Il est mesuré en transactions par seconde (TPS), à savoir la capacité maximale de transaction en une seconde.
Horodatage L'heure approximative de production du bloc est enregistrée sous forme d'horodatage Unix, qui correspond au nombre de millisecondes écoulées depuis 00:00:00 le 1er janvier 1970 UTC.
CTK Configuration du jeton.
TRC-10 Un standard de crypto token sur la plateforme TRON. Certaines règles et interfaces doivent être respectées lors de la détention d'une offre initiale de pièces le TRON blockchain.
TRX TRX signifie Tronix, qui est la crypto-monnaie officielle de TRON.
3 https://en.wikipedia.org/wiki/Remote_procedure_call
Introdução
1.1 Visão
TRON é um projeto ambicioso dedicado ao estabelecimento de uma Internet verdadeiramente descentralizada e sua
infraestrutura. O protocolo TRON, um dos maiores sistemas operacionais baseados em blockchain do
mundo, oferece suporte público blockchain de alto rendimento, alta escalabilidade e alta disponibilidade para
todos os aplicativos descentralizados (DApps) no ecossistema TRON. A aquisição de julho de 2018 da
O BitTorrent consolidou ainda mais a liderança de TRON na busca de um ecossistema descentralizado.
1.2 Antecedentes
A introdução de Bitcoin em 2009 revolucionou a percepção da sociedade sobre o mercado financeiro tradicional sistema na sequência da Grande Recessão (2007-2008). Como fundos de hedge e bancos centralizados entrou em colapso devido à especulação em derivativos financeiros opacos, a tecnologia blockchain forneceu um livro razão universal transparente do qual qualquer pessoa poderia obter informações sobre transações. O as transações foram protegidas criptograficamente usando um mecanismo de consenso de Prova de Trabalho (PoW), evitando assim problemas de gastos duplos.
No final de 2013, o white paper Ethereum propôs uma rede na qual smart contracts e um A Máquina Virtual Turing-complete Ethereum (EVM) permitiria aos desenvolvedores interagir com o rede através de DApps. No entanto, como os volumes de transações em Bitcoin e Ethereum atingiram o pico em 2017, ficou evidente pelos baixos tempos de processamento das transações e pelas altas taxas de transação que criptomoedas como Bitcoin e Ethereum em seu estado existente não eram escaláveis para uso generalizado adoção. Assim, TRON foi fundado e idealizado como uma solução inovadora para essas questões urgentes. desafios de escalabilidade.

1.3 História O TRON DAO foi estabelecido em julho de 2017 em Cingapura. Em dezembro de 2017, TRON tinha lançou seu protocolo de código aberto. O Testnet, Blockchain Explorer e Web Wallet foram todos lançada em março de 2018. TRON Mainnet foi lançada logo depois, em maio de 2018, marcando o Lançamento do Odyssey 2.0 como um marco técnico. Em junho de 2018, TRON declarou sua independência com a criação do bloco Genesis, juntamente com a aquisição do BitTorrent em julho de 2018. Em Outubro de 2018, TRON lançou a TRON Máquina Virtual (TVM), um conjunto completo de ferramentas para desenvolvedores, e sistema de suporte 360. O roteiro TRON envolve combinar os 100 milhões de usuários do BitTorrent com a rede TRON por meio do Project Atlas, além de incentivar a comunidade de desenvolvedores a lançar novos e emocionantes DApps na rede TRON1. 1 V1.0 está disponível em https://tron.network/static/doc/white_paper_v_1_0.pdf
1.4 Terminologia
Endereço/carteira Um endereço ou carteira que consiste em credenciais de conta na rede TRON é gerado por um par de chaves, que consiste em uma chave privada e uma chave pública, sendo esta última derivada da primeira através de um algoritmo. A chave pública é geralmente usada para criptografia de chave de sessão, assinatura verificação e criptografia de dados que poderiam ser descriptografados por uma chave privada correspondente.
ABI Uma interface binária de aplicativo (ABI) é uma interface entre dois módulos de programa binário; normalmente um desses módulos é uma biblioteca ou recurso do sistema operacional e o outro é uma execução do usuário programa.
API Uma interface de programação de aplicativos (API) é usada principalmente para desenvolvimento de clientes de usuários. Com API suporte, plataformas de emissão token também podem ser projetadas pelos próprios desenvolvedores.
Ativo Nos documentos de TRON, o ativo é igual a token, que também é indicado como TRC-10 token.
Pontos de largura de banda (BP) Para manter a rede operando sem problemas, as transações da rede TRON usam a BP como combustível. Cada conta recebe 5.000 BP diários gratuitos e mais podem ser obtidos congelando TRX para BP. TRX e TRC-10 token transferências são transações normais que custam BP. Implantação e execução de contratos inteligentes as transações consomem tanto BP quanto Energia.
Bloquear Os blocos contêm os registros digitais das transações. Um bloco completo consiste no número mágico, tamanho do bloco, cabeçalho do bloco, contador de transações e dados de transação.
Recompensa de bloco As recompensas de produção de blocos são enviadas para uma subconta (endereço/carteira). Superrepresentantes podem reivindicar suas recompensas no Tronscan ou diretamente através da API.
Cabeçalho do bloco Um cabeçalho de bloco faz parte de um bloco. Os cabeçalhos dos blocos TRON contêm o hash do bloco anterior, o Raiz Merkle, carimbo de data/hora, versão e endereço da testemunha.Carteira Fria A carteira fria, também conhecida como carteira offline, mantém a chave privada completamente desconectada de qualquer rede. As carteiras frias são geralmente instaladas em dispositivos "frios" (por exemplo, computadores ou telefones celulares). permanecer offline) para garantir a segurança da chave privada TRX.
DApp Aplicativo descentralizado é um aplicativo que opera sem uma parte centralmente confiável. Um aplicativo que permite interação/acordos/comunicação direta entre usuários finais e/ou recursos sem intermediário.
gRPC gRPC (gRPC Remote Procedure Calls) é um sistema de chamada de procedimento remoto (RPC) de código aberto 2 inicialmente desenvolvido no Google. Ele usa HTTP/2 para transporte, buffers de protocolo como interface linguagem de descrição e fornece recursos como autenticação, streaming bidirecional e fluxo controle, ligações bloqueadoras ou não bloqueadoras e cancelamento e tempos limite. Ele gera ligações de cliente e servidor de plataforma cruzada para vários idiomas. Cenários de uso mais comuns incluem a conexão de serviços em arquitetura estilo microsserviços e a conexão de dispositivos móveis, e clientes de navegador para serviços de back-end.
Carteira quente A carteira quente, também conhecida como carteira online, permite que a chave privada do usuário seja usada online, podendo assim ser suscetível a vulnerabilidades potenciais ou interceptação por atores mal-intencionados.
JDK Java Development Kit é o Java SDK usado para aplicativos Java. É o núcleo do Java desenvolvimento, compreendendo o ambiente de aplicação Java (biblioteca de classes JVM + Java) e Java ferramentas.
KhaosDB TRON possui um KhaosDB na memória do nó completo que pode armazenar todas as cadeias recém-bifurcadas geradas dentro de um determinado período de tempo e ajuda as testemunhas a mudar rapidamente de sua própria cadeia ativa em uma nova cadeia principal. Consulte 2.2.2 Armazenamento de estado para obter mais detalhes.
NívelDB O LevelDB foi inicialmente adotado com o objetivo principal de atender aos requisitos de R/W rápido e rápido desenvolvimento. Após lançar a Mainnet, TRON atualizou seu banco de dados para um totalmente customizado um atendia às suas próprias necessidades. Consulte 2.2.1 Armazenamento Blockchain para obter mais detalhes.
Raiz Merkel Uma raiz Merkle é o hash de todos os hashes de todas as transações incluídas como parte de um bloco em um blockchain rede. Consulte 3.1 Prova de participação delegada (DPoS) para obter mais detalhes. 2 https://en.wikipedia.org/wiki/GRPC

Rede de teste pública (Shasta) Uma versão da rede executada em uma configuração de nó único. Os desenvolvedores podem se conectar e testar recursos sem se preocupar com a perda econômica. Testnet tokens não têm valor e qualquer um pode solicite mais da torneira pública.
RPC
3
Na computação distribuída, uma chamada de procedimento remoto (RPC) ocorre quando um programa de computador causa um
procedimento (sub-rotina) para ser executado em um espaço de endereço diferente (geralmente em outro computador em
uma rede compartilhada), que é codificada como se fosse uma chamada de procedimento normal (local), sem o
programador codificando explicitamente os detalhes da interação remota.
Escalabilidade A escalabilidade é um recurso do protocolo TRON. É a capacidade de um sistema, rede ou processo de lidar com uma quantidade crescente de trabalho ou seu potencial será ampliado para acomodar esse crescimento.
SOL SUN substituiu drop como a menor unidade de TRX. 1 TRX = 1.000.000 SOL.
Taxa de transferência Alto rendimento é um recurso da TRON Mainnet. É medido em transações por segundo (TPS), ou seja, a capacidade máxima de transação em um segundo.
Carimbo de data e hora O tempo aproximado de produção do bloco é registrado como timestamp Unix, que é o número de milissegundos decorridos desde 00:00:00 de 01 de janeiro de 1970 UTC.
TKC Configuração de token.
TRC-10 Um padrão de criptografia token na plataforma TRON. Certas regras e interfaces devem ser seguidas ao realizar uma oferta inicial de moedas em TRON blockchain.
TRX TRX significa Tronix, que é a criptomoeda oficial de TRON.
3 https://en.wikipedia.org/wiki/Remote_procedure_call
Architecture
TRON adopte une architecture à 3 couches divisée en couche de stockage, couche principale et couche d'application. Le protocole TRON adhère à Google Protobuf, qui prend intrinsèquement en charge le multilingue prolongation.

Figure 1 : TRON Architecture à 3 couches
2.1 Noyau
Il existe plusieurs modules dans la couche principale, notamment smart contracts, la gestion des comptes et consensus. Une machine virtuelle basée sur une pile est implémentée sur TRON et une instruction optimisée l’ensemble est utilisé. Afin de mieux accompagner les développeurs DApp, Solidity a été choisi comme smart contract 4 langue, suivie par la prise en charge future d'autres langues avancées. De plus, le consensus de TRON Le mécanisme est basé sur la preuve de participation déléguée (DPoS) et de nombreuses innovations ont été apportées en afin de répondre à ses exigences uniques. 2.2 Stockage
TRON a conçu un protocole de stockage distribué unique composé de stockage par blocs et d'état Stockage. La notion de base de données graphes a été introduite dans la conception de la couche de stockage pour mieux répondre au besoin de stockage de données diversifié dans le monde réel. 2.2.1 Stockage blockchain
TRON blockchain Storage choisit d'utiliser LevelDB, développé par Google et éprouvé avec succès auprès de nombreuses entreprises et projets. Il a des performances élevées et prend en charge les octets arbitraires tableaux comme clés et valeurs, obtention, mise et suppression singulières, mise et suppression par lots, bidirectionnel itérateurs et compression simple utilisant l'algorithme Snappy très rapide. 2.2.2 Stockage d'état
TRON a une KhaosDB dans la mémoire complète du nœud qui peut stocker toutes les chaînes nouvellement fourchues générées dans un certain laps de temps et aide les témoins à quitter rapidement leur propre chaîne active dans une nouvelle chaîne principale. Il peut également protéger le stockage blockchain en le rendant plus stable contre les se terminant anormalement dans un état intermédiaire. 2.3 Demande
Les développeurs peuvent créer une gamme diversifiée de DApps et de portefeuilles personnalisés sur TRON. Depuis TRON permet aux smart contract d'être déployés et exécutés, les opportunités des applications utilitaires sont illimité. 4 Documentation officielle Solidité : https://solidity.readthedocs.io/
2.4 Protocole
Le protocole TRON adhère à Google Protocol Buffers , qui est neutre en termes de langage, de plate-forme, 5 et extensible de sérialiser des données structurées pour une utilisation dans les protocoles de communication, le stockage de données, et plus encore. 2.4.1 Tampons de protocole
Protocol Buffers (Protobuf) est un mécanisme flexible, efficace et automatisé pour la sérialisation structurée données, similaires à JSON ou XML, mais beaucoup plus petites, plus rapides et plus simples.
Les définitions Protobuf (.proto) peuvent être utilisées pour générer du code pour C++, Java, C#, Python, Ruby, Golang et Objective-C via les générateurs de code officiels. Divers tiers des implémentations sont également disponibles pour de nombreux autres langages. Protobuf facilite le développement de clients en unifiant les définitions des API et en optimisant également les transferts de données. Les clients peuvent utiliser l'API .proto du référentiel de protocoles de TRON et intégré via le code généré automatiquement bibliothèques.
À titre de comparaison, les tampons de protocole sont 3 à 10 fois plus petits et 20 à 100 fois plus rapides que XML, avec une syntaxe moins ambiguë. Protobuf génère des classes d'accès aux données plus faciles à utiliser par programmation. 2.4.2 HTTP
Le protocole TRON fournit une alternative à l'API HTTP RESTful à l'API Protobuf. Ils partagent la même chose interface mais l'API HTTP peut être facilement utilisée dans les clients javascript. 2.5 TRON Machine virtuelle (TVM)
Le TVM est une machine virtuelle complète et légère de Turing développée pour l'écosystème de TRON. Le
TVM se connecte de manière transparente à l'écosystème de développement existant pour fournir des millions de
développeurs avec un système blockchain personnalisé qui est efficace, pratique, stable, sécurisé et
évolutif.
2.6 Échange décentralisé (DEX)
5 Documentation officielle des tampons de protocole Google : https://developers.google.com/protocol-buffers/Le réseau TRON supporte nativement les fonctions d'échange décentralisées. Un échange décentralisé se compose de plusieurs paires de trading. Une paire de trading (notation « Exchange ») est un marché d'échange entre des TRC-10 token, ou entre un TRC-10 token et un TRX. N'importe quel compte peut créer un trading paire entre n’importe quel token, même si la même paire existe déjà sur le réseau TRON. Commerce et les fluctuations de prix des paires de trading suivent le protocole Bancor. Le réseau TRON stipule que 6 les poids des deux token dans toutes les paires de trading sont égaux, donc le rapport de leurs soldes est le prix entre eux. Par exemple, considérons une paire de trading contenant deux token, ABC et DEF. ABC a un solde de 10 millions et DEF a un solde de 1 million. Puisque leurs poids sont égaux, 10 ABC = 1 DÉF. Cela signifie que le rapport ABC/DEF est de 10 ABC par DEF. 2.7 Mise en œuvre
Le code TRON blockchain est implémenté en Java et était à l'origine un fork de EthereumJ.
6 Site officiel du Protocole Bancor : https://about.bancor.network/protocol/
Arquitetura
TRON adota uma arquitetura de 3 camadas dividida em camada de armazenamento, camada central e camada de aplicativo. O protocolo TRON segue o Google Protobuf, que oferece suporte intrínseco a vários idiomas extensão.

Figura 1: TRON Arquitetura de 3 camadas
2.1 Núcleo
Existem vários módulos na camada principal, incluindo smart contracts, gerenciamento de contas e consenso. Uma máquina virtual baseada em pilha é implementada em TRON e uma instrução otimizada conjunto é usado. Para melhor oferecer suporte aos desenvolvedores de DApp, Solidity foi escolhido como smart contract 4 idioma, seguido de suporte futuro para outros idiomas avançados. Além disso, o consenso de TRON mecanismo é baseado em Prova de Participação Delegada (DPoS) e muitas inovações foram feitas em para atender aos seus requisitos exclusivos. 2.2 Armazenamento
TRON projetou um protocolo exclusivo de armazenamento distribuído que consiste em Block Storage e State Armazenamento. A noção de banco de dados gráfico foi introduzida no design da camada de armazenamento para atender melhor à necessidade de armazenamento diversificado de dados no mundo real. 2.2.1 Armazenamento Blockchain
TRON blockchain armazenamento opta por usar LevelDB, que é desenvolvido pelo Google e comprovado sucesso com muitas empresas e projetos. Possui alto desempenho e suporta bytes arbitrários matrizes como chaves e valores, obtenção, colocação e exclusão singular, colocação e exclusão em lote, bidirecional iteradores e compactação simples usando o algoritmo Snappy muito rápido. 2.2.2 Armazenamento de Estado
TRON possui um KhaosDB na memória do nó completo que pode armazenar todas as cadeias recém-bifurcadas geradas dentro de um determinado período de tempo e ajuda as testemunhas a mudar rapidamente de sua própria cadeia ativa em uma nova cadeia principal. Ele também pode proteger o armazenamento blockchain, tornando-o mais estável contra terminando anormalmente em um estado intermediário. 2.3 Aplicação
Os desenvolvedores podem criar uma grande variedade de DApps e carteiras personalizadas em TRON. Desde TRON permite que smart contracts sejam implantados e executados, as oportunidades de aplicativos utilitários são ilimitado. 4 Documentação oficial do Solidity: https://solidity.readthedocs.io/
2.4 Protocolo
O protocolo TRON adere aos Google Protocol Buffers , que é um protocolo neutro em termos de linguagem, plataforma e 5 e extensível de serializar dados estruturados para uso em protocolos de comunicação, armazenamento de dados, e muito mais. 2.4.1 Buffers de Protocolo
Protocol Buffers (Protobuf) é um mecanismo flexível, eficiente e automatizado para serializar dados estruturados. dados, semelhantes a JSON ou XML, mas muito menores, mais rápidos e mais simples.
As definições de protobuf (.proto) podem ser usadas para gerar código para C++, Java, C#, Python, Ruby, Linguagens Golang e Objective-C por meio dos geradores de código oficiais. Vários terceiros implementações também estão disponíveis para muitos outros idiomas. Protobuf facilita o desenvolvimento para clientes unificando as definições da API e também otimizando as transferências de dados. Os clientes podem usar a API .proto do repositório de protocolo de TRON e integrado por meio do código gerado automaticamente bibliotecas.
Como comparação, os buffers de protocolo são de 3 a 10 vezes menores e de 20 a 100 vezes mais rápidos que o XML, com sintaxe menos ambígua. Protobuf gera classes de acesso a dados mais fáceis de usar programaticamente. 2.4.2HTTP
TRON O protocolo fornece uma API RESTful HTTP alternativa à API Protobuf. Eles compartilham o mesmo interface, mas a API HTTP pode ser facilmente usada em clientes javascript. 2.5 TRON Máquina Virtual (TVM)
O TVM é uma máquina virtual Turing completa e leve desenvolvida para o ecossistema de TRON. O
A TVM se conecta perfeitamente com o ecossistema de desenvolvimento existente para fornecer milhões de recursos globais
desenvolvedores com um sistema blockchain personalizado que é eficiente, conveniente, estável, seguro e
escalável.
2.6 Exchange Descentralizada (DEX)
5 Documentação oficial dos buffers de protocolo do Google: https://developers.google.com/protocol-buffers/A rede TRON oferece suporte nativo a funções de exchange descentralizadas. Uma exchange descentralizada consiste em vários pares de negociação. Um par de negociação (notação “Exchange”) é um mercado de câmbio entre TRC-10 tokens, ou entre um TRC-10 token e TRX. Qualquer conta pode criar uma negociação par entre quaisquer tokens, mesmo que o mesmo par já exista na rede TRON. Negociação e as flutuações de preços dos pares de negociação seguem o Protocolo Bancor. A rede TRON estipula que 6 os pesos dos dois tokens em todos os pares de negociação são iguais, então a proporção de seus saldos é o preço entre eles. Por exemplo, considere um par comercial contendo dois tokens, ABC e DEF. ABC tem um saldo de 10 milhões e o DEF tem um saldo de 1 milhão. Como seus pesos são iguais, 10 ABC = 1 DEF. Isso significa que a proporção de ABC para DEF é de 10 ABC por DEF. 2.7 Implementação
O código TRON blockchain é implementado em Java e era originalmente uma bifurcação de EthereumJ.
6 Site oficial do Protocolo Bancor: https://about.bancor.network/protocol/
Consensus
3.1 Preuve de participation déléguée (DPoS)
Le mécanisme de consensus le plus ancien est le mécanisme de consensus Proof of Work (PoW). Ceci Le protocole est actuellement implémenté dans Bitcoin et Ethereum . Dans les systèmes PoW, les transactions 7 8 diffusés à travers le réseau sont regroupés en blocs naissants pour confirmation par le mineur. Le Le processus de confirmation implique de hashing transactions à l'aide d'algorithmes cryptographiques hashing jusqu'à ce qu'un La racine Merkle a été atteinte, créant un arbre Merkle :
Figure 2 : 8 transactions TRX sont hashed dans la racine merkle. Cette racine merkle est ensuite incluse dans l'en-tête du bloc, qui est attaché aux blocs précédemment confirmés pour former un blockchain. Cela permet un suivi facile et transparent de transactions, horodatages et autres informations connexes.
7 Livre blanc Bitcoin : https://bitcoin.org/bitcoin.pdf 8 Livre blanc Ethereum : https://github.com/ethereum/wiki/wiki/White-Paper
Les algorithmes cryptographiques hashing sont utiles dans la prévention des attaques réseau car ils possèdent
plusieurs propriétés :
9
●
Taille de la longueur d'entrée/sortie - L'algorithme peut transmettre une entrée de n'importe quelle longueur, et
génère une valeur hash de longueur fixe.
●
Efficacité - L'algorithme est relativement simple et rapide à calculer.
●
Résistance de préimage - Pour une sortie z donnée, il est impossible de trouver une entrée x telle que
h(x) = z. En d’autres termes, l’algorithme hashing h(x) est une fonction unidirectionnelle dans laquelle seul le
la sortie peut être trouvée, étant donné une entrée. L’inverse n’est pas possible.
●
Résistance aux collisions - Il est informatiquement impossible de trouver des paires x1 ≠ x2 telles que h(x1)
= h(x2). En d’autres termes, la probabilité de trouver deux entrées différentes hash au même
le rendement est extrêmement faible. Cette propriété implique également une résistance à la seconde préimage.
●
Résistance de la deuxième pré-image - Étant donné x1, et donc h(x1), il est informatiquement impossible de
trouver n'importe quel x2 tel que h(x1) = h(x2). Bien que cette propriété soit similaire à la résistance aux collisions, la
la propriété diffère en ce sens qu'elle signifie qu'un attaquant avec un x1 donné le trouvera par calcul
impossible de trouver un x2 hash sur la même sortie.
●
Déterministe - mappe chaque entrée sur une et une seule sortie.
●
Effet Avalanche - un petit changement dans l'entrée entraîne une sortie entièrement différente.
Ces propriétés confèrent au réseau de crypto-monnaie sa valeur intrinsèque en garantissant que les attaques ne compromettre le réseau. Lorsque les mineurs confirment un blocage, ils sont récompensés par des token sous forme de récompense intégrée. incitation à la participation au réseau. Cependant, comme la capitalisation boursière mondiale des cryptomonnaies En constante augmentation, les mineurs se sont centralisés et ont concentré leurs ressources informatiques sur thésauriser les token en tant qu'actifs, plutôt qu'à des fins de participation au réseau. Les mineurs de CPU ont cédé la place à Les GPU, qui à leur tour ont cédé la place aux puissants ASIC. Dans une étude notable, la puissance totale la consommation de l’exploitation minière Bitcoin a été estimée à 3 GW, comparable à celle de l’Irlande. 10 consommation d'énergie. Cette même étude prévoyait que la consommation totale d'énergie atteindrait 8 GW à court terme. futur.
Pour résoudre le problème du gaspillage énergétique, le mécanisme de consensus Proof of Stake (PoS) a été proposé par de nombreux nouveaux réseaux. Dans les réseaux PoS, les détenteurs de token verrouillent leurs soldes token pour devenir des blocs validators. Les validator proposent et votent à tour de rôle sur le bloc suivant. Cependant, le problème avec le PoS standard, l'influence de validator est directement corrélée au nombre de token bloqués. Cela conduit les parties à thésauriser de grandes quantités de la monnaie de base du réseau et à les utiliser de manière injustifiée. influence dans l’écosystème du réseau.
Le mécanisme de consensus TRON utilise un système innovant de Delegated Proof of Stake dans lequel 27
Les super représentants (SR) produisent des blocs pour le réseau. Toutes les 6 heures, les titulaires de comptes TRX
qui gèlent leurs comptes peuvent voter pour une sélection de candidats SR, les 27 premiers candidats
considérés comme les SR. Les électeurs peuvent choisir les SR en fonction de critères tels que les projets parrainés par les SR pour
9 PAAR, C., PELZL, J., Comprendre la cryptographie : un manuel pour les étudiants et les praticiens, 2010 éd.
Springer-Verlag Berlin Heidelberg, 2010.
10 https://www.sciencedirect.com/science/article/pii/S2542435118301776augmenter l’adoption du TRX et les récompenses distribuées aux électeurs. Cela permet une société plus démocratisée et
écosystème décentralisé. Les comptes des SR sont des comptes normaux, mais leur accumulation de voix
leur permet de produire des blocs. Avec les faibles débits de Bitcoin et Ethereum en raison de leur
Mécanisme de consensus PoW et problèmes d'évolutivité, le système DPoS de TRON offre une solution innovante
mécanisme résultant en 2000 TPS par rapport aux 3 TPS de Bitcoin et aux 15 TPS de Ethereum.
Le réseau de protocole TRON génère un bloc toutes les trois secondes, chaque bloc attribuant 32 TRX aux super représentants. Un total de 336 384 000 TRX seront attribués chaque année aux 27 SR. Chaque fois qu'un SR termine la production de blocs, les récompenses sont envoyées sur un sous-compte du super-grand livre. Les SR peuvent vérifier, mais ne peuvent pas utiliser directement ces TRX token. Un retrait peut être effectué par chacun SR une fois toutes les 24 heures, transférant les récompenses du sous-compte vers le SR spécifié compte.
Les trois types de nœuds sur le réseau TRON sont Witness Node, Full Node et Solidity Node. Les nœuds témoins sont mis en place par les SR et sont principalement responsables de la production et de la proposition des blocs. création/vote. Les nœuds complets fournissent des API et diffusent des transactions et des blocs. Synchronisation des nœuds Solidity blocs à partir d’autres nœuds complets et fournissent également des API indexables.
Consenso
3.1 Prova de Participação Delegada (DPoS)
O mecanismo de consenso mais antigo é o mecanismo de consenso Prova de Trabalho (PoW). Isto o protocolo está atualmente implementado em Bitcoin e Ethereum . Em sistemas PoW, as transações 7 8 transmitidos pela rede são agrupados em blocos nascentes para confirmação do minerador. O O processo de confirmação envolve hashing transações usando algoritmos criptográficos hashing até que um A raiz merkle foi alcançada, criando uma árvore merkle:
Figura 2: 8 transações TRX são hash inseridas na raiz merkle. Essa raiz merkle é então incluída no cabeçalho do bloco, que é anexado aos blocos previamente confirmados para formar um blockchain. Isso permite um rastreamento fácil e transparente de transações, carimbos de data/hora e outras informações relacionadas.
7 Bitcoin documento técnico: https://bitcoin.org/bitcoin.pdf 8 Ethereum documento técnico: https://github.com/ethereum/wiki/wiki/White-Paper
Algoritmos criptográficos hashing são úteis na prevenção de ataques à rede porque possuem
várias propriedades:
9
●
Tamanho do comprimento de entrada/saída - O algoritmo pode passar uma entrada de qualquer tamanho e
gera um valor hash de comprimento fixo.
●
Eficiência - O algoritmo é relativamente fácil e rápido de calcular.
●
Resistência de pré-imagem - Para uma determinada saída z, é impossível encontrar qualquer entrada x tal que
h(x) = z. Em outras palavras, o algoritmo hashing h(x) é uma função unidirecional em que apenas o
a saída pode ser encontrada, dada uma entrada. O inverso não é possível.
●
Resistência à colisão - É computacionalmente inviável encontrar quaisquer pares x1 ≠ x2 tais que h(x1)
=h(x2). Em outras palavras, a probabilidade de encontrar duas entradas diferentes hash na mesma
a saída é extremamente baixa. Esta propriedade também implica segunda resistência de pré-imagem.
●
Segunda resistência de pré-imagem - Dado x1, e portanto h(x1), é computacionalmente inviável
encontre qualquer x2 tal que h(x1) = h(x2). Embora esta propriedade seja semelhante à resistência à colisão, o
propriedade difere porque diz que um invasor com um determinado x1 irá encontrá-lo computacionalmente
inviável encontrar qualquer x2 hashing para a mesma saída.
●
Determinístico - mapeia cada entrada para uma e apenas uma saída.
●
Efeito Avalanche - uma pequena alteração na entrada resulta em uma saída totalmente diferente.
Estas propriedades conferem à rede de criptomoedas o seu valor intrínseco, garantindo que os ataques não comprometer a rede. Quando os mineradores confirmam um bloqueio, eles são recompensados com tokens como um recurso integrado incentivo à participação na rede. No entanto, à medida que a capitalização do mercado global de criptomoedas aumentou constantemente, os mineiros tornaram-se centralizados e concentraram seus recursos de computação em acumular tokens como ativos, e não para fins de participação na rede. Os mineradores de CPU deram lugar a GPUs, que por sua vez deram lugar a poderosos ASICs. Em um estudo notável, o poder total o consumo de mineração Bitcoin foi estimado em até 3 GW, comparável ao da Irlanda 10 consumo de energia. Este mesmo estudo projetou que o consumo total de energia atingirá 8 GW no próximo futuro.
Para resolver a questão do desperdício de energia, o mecanismo de consenso Proof of Stake (PoS) foi proposto por muitas novas redes. Em redes PoS, os titulares de token bloqueiam seus saldos token para se tornarem bloqueados validators. Os validators se revezam propondo e votando no próximo bloco. No entanto, o problema com PoS padrão é que a influência de validator se correlaciona diretamente com a quantidade de tokens bloqueados. Isto resulta em partes que acumulam grandes quantidades da moeda base da rede e exercem indevidamente influência no ecossistema da rede.
O mecanismo de consenso TRON usa um sistema inovador de Prova de Participação Delegada no qual 27
Super Representantes (SRs) produzem blocos para a rede. A cada 6 horas, titulares de contas TRX
que congelam suas contas podem votar em uma seleção de candidatos SR, com os 27 principais candidatos
considerados os SRs. Os eleitores podem escolher RS com base em critérios como projetos patrocinados por RS para
9 PAAR, C., PELZL, J., Compreendendo a criptografia: um livro didático para estudantes e profissionais, 2010 ed.
Springer-Verlag Berlim Heidelberg, 2010.
10 https://www.sciencedirect.com/science/article/pii/S2542435118301776aumentar a adoção do TRX e recompensas distribuídas aos eleitores. Isto permite um ambiente mais democratizado e
ecossistema descentralizado. As contas dos SRs são contas normais, mas a sua acumulação de votos
lhes permite produzir blocos. Com as baixas taxas de transferência de Bitcoin e Ethereum devido à sua
Mecanismo de consenso PoW e problemas de escalabilidade, o sistema TRON de DPoS oferece um inovador
mecanismo resultando em 2000 TPS em comparação com Bitcoin 3 TPS e Ethereum 15 TPS.
A rede do protocolo TRON gera um bloco a cada três segundos, com cada bloco concedendo 32 TRX para Super Representantes. Um total de 336.384.000 TRX serão concedidos anualmente aos 27 SRs. Cada vez que um SR termina a produção do bloco, as recompensas são enviadas para uma subconta no super-razão. Os SRs podem verificar, mas não fazer uso direto desses TRX tokens. Um saque pode ser feito por cada SR uma vez a cada 24 horas, transferindo as recompensas da subconta para o SR especificado conta.
Os três tipos de nós na rede TRON são Witness Node, Full Node e Solidity Node. Os nós testemunhas são configurados pelos SRs e são os principais responsáveis pela produção e proposta de blocos criação/votação. Nós completos fornecem APIs e transações e blocos de transmissão. Sincronização de nós de solidez blocos de outros Full Nodes e também fornecem APIs indexáveis.
Compte
4.1 Types
Les trois types de comptes du réseau TRON sont les comptes réguliers, les comptes token et comptes de contrats.
1.
Les comptes réguliers sont utilisés pour les transactions standard.
2.
Les comptes de jetons sont utilisés pour stocker les TRC-10 token.
3.
Les comptes de contrats sont des comptes smart contract créés par des comptes réguliers et peuvent être
déclenchés également par les comptes réguliers.
4.2 Création
Il existe trois façons de créer un compte TRON :
1. Créer un nouveau compte via l'API 2. Transférer TRX vers une nouvelle adresse de compte 3. Transférez n'importe quel TRC-10 token vers une nouvelle adresse de compte
Une paire de clés hors ligne composée d'une adresse (clé publique) et d'une clé privée, et non enregistrée par le Le réseau TRON, peut également être généré. L'algorithme de génération d'adresse utilisateur consiste en générer une paire de clés puis extraire la clé publique (tableau d'octets de 64 octets représentant x, y coordonnées). Hachez la clé publique grâce à la fonction SHA3-256 (le protocole SHA3 adopté est KECCAK-256) et extrayez les 20 derniers octets du résultat. Ajoutez 41 au début du tableau d'octets et assurez-vous que la longueur de l’adresse initiale est de 21 octets. Hachez l'adresse deux fois à l'aide de la fonction SHA3-256 et prenez les 4 premiers octets comme code de vérification. Ajoutez le code de vérification à la fin du mot initial et obtenez l'adresse au format base58check via l'encodage base58. Un codé L'adresse du réseau principal commence par T et mesure 34 octets. 4.3 Structure
Les trois types de comptes différents sont Normal, AssetIssue et Contract. Un compte contient 7 paramètres :
1.
account_name : le nom de ce compte – par ex. Compte de factures.
2.
type : quel est le type de ce compte – par ex. 0 (signifie type « Normal »).
3.
solde : solde de ce compte – par ex. 4213312.
4.
vote : votes reçus sur ce compte – par ex. {("0x1b7w…9xj3",323),
(« 0x8djq…j12m »,88),…,(« 0x82nd…mx6i »,10001)}.
5.
actif : autres actifs TRX attendus dans ce compte – par ex. {<"WishToken", 66666>, <"Dogie",
233>}.
6.
last_operation_time : la dernière heure de fonctionnement de ce compte.
Protobuf data structure:
message Account {
message Vote {
bytes vote_address = 1;
int64 vote_count = 2;
}
bytes accout_name = 1;
AccountType type = 2;
bytes address = 3;
int64 balance = 4;
repeated Vote votes = 5;
map<string, int64> asset = 6;
int64 latest_operation_time = 10;
}
enum AccountType {
Normal = 0;
AssetIssue = 1;
Contract = 2;
}
Conta
4.1 Tipos
Os três tipos de contas na rede TRON são contas normais, contas token e contas contratuais.
1.
Contas regulares são usadas para transações padrão.
2.
Contas de token são usadas para armazenar TRC-10 tokens.
3.
As contas de contrato são contas smart contract criadas por contas normais e podem ser
acionado por contas regulares também.
4.2 Criação
Existem três maneiras de criar uma conta TRON:
1. Crie uma nova conta através da API 2. Transfira TRX para um novo endereço de conta 3. Transfira qualquer TRC-10 token para um novo endereço de conta
Um par de chaves off-line composto por um endereço (chave pública) e uma chave privada, e não registrado pelo TRON rede, também pode ser gerada. O algoritmo de geração de endereço de usuário consiste em gerando um par de chaves e depois extraindo a chave pública (matriz de bytes de 64 bytes representando x, y coordenadas). Faça hash da chave pública usando a função SHA3-256 (o protocolo SHA3 adotado é KECCAK-256) e extraia os últimos 20 bytes do resultado. Adicione 41 ao início da matriz de bytes e certifique-se de que o comprimento do endereço inicial seja de 21 bytes. Hash o endereço duas vezes usando a função SHA3-256 e pegue os primeiros 4 bytes como código de verificação. Adicione o código de verificação ao final do inicial endereço e obtenha o endereço no formato base58check por meio da codificação base58. Um codificado O endereço da rede principal começa com T e tem 34 bytes de comprimento. 4.3 Estrutura
Os três tipos de conta diferentes são Normal, AssetIssue e Contrato. Uma conta contém 7 parâmetros:
1.
nome_da_conta: o nome desta conta – por exemplo. Conta de contas.
2.
tipo: que tipo é esta conta – por ex. 0 (significa tipo ‘Normal’).
3.
saldo: saldo desta conta – por ex. 4213312.
Protobuf data structure:
message Account {
message Vote {
bytes vote_address = 1;
int64 vote_count = 2;
}
bytes accout_name = 1;
AccountType type = 2;
bytes address = 3;
int64 balance = 4;
repeated Vote votes = 5;
map<string, int64> asset = 6;
int64 latest_operation_time = 10;
}
enum AccountType {
Normal = 0;
AssetIssue = 1;
Contract = 2;
}
Bloc
Un bloc contient généralement un en-tête de bloc et plusieurs transactions.
Protobuf data structure:
message Block {
BlockHeader block_header = 1;
repeated Transaction transactions = 2;
}
5.1 En-tête de bloc
Un en-tête de bloc contient raw_data, witness_signature et blockID.
Protobuf data structure:
message BlockHeader {
message raw {
int64 timestamp = 1;
bytes txTrieRoot = 2;
bytes parentHash = 3;
uint64 number = 4;
uint64 version = 5;
bytes witness_address = 6;
}
bytes witness_signature = 2;
bytes blockID = 3;
}
5.1.1 Données brutes
Les données brutes sont désignées par raw_data dans Protobuf. Il contient les données brutes d'un message, contenant 6 paramètres :
1. timestamp : horodatage de ce message – par ex. 1543884429000. 2. txTrieRoot : la racine de l'arbre Merkle – par ex. 7dacsa…3éd. 3. parentHash : le hash du dernier bloc – par ex. 7dacsa…3éd. 4. nombre : la hauteur du bloc – par ex. 4638708. 5. version: réservé – par ex. 5.

6. Witness_address : l'adresse du témoin contenue dans ce bloc – par ex. 41928c...4d21. 5.1.2 Signature du témoin
La signature du témoin est désignée par witness_signature dans Protobuf, qui est la signature de ce en-tête de bloc du nœud témoin. 5.1.3 ID de bloc
L'ID de bloc est noté blockID dans Protobuf. Il contient l'identification atomique d'un bloc. Un bloc L'ID contient 2 paramètres : 1. hash : le hash du bloc. 2. numéro : le hash et la hauteur du bloc. 5.2 Opérations 5.2.1 Signature
Le processus de signature de transaction de TRON suit un algorithme cryptographique ECDSA standard, avec un
Courbe de sélection SECP256K1. Une clé privée est un nombre aléatoire et la clé publique est un point sur le
courbe elliptique. Le processus de génération de clé publique consiste à générer d'abord un nombre aléatoire
clé privée, puis en multipliant le point de base de la courbe elliptique par la clé privée pour obtenir le
clé publique. Lorsqu'une transaction se produit, les données brutes de la transaction sont d'abord converties au format octet.
Les données brutes subissent ensuite un SHA-256 hashing. La clé privée correspondant au contrat
adresse signe ensuite le résultat du SHA256 hash. Le résultat de la signature est ensuite ajouté au
transaction.
5.2.2 Modèle de bande passante
Les transactions ordinaires ne consomment que des points de bande passante, mais les opérations smart contract consomment les deux. points d’énergie et de bande passante. Il existe deux types de points de bande passante disponibles. Les utilisateurs peuvent gagner points de bande passante contre le gel de TRX, tandis que 5 000 points de bande passante gratuits sont également disponibles quotidiennement.
Lorsqu'une transaction TRX est diffusée, elle est transmise et stockée sous la forme d'un tableau d'octets sur le réseau. Points de bande passante consommés par une transaction = nombre d'octets de transaction multiplié par le taux de points de bande passante. Par exemple, si la longueur du tableau d'octets d'une transaction est de 200, alors la transaction consomme 200 points de bande passante. Cependant, si un transfert TRX ou token entraîne le compte cible en cours de création, puis uniquement les points de bande passante consommés pour créer le compte seront déduits et les points de bande passante supplémentaires ne seront pas déduits. Dans une création de compte Dans ce scénario, le réseau consommera d'abord les points de bande passante gagnés par l'initiateur de la transaction.du gel de TRX. Si ce montant est insuffisant, alors le réseau consomme la transaction TRX de l’initiateur.
Dans les scénarios de transfert TRX standard d'un compte TRX à un autre, le réseau consomme d'abord les points de bande passante gagnés par l'initiateur de la transaction pour geler TRX. Si cela est insuffisant, alors consomme à partir des 5 000 points de bande passante quotidiens gratuits. Si cela ne suffit toujours pas, alors le réseau consomme le TRX de l'initiateur de la transaction. Le montant est calculé par le nombre d'octets dans la transaction multipliée par 10 SUN. Ainsi, pour la plupart des détenteurs de TRX qui ne gèlent pas nécessairement leur TRX pour participer au vote SR, la première étape est automatiquement ignorée (puisque le solde TRX gelé = 0) et les 5 000 bandes passantes gratuites quotidiennes alimentent la transaction.
Pour les transferts TRC-10 token, le réseau vérifie d'abord si le total des points de bande passante libre du l'actif token émis est suffisant. Sinon, les points de bande passante obtenus en gelant TRX sont consommé. S’il n’y a toujours pas assez de points de bande passante, alors cela consomme le TRX de la transaction initiateur.
5.2.3 Frais
Le réseau TRON ne facture généralement pas de frais pour la plupart des transactions, cependant, en raison du système les restrictions et l'équité, l'utilisation de la bande passante et les transactions entraînent certains frais.
Les frais facturés sont répartis dans les catégories suivantes : 1. Les transactions normales coûtent des points de bande passante. Les utilisateurs peuvent utiliser les points de bande passante quotidiens gratuits (5000) ou geler TRX pour en obtenir plus. Lorsque les points de bande passante ne suffisent pas, TRX sera utilisé directement à partir du compte d’envoi. Le TRX nécessaire est le nombre d'octets * 10 SUN. 2. Les contrats intelligents coûtent de l'énergie (Section 6) mais nécessiteront également des points de bande passante pour le transaction à diffuser et à confirmer. Le coût de la bande passante est le même que ci-dessus. 3. Toutes les transactions de requête sont gratuites. Cela ne coûte ni énergie ni bande passante.
Le réseau TRON définit également un ensemble de frais fixes pour les transactions suivantes : 1. Création d'un nœud témoin : 9999 TRX 2. Émission d'un TRC-10 token : 1024 TRX 3. Création d'un nouveau compte : 0.1 TRX 4. Création d'une paire d'échange : 1024 TRX 5.2.4 Transaction comme preuve de participation (TaPoS)
TRON utilise TaPoS pour garantir que les transactions confirment toutes le blockchain principal, tout en le réalisant
difficile de forger des chaînes contrefaites. Dans TaPoS, les réseaux exigent que chaque transaction comprenne une partie de
le hash d’un en-tête de bloc récent. Cette exigence empêche la relecture des transactions sur
forks n'incluant pas le bloc référencé, et signale également au réseau qu'un utilisateur particulier et sonles enjeux sont sur une fourchette spécifique. Ce mécanisme de consensus protège le réseau contre le déni de
Service, 51 %, exploitation minière égoïste et attaques à double dépense.
5.2.5 Confirmation de transaction
Une transaction est incluse dans un futur bloc après avoir été diffusée sur le réseau. Après 19 blocs sont extrait le TRON (y compris son propre bloc), la transaction est confirmée. Chaque bloc est produit par l'un des 27 meilleurs super-représentants dans un tournoi à la ronde. Chaque bloc prend environ 3 secondes pour être extrait sur le blockchain. Le temps peut légèrement varier pour chaque super représentant en raison du réseau conditions et configurations des machines. En général, une transaction est considérée comme entièrement confirmée après ~1 minute. 5.2.6 Structure
Transaction APIs consist of the following functions: message Transaction { message Contract { enum ContractType { AccountCreateContract = 0; // Create account/wallet TransferContract = 1; // Transfer TRX TransferAssetContract = 2; // Transfer TRC10 token VoteWitnessContract = 4; // Vote for Super Representative (SR) WitnessCreateContract = 5; // Create a new SR account AssetIssueContract = 6; // Create a new TRC10 token WitnessUpdateContract = 8; // Update SR information ParticipateAssetIssueContract = 9; // Purchase TRC10 token AccountUpdateContract = 10; // Update account/wallet information FreezeBalanceContract = 11; // Freeze TRX for bandwidth or energy UnfreezeBalanceContract = 12; // Unfreeze TRX WithdrawBalanceContract = 13; // Withdraw SR rewards, once per day UnfreezeAssetContract = 14; // Unfreeze TRC10 token UpdateAssetContract = 15; // Update a TRC10 token’s information ProposalCreateContract = 16; // Create a new network proposal by any SR ProposalApproveContract = 17; // SR votes yes for a network proposal ProposalDeleteContract = 18; // Delete a network proposal by owner CreateSmartContract = 30; // Deploy a new smart contract TriggerSmartContract = 31; // Call a function on a smart contract GetContract = 32; // Get an existing smart contract UpdateSettingContract = 33; // Update a smart contract’s parameters ExchangeCreateContract = 41; // Create a token trading pair on DEX ExchangeInjectContract = 42; // Inject funding into a trading pair
ExchangeWithdrawContract = 43; // Withdraw funding from a trading pair ExchangeTransactionContract = 44; // Perform token trading UpdateEnergyLimitContract = 45; // Update origin_energy_limit on a smart contract } } }
Bloco
Um bloco normalmente contém um cabeçalho de bloco e diversas transações.
Protobuf data structure:
message Block {
BlockHeader block_header = 1;
repeated Transaction transactions = 2;
}
5.1 Cabeçalho do bloco
Um cabeçalho de bloco contém raw_data, witness_signature e blockID.
Protobuf data structure:
message BlockHeader {
message raw {
int64 timestamp = 1;
bytes txTrieRoot = 2;
bytes parentHash = 3;
uint64 number = 4;
uint64 version = 5;
bytes witness_address = 6;
}
bytes witness_signature = 2;
bytes blockID = 3;
}
5.1.1 Dados Brutos
Os dados brutos são denotados como raw_data no Protobuf. Ele contém os dados brutos de uma mensagem, contendo 6 parâmetros:
1. timestamp: timestamp desta mensagem – por ex. 1543884429000. 2. txTrieRoot: a raiz da árvore Merkle – por exemplo. 7dacsa…3ed. 3. parentHash: o hash do último bloco – por exemplo. 7dacsa…3ed. 4. número: a altura do bloco – por ex. 4638708. 5. versão: reservada – por exemplo. 5.

6. testemunha_address: o endereço da testemunha compactada neste bloco – por exemplo. 41928c...4d21. 5.1.2 Assinatura da Testemunha
A assinatura da testemunha é denotada como witness_signature no Protobuf, que é a assinatura para este cabeçalho do bloco do nó testemunha. 5.1.3 ID do bloco
Block ID é denotado como blockID no Protobuf. Ele contém a identificação atômica de um bloco. Um bloco O ID contém 2 parâmetros: 1. hash: o hash do bloco. 2. número: o hash e a altura do bloco. 5.2 Transação 5.2.1 Assinatura
O processo de assinatura da transação de TRON segue um algoritmo criptográfico ECDSA padrão, com um
Curva de seleção SECP256K1. Uma chave privada é um número aleatório e a chave pública é um ponto na
curva elíptica. O processo de geração de chave pública consiste em primeiro gerar um número aleatório como um
chave privada e, em seguida, multiplicando o ponto base da curva elíptica pela chave privada para obter o
chave pública. Quando ocorre uma transação, os dados brutos da transação são primeiro convertidos em formato de byte.
Os dados brutos são então submetidos a SHA-256 hashing. A chave privada correspondente ao contrato
address então assina o resultado do SHA256 hash. O resultado da assinatura é então adicionado ao
transação.
5.2.2 Modelo de largura de banda
As transações comuns consomem apenas pontos de largura de banda, mas as operações smart contract consomem ambos pontos de energia e largura de banda. Existem dois tipos de pontos de largura de banda disponíveis. Os usuários podem ganhar pontos de largura de banda do congelamento do TRX, enquanto 5.000 pontos de largura de banda gratuitos também estão disponíveis diariamente.
Quando uma transação TRX é transmitida, ela é transmitida e armazenada na forma de uma matriz de bytes sobre a rede. Pontos de largura de banda consumidos por uma transação = número de bytes da transação multiplicado pela taxa de pontos de largura de banda. Por exemplo, se o comprimento da matriz de bytes de uma transação for 200, então a transação consome 200 pontos de largura de banda. No entanto, se uma transferência TRX ou token resultar em a conta de destino sendo criada, apenas os pontos de largura de banda consumidos para criar a conta serão deduzidos e pontos de largura de banda adicionais não serão deduzidos. Na criação de uma conta cenário, a rede consumirá primeiro os pontos de largura de banda que o iniciador da transação ganhoudo congelamento do TRX. Se esse valor for insuficiente, a rede consome a transação TRX do iniciador.
Em cenários padrão de transferência TRX de uma conta TRX para outra, a rede primeiro consome os pontos de largura de banda obtidos pelo iniciador da transação para congelar o TRX. Se isso for insuficiente, então consome dos 5.000 pontos de largura de banda diários gratuitos. Se isso ainda não for suficiente, então a rede consome o TRX do iniciador da transação. O valor é calculado pelo número de bytes em a transação multiplicada por 10 SUN. Assim, para a maioria dos detentores de TRX que podem não necessariamente congelar seu TRX para participar da votação SR, a primeira etapa é automaticamente ignorada (já que o saldo TRX frozen = 0) e a largura de banda gratuita diária de 5.000 alimenta a transação.
Para transferências TRC-10 token, a rede primeiro verifica se o total de pontos de largura de banda livre do ativo token emitido são suficientes. Caso contrário, os pontos de largura de banda obtidos com o congelamento do TRX são consumido. Se ainda não houver pontos de largura de banda suficientes, então consome o TRX da transação iniciador.
5.2.3 Taxa
A rede TRON geralmente não cobra taxas para a maioria das transações, entretanto, devido ao sistema restrições e justiça, uso de largura de banda e transações cobram certas taxas.
As taxas cobradas são divididas nas seguintes categorias: 1. As transações normais custam pontos de largura de banda. Os usuários podem usar os pontos de largura de banda diários gratuitos (5000) ou congele TRX para obter mais. Quando os pontos de largura de banda não forem suficientes, o TRX será usado diretamente da conta remetente. O TRX necessário é o número de bytes * 10 SUN. 2. Os contratos inteligentes custam energia (Seção 6), mas também precisarão de pontos de largura de banda para o transação a ser transmitida e confirmada. O custo da largura de banda é o mesmo acima. 3. Todas as transações de consulta são gratuitas. Não custa energia ou largura de banda.
A rede TRON também define um conjunto de taxas fixas para as seguintes transações: 1. Criando um nó testemunha: 9999 TRX 2. Emitindo um TRC-10 token: 1024 TRX 3. Criando uma nova conta: 0,1 TRX 4. Criando um par de troca: 1024 TRX 5.2.4 Transação como Prova de Participação (TaPoS)
TRON usa TaPoS para garantir que todas as transações confirmem o blockchain principal, ao mesmo tempo que o faz
difícil forjar correntes falsificadas. No TaPoS, as redes exigem que cada transação inclua parte de
o hash de um cabeçalho de bloco recente. Este requisito impede que as transações sejam reproduzidas em
bifurcações não incluindo o bloco referenciado, e também sinaliza à rede que um determinado usuário e seusa aposta está em um fork específico. Este mecanismo de consenso protege a rede contra negação de
Serviço, 51%, mineração egoísta e ataques de gasto duplo.
5.2.5 Confirmação de Transação
Uma transação é incluída em um bloco futuro após ser transmitida para a rede. Após 19 blocos serem minerado em TRON (incluindo seu próprio bloco), a transação é confirmada. Cada bloco é produzido por um dos 27 principais superrepresentantes em um estilo round robin. Cada bloco leva cerca de 3 segundos para ser extraído em blockchain. O tempo pode variar ligeiramente para cada Super Representante devido à rede condições e configurações da máquina. Em geral, uma transação é considerada totalmente confirmada após ~1 minuto. 5.2.6 Estrutura
Transaction APIs consist of the following functions: message Transaction { message Contract { enum ContractType { AccountCreateContract = 0; // Create account/wallet TransferContract = 1; // Transfer TRX TransferAssetContract = 2; // Transfer TRC10 token VoteWitnessContract = 4; // Vote for Super Representative (SR) WitnessCreateContract = 5; // Create a new SR account AssetIssueContract = 6; // Create a new TRC10 token WitnessUpdateContract = 8; // Update SR information ParticipateAssetIssueContract = 9; // Purchase TRC10 token AccountUpdateContract = 10; // Update account/wallet information FreezeBalanceContract = 11; // Freeze TRX for bandwidth or energy UnfreezeBalanceContract = 12; // Unfreeze TRX WithdrawBalanceContract = 13; // Withdraw SR rewards, once per day UnfreezeAssetContract = 14; // Unfreeze TRC10 token UpdateAssetContract = 15; // Update a TRC10 token’s information ProposalCreateContract = 16; // Create a new network proposal by any SR ProposalApproveContract = 17; // SR votes yes for a network proposal ProposalDeleteContract = 18; // Delete a network proposal by owner CreateSmartContract = 30; // Deploy a new smart contract TriggerSmartContract = 31; // Call a function on a smart contract GetContract = 32; // Get an existing smart contract UpdateSettingContract = 33; // Update a smart contract’s parameters ExchangeCreateContract = 41; // Create a token trading pair on DEX ExchangeInjectContract = 42; // Inject funding into a trading pair
ExchangeWithdrawContract = 43; // Withdraw funding from a trading pair ExchangeTransactionContract = 44; // Perform token trading UpdateEnergyLimitContract = 45; // Update origin_energy_limit on a smart contract } } }
TRON Machine virtuelle
6.1 Présentation
TRON Virtual Machine (TVM) est une machine virtuelle légère et complète de Turing développée pour le L'écosystème de TRON. Son objectif est de fournir un système blockchain sur mesure qui soit efficace, pratique, stable, sécurisé et évolutif.
TVM est initialement dérivé de EVM et peut se connecter de manière transparente à la solidité existante smart contract 11 écosystème de développement. Sur cette base, TVM prend également en charge le consensus DPoS.
TVM utilise le concept d'énergie. Différent du mécanisme à gaz sur EVM, les opérations de les transactions et les smart contract sur TVM sont gratuits, sans TRX consommé. Techniquement, exécutable la capacité de calcul sur TVM n'est pas limitée par le montant total de détention de tokens. 6.2 Flux de travail
Le compilateur traduit d'abord le Solidity smart contract en bytecode lisible et exécutable sur le TVM. Le TVM traite ensuite les données via l'opcode, ce qui équivaut à faire fonctionner la logique d'une machine à états finis basée sur une pile. Enfin, le TVM accède aux données blockchain et invoque Interface de données externe via la couche d'interopération. 11 EVM : Ethereum Machine virtuelle (https://github.com/ethereum/ethereumj)

Figure 3 : Flux de travail TVM
6.3 Performances 6.3.1 Architecture légère
TVM adopte une architecture légère dans le but de réduire la consommation de ressources pour garantir performances du système. 6.3.2 Robuste
Les transferts TRX et l'exécution smart contract coûtent uniquement des points de bande passante, au lieu de TRX, qui exempte TRON d'être attaqué. La consommation de bande passante est prévisible et statique puisque chaque le coût de l’étape de calcul est fixe. 6.3.3 Haute compatibilité
TVM est compatible avec EVM et sera compatible avec davantage de machines virtuelles grand public à l'avenir. Ainsi, tous les smart contract sur EVM sont exécutables sur TVM. 6.3.4 Faible coût
Grâce à la configuration de la bande passante de TVM, les coûts de développement sont réduits et les développeurs peuvent se concentrer sur le développement logique de leur code de contrat. TVM propose également des interfaces tout-en-un pour les contrats déploiement, déclenchement et visualisation pour offrir la commodité aux développeurs.
TRON Máquina Virtual
6.1 Introdução
TRON Máquina Virtual (TVM) é uma máquina virtual Turing completa e leve desenvolvida para o Ecossistema de TRON. Seu objetivo é fornecer um sistema blockchain personalizado que seja eficiente, conveniente, estável, seguro e escalável.
TVM inicialmente bifurcado de EVM e pode se conectar perfeitamente com a solidez existente smart contract 11 ecossistema de desenvolvimento. Com base nisso, o TVM também oferece suporte ao consenso DPoS.
A TVM emprega o conceito de Energia. Diferente do mecanismo de gás em EVM, as operações de transações e smart contracts no TVM são gratuitas, sem consumo de TRX. Tecnicamente, executável a capacidade de computação no TVM não é restrita pela quantidade total de tokens. 6.2 Fluxo de trabalho
O compilador primeiro traduz o Solidity smart contract em bytecode legível e executável em a TVM. O TVM então processa os dados através do opcode, o que equivale a operar a lógica de uma máquina de estados finitos baseada em pilha. Finalmente, o TVM acessa dados blockchain e invoca Interface de dados externos através da camada de interoperação. 11 EVM: Ethereum Máquina Virtual (https://github.com/ethereum/ethereumj)

Figura 3: Fluxo de trabalho TVM
6.3 Desempenho 6.3.1 Arquitetura Leve
A TVM adota uma arquitetura leve com o objetivo de reduzir o consumo de recursos para garantir desempenho do sistema. 6.3.2 Robusto
As transferências de TRX e a execução de smart contract custam apenas pontos de largura de banda, em vez de TRX, que isenta TRON de ser atacado. O consumo de largura de banda é previsível e estático, pois cada o custo da etapa computacional é fixo. 6.3.3 Alta Compatibilidade
TVM é compatível com EVM e será compatível com VMs mais convencionais no futuro. Assim, todos os smart contracts em EVM são executáveis no TVM. 6.3.4 Baixo Custo
Devido à configuração da largura de banda do TVM, os custos de desenvolvimento são reduzidos e os desenvolvedores podem se concentrar no desenvolvimento lógico de seu código de contrato. A TVM também oferece interfaces completas para contratos implantação, acionamento e visualização para oferecer conveniência aos desenvolvedores.
Contrat intelligent
7.1 Introduction
Un smart contract est un protocole qui vérifie numériquement la négociation d'un contrat. Ils définissent les règles et pénalités liées à un accord et faire respecter automatiquement ces obligations. L'intelligent le code du contrat facilite, vérifie et impose la négociation ou l’exécution d’un accord ou transaction. Du point de vue de la tokenisation, les smart contract facilitent également les fonds automatiques les transferts entre les parties participantes si certains critères sont remplis.
TRON smart contracts sont écrits dans le langage Solidity. Une fois rédigés et testés, ils peuvent être compilé en bytecode, puis déployé sur le réseau TRON pour la machine virtuelle TRON. Une fois déployés, les smart contract peuvent être interrogés via leurs adresses contractuelles. La demande de contrat L'interface binaire (ABI) affiche les fonctions d'appel du contrat et est utilisée pour interagir avec le réseau. 7.2 Modèle énergétique
La limite d'énergie maximale pour le déploiement et le déclenchement d'un smart contract est fonction de plusieurs variables :
● L'énergie dynamique issue du gel 1 TRX est de 50 000 000 000 (limite d'énergie totale) / (énergie totale Poids) ● La limite d'énergie est la limite d'énergie quotidienne du compte suite au gel du TRX. ● L'énergie quotidienne restante due au gel du TRX est calculée comme Limite d'énergie - Énergie Utilisé ● La limite de frais dans TRX est définie dans l'appel de déploiement/déclenchement smart contract ● TRX restant utilisable dans le compte ● Énergie par TRX si achetée directement (10 SUN = 1 Énergie) = 100 000, les SR peuvent voter réglage
Il existe deux scénarios de consommation pour calculer la limite énergétique maximale pour le déploiement et
déclencheur. La logique peut s’exprimer ainsi :
const R = Dynamic Energy Limit
const F = Daily account energy from freezing TRX
const E = Remaining daily account energy from freezing TRX
const L = Fee limit in TRX set in deploy/trigger call
const T = Remaining usable TRX in account
const C = Energy per TRX if purchased directly
// Calculate M, defined as maximum energy limit for deployment/trigger of smart contract if F > LR let M = min(E+TC, LR) else let M = E+TC 7.3 Déploiement
Lorsqu'une solidité TRON smart contract est compilée, la machine virtuelle TRON lit le contenu compilé. bytecode. Le bytecode se compose d'une section pour le déploiement du code, le code du contrat et les Auxdata. L’Auxdata est l’empreinte cryptographique du code source, utilisée pour la vérification. Le déploiement le bytecode exécute la fonction constructeur et configure les variables de stockage initiales. Le déploiement code calcule également le code du contrat et le renvoie au TVM. L'ABI est un fichier JSON qui décrit les fonctions d'un TRON smart contract. Ce fichier définit les noms des fonctions, leur payabilité, les valeurs de retour de la fonction et leur mutabilité d'état. 7.4 Fonction de déclenchement
Une fois les TRON smart contract déployés, leurs fonctions peuvent être déclenchées individuellement soit via TronStudio ou via des appels API. Les fonctions de changement d'état nécessitent de l'énergie tandis que les fonctions en lecture seule exécuter sans énergie. 7.5 TRON Solidité
TRON Solidity est un fork du langage Solidity de Ethereum. TRON modifie le projet d'origine pour prend en charge les unités TRX et SUN (1 TRX = 1 000 000 SUN). Le reste de la syntaxe du langage est compatible avec Solidité ^0.4.24. Ainsi la Machine Virtuelle Tron (TVM) est quasiment 100% compatible avec les instructions EVM.
Contrato Inteligente
7.1 Introdução
Um smart contract é um protocolo que verifica digitalmente a negociação de contratos. Eles definem as regras e penalidades relacionadas a um acordo e também aplicar automaticamente essas obrigações. O inteligente O código do contrato facilita, verifica e reforça a negociação ou execução de um acordo ou transação. De uma perspectiva de tokenização, smart contracts também facilitam fundos automáticos transferências entre as partes participantes caso determinados critérios sejam atendidos.
TRON smart contracts são escritos na linguagem Solidity. Uma vez escritos e testados, eles podem ser compilado em bytecode e então implantado na rede TRON para a máquina virtual TRON. Uma vez implantados, smart contracts podem ser consultados por meio de seus endereços de contrato. A aplicação do contrato Interface Binária (ABI) mostra as funções de chamada do contrato e é usada para interagir com o rede. 7.2 Modelo Energético
O limite máximo de energia para implantar e acionar um smart contract é uma função de vários variáveis:
● A energia dinâmica do congelamento de 1 TRX é 50.000.000.000 (Limite de Energia Total) / (Energia Total Peso) ● O limite de energia é o limite diário de energia da conta após o congelamento do TRX ● A energia restante da conta diária do congelamento do TRX é calculada como Limite de Energia - Energia Usado ● O limite de taxa no TRX é definido em smart contract implantar/acionar chamada ● TRX utilizável restante na conta ● Energia por TRX se comprada diretamente (10 SUN = 1 Energia) = 100.000, os SRs podem votar ajuste
Existem dois cenários de consumo para calcular o limite máximo de energia para implantação e
gatilho. A lógica pode ser expressa da seguinte forma:
const R = Dynamic Energy Limit
const F = Daily account energy from freezing TRX
const E = Remaining daily account energy from freezing TRX
const L = Fee limit in TRX set in deploy/trigger call
const T = Remaining usable TRX in account
const C = Energy per TRX if purchased directly
// Calculate M, defined as maximum energy limit for deployment/trigger of smart contract if F > LR let M = min(E+TC, LR) else let M = E+TC 7.3 Implantação
Quando uma solidez TRON smart contract é compilada, a máquina virtual TRON lê o compilado bytecódigo. O bytecode consiste em uma seção para implantação de código, código de contrato e Auxdata. O Auxdata é a impressão digital criptográfica do código-fonte, usada para verificação. A implantação bytecode executa a função construtora e configura as variáveis de armazenamento iniciais. A implantação code também calcula o código do contrato e o retorna ao TVM. A ABI é um arquivo JSON que descreve as funções de TRON smart contract. Este arquivo define os nomes das funções, sua remuneração, os valores de retorno da função e sua mutabilidade de estado. 7.4 Função de disparo
Depois que os TRON smart contracts forem implantados, suas funções poderão ser acionadas individualmente por meio de TronStudio ou através de chamadas de API. Funções de mudança de estado requerem energia enquanto funções somente leitura executar sem energia. 7.5 TRON Solidez
TRON Solidity é um fork da linguagem Solidity de Ethereum. TRON modifica o projeto original para suporta unidades TRX e SUN (1 TRX = 1.000.000 SUN). O resto da sintaxe da linguagem é compatível com Solidity ^0.4.24. Assim, a Máquina Virtual Tron (TVM) é quase 100% compatível com instruções EVM.
Token
8.1 Jeton TRC-10
Dans le réseau TRON, chaque compte peut émettre des token au prix de 1024 TRX. Pour émettre des tokens, l'émetteur doit préciser un nom token, la capitalisation totale, le taux de change par rapport au TRX, durée de diffusion, description, site Internet, consommation maximale de bande passante par compte, total la consommation de bande passante et la quantité de token gelée. Chaque édition token peut également configurer le maximum quotidien de chaque compte token transférer des points de bande passante, le maximum quotidien de l'ensemble du réseau token transférer des points de bande passante, l'offre totale de token, la durée de verrouillage en jours et le montant total de token verrouillés. 8.2 Jeton TRC-20
TRC-20 est une norme technique utilisée pour les smart contract mettant en œuvre les token pris en charge par le TRON Machine virtuelle. Il est entièrement compatible avec ERC-20.
L'interface est la suivante :
contrat TRC20Interface {
fonction totalSupply() public retours constants (uint);
fonction balanceOf(adresse tokenOwner) public rendements constants (uint
solde);
fonction allocation(adresse tokenPropriétaire, adresse du dépensier) publique constante
renvoie (uint restant) ;
fonction transfer(adresse à, uint tokens) public retours (bool success) ;
fonction approuve(adresse dépensier, uint tokens) public retourne (bool
succès);
fonction transferFrom(adresse de, adresse à, uint tokens) public
renvoie (succès booléen) ;
événement Transfer(adresse indexée de, adresse indexée vers, uint tokens) ;
événement Approbation(adresse indexée tokenPropriétaire, adresse dépensière indexée, uint
tokens); }
Du point de vue du développeur, il existe plusieurs différences entre TRC-10 et TRC-20. Certains L'une des principales différences réside dans le fait que les token TRC-10 sont accessibles par les API et les smart contract tandis que Les token TRC-20 permettent la personnalisation de l'interface mais ne sont accessibles que dans les smart contract.
Du point de vue des coûts, les TRC-10 token ont des frais de transaction 1 000 fois inférieurs à ceux des
TRC-20, mais entraîne des coûts de bande passante pour les transferts et les dépôts d'API. Virements et dépôts en smart
les contrats pour les TRC-10 token coûtent à la fois de la bande passante et de l'énergie.
8.3 Au-delà
Étant donné que TRON utilise la même version Solidity que Ethereum, davantage de normes token pourraient être facilement porté sur TRON.
Token
8.1 Token TRC-10
Na rede TRON, cada conta pode emitir tokens às custas de 1024 TRX. Para emitir tokens, o emissor precisa especificar um nome token, a capitalização total, a taxa de câmbio para TRX, duração da circulação, descrição, site, consumo máximo de largura de banda por conta, total consumo de largura de banda e a quantidade de token congelados. Cada emissão token também pode configurar o máximo diário de token pontos de largura de banda de transferência de cada conta, o máximo diário de toda a rede token pontos de largura de banda de transferência, fornecimento total de token, duração do bloqueio em dias e valor total de tokens bloqueados. 8.2 Token TRC-20
TRC-20 é um padrão técnico usado para smart contracts implementando tokens suportado pelo TRON Máquina Virtual. É totalmente compatível com ERC-20.
A interface é a seguinte:
contrato TRC20Interface {
função totalSupply() retornos constantes públicos (uint);
função balanceOf(endereço tokenOwner) public constantes retornos (uint
equilíbrio);
função subsídio(endereço tokenProprietário, endereço gastador) public constante
retorna (uint restante);
transferência de função (endereço para, uint tokens) retornos públicos (bool sucesso);
função aprovar (endereço gastador, uint tokens) retornos públicos (bool
sucesso);
função transferFrom(endereço de, endereço para, uint tokens) public
retorna (bool sucesso);
event Transfer(endereço indexado de, endereço indexado para, uint tokens);
Aprovação do evento (endereço indexado tokenProprietário, endereço gastador indexado, uint
tokens); }
Do ponto de vista do desenvolvedor, existem várias diferenças entre o TRC-10 e o TRC-20. Alguns das principais diferenças é que TRC-10 tokens são acessíveis por APIs e smart contracts enquanto TRC-20 tokens permitem a personalização da interface, mas só são acessíveis dentro de smart contracts.
Do ponto de vista de custo, os TRC-10 tokens têm taxas de transação 1.000 vezes mais baixas do que
TRC-20, mas acarreta custos de largura de banda para transferências e depósitos de API. Transferências e depósitos em smart
os contratos para TRC-10 tokens custam largura de banda e energia.
8.3 Além
Como TRON usa a mesma versão do Solidity que Ethereum, mais padrões token poderiam ser prontamente portado para TRON.
Gouvernance
9.1 Super Représentant 9.1.1 Général
Chaque compte du réseau TRON peut postuler et avoir l'opportunité de devenir un Super Représentant (noté SR). Tout le monde peut voter pour les candidats SR. Les 27 meilleurs candidats avec le plus grand nombre de votes deviendront des SR avec le droit et l'obligation de générer des blocs. Les votes sont compté toutes les 6 heures et les SR changeront en conséquence.
Pour prévenir les attaques malveillantes, devenir candidat SR a un coût. Lors de votre candidature, 9999 TRX sera brûlé depuis le compte du demandeur. Une fois réussi, ce compte peut rejoindre le SR élection. 9.1.2 Élection
TRON La puissance (notée TP) est nécessaire pour voter et le montant de TP dépend de la puissance de l'électeur. avoirs gelés (TRX).
TP est calculé de la manière suivante :
TP
1 TRX gelé pour obtenir de la bande passante
1
=
Chaque compte du réseau TRON a le droit de voter pour ses propres SR.
Après la sortie (dégel, disponible après 3 jours), les utilisateurs n'auront plus aucun actif gelé et perdront tout TP en conséquence. En conséquence, tous les votes deviennent invalides pour le tour de scrutin en cours et à venir, à moins que TRX est à nouveau gelé pour voter.
Notez que le réseau TRON n'enregistre que le vote le plus récent, ce qui signifie que chaque nouveau vote annulera tous les votes précédents. 9.1.3 Récompense une. Récompense de vote
Également connu sous le nom de Récompense du candidat, que les 127 meilleurs candidats ont mis à jour une fois à chaque tour (6
heures) partagera 115 200 TRX tels qu’ils sont extraits. La récompense sera répartie en fonction du poids du vote
chaque candidat reçoit. Chaque année, la récompense totale des candidats s'élèvera à 168 192 000 TRX.
Récompense totale des votes par tour
Pourquoi 115 200 TRX à chaque tour ?
15h00 TRX
récompense totale des votes par tour (V R/tour)
1
2
=
V R/tour = 16 T RX/bloc × 20 blocs/min × 60 min/h × 6 heures/tour
Remarque : ceci est défini par WITNESS_STANDBY_ALLOWANCE = 115 200 TRX. Voir les paramètres de réseau dynamiques.
Récompense totale des votes par an
Pourquoi 168 192 000 TRX chaque année ?
168 192 000 T RX = récompense totale des votes par an (V R/an)
V R/an = 115, 200 T RX/tour × 4 tours/jour × 365 jours/an
b. Bloquer la récompense
Également connue sous le nom de Super Representative Reward, qui récompense les 27 meilleurs candidats (SR) élus
chaque tour (6 heures) partagera environ 230 400 TRX extraits. La récompense sera répartie équitablement
entre les 27 SR (moins le total des blocs de récompense manqués en raison d'une erreur réseau). Un total de
336 384 000 TRX seront attribués chaque année aux 27 SR.
Récompense totale de bloc par tour
Pourquoi 230 400 TRX à chaque tour ?
230 400 T RX = récompense de bloc totale par tour (BR/tour)
BR/tour = 32 T RX/bloc × 20 blocs/min × 60 min/h × 6 h/tour
Remarque : la récompense du bloc unitaire est définie par WITNESS_PAY_PER_BLOCK = 32 TRX. Voir le réseau dynamique
paramètres.
Récompense de bloc totale par an
Pourquoi 336 384 000 TRX chaque année ?
336 384 000 T RX = récompense de bloc totale par an (BR/an)
BR/an = 230, 400 T RX/tour × 4 tours/jour × 365 jours/an
1 janvier 2021
Il n'y aura pas d'inflation sur le réseau TRON avant le 1er janvier 2021, et le TRON DAO sera
attribuer toutes les récompenses de bloc et les récompenses de candidat avant cette date.
c. Calcul des récompenses
Calcul de la récompense SR
récompense totale
récompense de vote (V R)
récompense de bloc (BR)
t
=
+
R.
V R totale
V
=
×
total des voix
votes reçus par le candidat SR
R.
bloc manqué
2
B
=
27
BR total −
× 3
Remarque : la récompense est calculée par SR et par tour (6 heures)
Calcul de la récompense du candidat SR du rang 28 au rang 127 récompense totale récompense de vote (V R) t =
R.
V R totale
V
=
×
total des voix
votes reçus par le candidat SR
Remarque : la récompense est calculée par candidat SR et par tour (6 heures)
9.2 Comité
9.2.1 Général
Le comité est utilisé pour modifier les paramètres dynamiques du réseau TRON, tels que la génération de blocs
récompenses, frais de transaction, etc. Le comité est composé des 27 SR du tour en cours. Chaque SR
a le droit de proposer et de voter sur les propositions. Lorsqu'une proposition reçoit 19 voix ou plus, elle est
approuvé et les nouveaux paramètres réseau seront appliqués au cours de la prochaine période de maintenance (3 jours).
9.2.2 Paramètres de réseau dynamiques
0.
MAINTENANCE_TIME_INTERVAL
une.
Descriptif
Modifier le temps d'intervalle de maintenance en ms. Connu sous le nom de temps d'intervalle de vote SR par
rond.
b.
Exemple
[6 * 3600 * 1000] ms - soit 6 heures.
c.
Gamme
[3271000, 2436001000] ms
1.
ACCOUNT_UPGRADE_COST
une.
Descriptif
Modifier le coût de demande de compte SR.
b.
Exemple
[9 999 000 000] SOLEIL - soit 9 999 TRX.
c.
Gamme
[0,100 000 000 000 000 000] DIM
2.
CREATE_ACCOUNT_FEE
une.
Descriptif
Modifier les frais de création de compte.b.
Exemple
[100 000] SOLEIL - soit 1 TRX.
c.
Gamme
[0,100 000 000 000 000 000] DIM
3.
TRANSACTION_FEE
une.
Descriptif
Modifiez le montant des frais utilisés pour obtenir une bande passante supplémentaire.
b.
Exemple
[10] SUN/octet.
c.
Gamme
[0,100 000 000 000 000 000] SUN/octet
4.
ASSET_ISSUE_FEE
une.
Descriptif
Modifier les frais d'émission d'actifs.
b.
Exemple
[1024 000 000] SOLEIL - soit 1024 TRX.
c.
Gamme
[0,100 000 000 000 000 000] DIM
5.
WITNESS_PAY_PER_BLOCK
une.
Descriptif
Modifier la récompense de génération de bloc SR. Connu sous le nom de récompense de bloc unitaire.
b.
Exemple
[32 000 000] SOLEIL - soit 32 TRX.
c.
Gamme
[0,100 000 000 000 000 000] DIM
6.
WITNESS_STANDBY_ALLOWANCE
une.
Descriptif
Modifier les récompenses accordées aux 127 meilleurs candidats SR. Connu sous le nom de récompense totale du vote
par tour.
b.
Exemple
[115 200 000 000] SOLEIL - soit 115 200 TRX.
c.
Gamme
[0,100 000 000 000 000 000] DIM
7.
CREATE_NEW_ACCOUNT_FEE_IN_SYSTEM_CONTRACT
une.
Descriptif
Modifier le coût de création de compte. Combinez les paramètres de réseau dynamiques #8 pour obtenir
coût total de création de compte :
REATE_NEW_ACCOUNT_FEE_IN_SY STEM_CONTRACT
REATE_NEW_ACCOUNT_BANDWIDTH_RATE
C
×C
b. Exemple [0] DIM. c. Gamme [0,100 000 000 000 000 000] DIM 8. CREATE_NEW_ACCOUNT_BANDWIDTH_RATE
une.
Descriptif
Modifier le coût de création de compte. Combinez les paramètres de réseau dynamiques n°7 pour obtenir
coût total de création de compte :
REATE_NEW_ACCOUNT_FEE_IN_SY STEM_CONTRACT
REATE_NEW_ACCOUNT_BANDWIDTH_RATE
C
×C
b. Exemple [1]. c. Gamme [0,100,000,000,000,000,000] 9. ALLOW_CREATION_OF_CONTRACTS une. Descriptif Pour activer la machine virtuelle Tron (TVM). b. Exemple True - défini pour être activé et pris en compte depuis le 10/10/2018 à 23h47 UTC. c. Gamme Vrai/Faux 10. REMOVE_THE_POWER_OF_THE_GR une. Descriptif Supprimer les votes initiaux de la genèse GR b. Exemple Vrai - effectué le 11/4/2018 08:46 UTC. c. Gamme Vrai/Faux - Remarque : impossible de revenir à Faux à partir de Vrai. 11. ÉNERGIE_FEE une. Descriptif Modifier les frais de 1 énergie. b. Exemple 20 DIM. c. Gamme [0,100 000 000 000 000 000] DIM 12. EXCHANGE_CREATE_FEE une. Descriptif Modifier le coût de création d'une paire de trading. Connu comme le coût de création d’un ordre commercial. b. Exemple [1 024 000 000] SOLEIL - soit 1 024 TRX. c. Gamme [0,100 000 000 000 000 000] DIM 13. MAX_CPU_TIME_OF_ONE_TX une. Descriptif Modifier le temps d'exécution maximum d'une transaction. Connu sous le nom de délai d'attente de une transaction. b. Exemple 50 ms. c. Gamme
[0, 1000] ms
14. ALLOW_UPDATE_ACCOUNT_NAME
une.
Descriptif
Modifiez l'option pour permettre à un compte de mettre à jour son nom de compte.
b.
Exemple
False - qui peut être proposé à partir de Java-tron Odyssey v3.2.
c.
Gamme
Vrai/Faux - Remarque : impossible de revenir à Faux à partir de Vrai.
15. ALLOW_SAME_TOKEN_NAME
une.
Descriptif
Modifiez la validation en autorisant différents token à avoir un nom en double.
b.
Exemple
False - qui peut être proposé à partir de Java-tron Odyssey v3.2.
c.
Gamme
Vrai/Faux - Remarque : impossible de revenir à Faux à partir de Vrai.
16. ALLOW_DELEGATE_RESOURCE
une.
Descriptif
Modifier la validation de l'autorisation d'émettre token avec un nom en double, afin que le
tokenID du token, en type de données entier long, serait le seul atome
identification d’un token.
b.
Exemple
False - qui peut être proposé à partir de Java-tron Odyssey v3.2.
c.
Gamme
Vrai/Faux - Remarque : impossible de revenir à Faux à partir de Vrai.
17. TOTAL_ENERGY_LIMIT
une.
Descriptif
Modifier la limite énergétique totale de l'ensemble du réseau.
b.
Exemple
[50 000 000 000 000 000] SOLEIL - soit 50 000 000 000 TRX.
c.
Gamme
[0,100,000,000,000,000,000] SOLEIL
18. ALLOW_TVM_TRANSFER_TRC10
une.
Descriptif
Autoriser le transfert TRC-10 token dans les smart contracts.
ALLOW_UPDATE_ACCOUNT_NAME, ALLOW_SAME_TOKEN_NAME,
Les propositions ALLOW_DELEGATE_RESOURCE doivent toutes être approuvées avant d'être proposées.
ce changement de paramètre.
b.
Exemple
False - qui peut être proposé à partir de Java-tron Odyssey v3.2.
c.
Gamme
Vrai/Faux - Remarque : impossible de revenir à Faux à partir de Vrai.9.2.3 Créer une proposition
Seuls les comptes SR ont le droit de proposer une modification des paramètres dynamiques du réseau. 9.2.4 Proposition de vote
Seuls les membres du comité (SR) peuvent voter pour une proposition et le membre qui ne vote pas à temps sera considéré comme un désaccord. La proposition est active pendant 3 jours après sa création. Le vote peut être modifié ou récupéré pendant la fenêtre de vote de 3 jours. Une fois la période terminée, la proposition sera soit réussir (19+ votes), soit échouer (et terminer). 9.2.5 Annuler la proposition
Le proposant peut annuler la proposition avant qu'elle ne devienne effective. 9.3 Structure
Les SR sont les témoins des blocs nouvellement générés. Un témoin contient 8 paramètres :
1.
adresse : l'adresse de ce témoin – par ex. 0xu82h…7237.
2.
voteCount : nombre de votes reçus sur ce témoin – par ex. 234234.
3.
pubKey : la clé publique de ce témoin – par ex. 0xu82h…7237.
4.
url : l'url de ce témoin – par ex. https://www.noonetrust.com.
5.
totalProduced : le nombre de blocs produits par ce témoin – par ex. 2434.
6.
totalMissed : le nombre de blocs manqués par ce témoin – par ex. 7.
7.
lastBlockNum : la dernière hauteur du bloc – par ex. 4522.
8.
isjobs : un indicateur booléen.
Structure des données Protobuf :
message Témoin{
adresse octets = 1 ;
int64 voteCount = 2;
octets pubKey = 3;
URL de chaîne = 4;
int64 totalProduced = 5;
int64 totalManqué = 6;
int64 lastBlockNum = 7;
bool isJobs = 8;
}
- Développement DApp 10.1 API
Le réseau TRON offre une large sélection de plus de 60 passerelles API HTTP pour interagir avec le réseau via des nœuds complets et solides. De plus, TronWeb est une bibliothèque JavaScript complète contenant des fonctions API qui permettent aux développeurs de déployer des smart contract, modifiez le blockchain état, interrogez blockchain et informations sur le contrat, négociez sur le DEX et bien plus encore. Ces API les passerelles peuvent être dirigées vers un réseau privé local, le réseau de test Shasta ou le réseau principal TRON.
10.2 Réseaux
TRON possède à la fois un réseau de test Shasta et un réseau principal. Les développeurs peuvent se connecter aux réseaux en
déployer des nœuds, interagir via TronStudio ou utiliser des API via le service TronGrid. La grille Tron
Le service se compose de clusters de nœuds à charge équilibrée hébergés sur des serveurs AWS dans le monde entier. En tant que DApp
le développement s'intensifie et les volumes d'appels API augmentent, TronGrid répond avec succès à l'augmentation du
Trafic API.
10.3 Outils
TRON propose une suite d'outils de développement permettant aux développeurs de créer des DApp innovantes.
TronBox est un framework qui permet aux développeurs de tester et de déployer des smart contract via TronWeb
API. TronGrid est un service API hébergé et à charge équilibrée qui permet aux développeurs d'accéder au
TRON réseau sans avoir à exécuter leur propre nœud. TronGrid offre un accès à la fois au Shasta
testnet ainsi que le réseau principal TRON. TronStudio est un développement intégré complet
Environnement (IDE) qui permet aux développeurs de compiler, déployer et déboguer leur solution intelligente Solidity
contrats. TronStudio contient un nœud complet interne qui crée un environnement local privé pour
smart contract tests avant le déploiement. La bibliothèque API TronWeb connecte les développeurs au
réseau via une large sélection d'appels d'API HTTP enveloppés dans JavaScript.
10.4 Ressources
Le TRON Developer Hub est un site de documentation API complet conçu pour 12 développeurs souhaitant s’appuyer sur le réseau TRON. Le Developer Hub fournit un haut niveau compréhension conceptuelle de TRON et guide les utilisateurs à travers les détails de l'interaction avec le 12 Hub des développeurs : https://developers.tron.network/
réseau. Les guides guident les développeurs dans la configuration, le déploiement et l'interaction des nœuds avec Smart.
contrats, interaction et mise en œuvre de l'API, création d'exemples de DApp et utilisation de chacun des
outils de développement. De plus, les chaînes de la communauté des développeurs sont disponibles via Discord.
13
13 Discorde : https://discordapp.com/invite/GsRgsTD
- Conclusion
TRON est une solution blockchain évolutive qui a utilisé des méthodes innovantes pour lutter contre défis rencontrés par les anciens réseaux blockchain. Ayant atteint plus de 2 millions de transactions par jour, avec plus de 700 000 comptes TRX et dépassant les 2 000 TPS, TRON a permis à la communauté de créer un réseau décentralisé et démocratisé.
Governança
9.1 Superrepresentante 9.1.1 Geral
Todas as contas da rede TRON podem se inscrever e ter a oportunidade de se tornar um Super Representante (denotado como SR). Todos podem votar em candidatos SR. Os 27 principais candidatos com os mais votados se tornarão SRs com direito e obrigação de gerar blocos. Os votos são contado a cada 6 horas e os SRs mudarão de acordo.
Para evitar ataques maliciosos, há um custo para se tornar um candidato à RS. Ao se inscrever, 9999 O TRX será eliminado da conta do requerente. Uma vez bem-sucedida, essa conta pode ingressar no SR eleição. 9.1.2 Eleição
TRON O poder (denotado como TP) é necessário para votar e a quantidade de TP depende do eleitor ativos congelados (TRX).
O TP é calculado da seguinte forma:
PT
1 TRX congelado para obter largura de banda
1
=
Cada conta na rede TRON tem o direito de votar em seus próprios SRs.
Após o lançamento (descongelamento, disponível após 3 dias), os usuários não terão nenhum ativo congelado e perderão todos TP em conformidade. Como resultado, todos os votos tornam-se inválidos para a ronda de votação em curso e futura, a menos que TRX está congelado novamente para votar.
Observe que a rede TRON registra apenas o voto mais recente, o que significa que cada novo voto anulará todos os votos anteriores. 9.1.3 Recompensa uma. Recompensa de voto
Também conhecido como Recompensa do Candidato, que os 127 melhores candidatos atualizam uma vez a cada rodada (6
horas) compartilhará 115.200 TRX extraídos. A recompensa será dividida de acordo com o peso dos votos
cada candidato recebe. A cada ano, a recompensa total para os candidatos será de 168.192.000 TRX.
Recompensa total de votos por rodada
Por que 115.200 TRX a cada rodada?
15,00 TRX
recompensa total de votos por rodada (V R/rodada)
1
2
=
V R/rodada = 16 T RX/bloco × 20 blocos/min × 60 minutos/h × 6 horas/rodada
Aviso: isso é definido por WITNESS_STANDBY_ALLOWANCE = 115.200 TRX. Consulte parâmetros de rede dinâmica.
Recompensa total de votos por ano
Por que 168.192.000 TRX todos os anos?
168.192.000 T RX = recompensa total de votos por ano (V R/ano)
V R/ano = 115.200 T RX/rodada × 4 rodadas/dia × 365 dias/ano
b. Recompensa de bloco
Também conhecida como Recompensa do Super Representante, que os 27 principais candidatos (SRs) eleitos
cada rodada (6 horas) compartilhará cerca de 230.400 TRX extraídos. A recompensa será dividida igualmente
entre os 27 SRs (menos o total de blocos de recompensa perdidos devido a erro de rede). Um total de
336.384.000 TRX serão concedidos anualmente aos 27 SRs.
Recompensa total do bloco por rodada
Por que 230.400 TRX a cada rodada?
230, 400 T RX = recompensa total do bloco por rodada (BR/rodada)
BR/rodada = 32 T RX/bloco × 20 blocos/min × 60 minutos/h × 6 horas/rodada
Aviso: a recompensa do bloco unitário é definida por WITNESS_PAY_PER_BLOCK = 32 TRX. Veja rede dinâmica
parâmetros.
Recompensa total do bloco por ano
Por que 336.384.000 TRX todos os anos?
336.384.000 T RX = recompensa total do bloco por ano (BR/ano)
BR/ano = 230.400 T RX/rodada × 4 rodadas/dia × 365 dias/ano
1º de janeiro de 2021
Não haverá inflação na rede TRON antes de 1º de janeiro de 2021, e TRON DAO
conceder todas as recompensas em bloco e recompensas de candidatos antes dessa data.
c. Cálculo de recompensa
Cálculo de recompensa SR
recompensa total
recompensa de voto (V R)
recompensa de bloco (BR)
t
=
+
R
VR total
V
=
×
total de votos
votos que o candidato SR recebeu
R
bloco perdido
2
B
=
27
BR total -
× 3
Nota: a recompensa é calculada por SR por rodada (6 horas)
Cálculo de recompensa de candidato de classificação 28 a 127 SR recompensa total recompensa de voto (V R) t =
R
VR total
V
=
×
total de votos
votos que o candidato SR recebeu
Nota: a recompensa é calculada por candidato SR por rodada (6 horas)
9.2 Comitê
9.2.1 Geral
O comitê é usado para modificar parâmetros de rede dinâmicos TRON, como geração de blocos
recompensas, taxas de transação, etc. O comitê é composto pelos 27 SRs da rodada atual. Cada RS
tem o direito de propor e votar propostas. Quando uma proposta recebe 19 votos ou mais, é
aprovado e os novos parâmetros de rede serão aplicados no próximo período de manutenção (3 dias).
9.2.2 Parâmetros de Rede Dinâmicos
0.
MAINTENANCE_TIME_INTERVAL
uma.
Descrição
Modifique o tempo do intervalo de manutenção em ms. Conhecido como tempo de intervalo de votação SR por
redondo.
b.
Exemplo
[6 * 3600 * 1000] ms - que é 6 horas.
c.
Alcance
[3271000, 2436001000]ms
1.
ACCOUNT_UPGRADE_COST
uma.
Descrição
Modifique o custo de inscrição para uma conta SR.
b.
Exemplo
[9.999.000.000] SUN – que é 9.999 TRX.
c.
Alcance
[0,100 000 000 000 000 000] SOL
2.
CREATE_ACCOUNT_FEE
uma.
Descrição
Modifique a taxa de criação de conta.b.
Exemplo
[100.000] SOL - que é 1 TRX.
c.
Alcance
[0,100 000 000 000 000 000] SOL
3.
TRANSACTION_FEE
uma.
Descrição
Modifique o valor da taxa usada para obter largura de banda extra.
b.
Exemplo
[10] SOL/byte.
c.
Alcance
[0,100 000 000 000 000 000] SOL/byte
4.
ASSET_ISSUE_FEE
uma.
Descrição
Modifique a taxa de emissão de ativos.
b.
Exemplo
[1024.000.000] SOL - que é 1024 TRX.
c.
Alcance
[0,100 000 000 000 000 000] SOL
5.
WITNESS_PAY_PER_BLOCK
uma.
Descrição
Modifique a recompensa de geração de bloco SR. Conhecida como recompensa de bloco unitário.
b.
Exemplo
[32.000.000] SUN - que é 32 TRX.
c.
Alcance
[0,100 000 000 000 000 000] SOL
6.
WITNESS_STANDBY_ALLOWANCE
uma.
Descrição
Modifique as recompensas dadas aos 127 principais candidatos SR. Conhecida como recompensa total de votos
por rodada.
b.
Exemplo
[115.200.000.000] SUN – que é 115.200 TRX.
c.
Alcance
[0,100 000 000 000 000 000] SOL
7.
CREATE_NEW_ACCOUNT_FEE_IN_SYSTEM_CONTRACT
uma.
Descrição
Modifique o custo de criação de conta. Combine os parâmetros de rede dinâmica nº 8 para obter
custo total de criação de conta:
REATE_NEW_ACCOUNT_FEE_IN_SY STEM_CONTRACT
REATE_NEW_ACCOUNT_BANDWIDTH_RATE
C
×C
b. Exemplo [0] SOL. c. Alcance [0,100 000 000 000 000 000] SOL 8. CREATE_NEW_ACCOUNT_BANDWIDTH_RATE
uma.
Descrição
Modifique o custo de criação de conta. Combine os parâmetros de rede dinâmica nº 7 para obter
custo total de criação de conta:
REATE_NEW_ACCOUNT_FEE_IN_SY STEM_CONTRACT
REATE_NEW_ACCOUNT_BANDWIDTH_RATE
C
×C
b. Exemplo [1]. c. Alcance [0.100.000.000.000.000.000] 9. ALLOW_CREATION_OF_CONTRACTS uma. Descrição Para ativar a Máquina Virtual Tron (TVM). b. Exemplo Verdadeiro - definido para ativação e efeito desde 10/10/2018 23:47 UTC. c. Alcance Verdadeiro/Falso 10. REMOVE_THE_POWER_OF_THE_GR uma. Descrição Remova os votos iniciais do GR genesis b. Exemplo Verdadeiro - efetuado em 04/11/2018 08:46 UTC. c. Alcance Verdadeiro/Falso - Aviso: não é possível retornar de Verdadeiro para Falso. 11. ENERGY_FEE uma. Descrição Modifique a taxa de 1 energia. b. Exemplo 20 SOL. c. Alcance [0,100 000 000 000 000 000] SOL 12. EXCHANGE_CREATE_FEE uma. Descrição Modifique o custo de criação de pares de negociação. Conhecido como o custo de criação de uma ordem comercial. b. Exemplo [1.024.000.000] SOL - que é 1024 TRX. c. Alcance [0,100 000 000 000 000 000] SOL 13. MAX_CPU_TIME_OF_ONE_TX uma. Descrição Modifique o tempo máximo de execução de uma transação. Conhecido como limite de tempo limite de uma transação. b. Exemplo 50 ms. c. Alcance
[0, 1000] ms
14. ALLOW_UPDATE_ACCOUNT_NAME
uma.
Descrição
Modifique a opção para permitir que uma conta atualize seu nome de conta.
b.
Exemplo
Falso - que está disponível para proposta no java-tron Odyssey v3.2.
c.
Alcance
Verdadeiro/Falso - Aviso: não é possível retornar de Verdadeiro para Falso.
15.ALLOW_SAME_TOKEN_NAME
uma.
Descrição
Modifique a validação para permitir que diferentes token tenham um nome duplicado.
b.
Exemplo
Falso - que está disponível para proposta no java-tron Odyssey v3.2.
c.
Alcance
Verdadeiro/Falso - Aviso: não é possível retornar de Verdadeiro para Falso.
16. ALLOW_DELEGATE_RESOURCE
uma.
Descrição
Modifique a validação para permitir a emissão de token com nome duplicado, para que o
tokenID do token, no tipo de dados inteiro longo, seria o único atômico
identificação de um token.
b.
Exemplo
Falso - que está disponível para proposta no java-tron Odyssey v3.2.
c.
Alcance
Verdadeiro/Falso - Aviso: não é possível retornar de Verdadeiro para Falso.
17. TOTAL_ENERGY_LIMIT
uma.
Descrição
Modifique todo o limite de energia total da rede.
b.
Exemplo
[50.000.000.000.000.000] SOL - que é 50.000.000.000 TRX.
c.
Alcance
[0.100.000.000.000.000.000] SOL
18. ALLOW_TVM_TRANSFER_TRC10
uma.
Descrição
Permitir transferência TRC-10 token dentro de smart contracts.
ALLOW_UPDATE_ACCOUNT_NAME, ALLOW_SAME_TOKEN_NAME,
Todas as propostas ALLOW_DELEGATE_RESOURCE devem ser aprovadas antes de serem propostas
esta mudança de parâmetro.
b.
Exemplo
Falso - que está disponível para proposta no java-tron Odyssey v3.2.
c.
Alcance
Verdadeiro/Falso - Aviso: não é possível retornar de Verdadeiro para Falso.9.2.3 Criar Proposta
Somente as contas SR têm o direito de propor uma alteração nos parâmetros dinâmicos da rede. 9.2.4 Proposta de Votação
Somente os membros do comitê (SRs) podem votar em uma proposta e o membro que não votar a tempo será considerado como discordo. A proposta fica ativa por 3 dias após ser criada. A votação pode ser alterado ou recuperado durante o período de votação de 3 dias. Terminado o período, a proposta será sucesso (mais de 19 votos) ou fracasso (e fim). 9.2.5 Cancelar Proposta
O proponente pode cancelar a proposta antes que ela entre em vigor. 9.3 Estrutura
SRs são as testemunhas dos blocos recém-gerados. Uma testemunha contém 8 parâmetros:
1.
endereço: o endereço desta testemunha – por ex. 0xu82h…7237.
2.
voteCount: número de votos recebidos nesta testemunha – por ex. 234234.
3.
pubKey: a chave pública desta testemunha – por exemplo. 0xu82h…7237.
4.
url: o URL desta testemunha – por ex. https://www.noonetrust.com.
5.
totalProduzido: o número de blocos que esta testemunha produziu – por exemplo. 2434.
6.
totalMissed: o número de blocos que esta testemunha perdeu – por exemplo. 7.
7.
lastBlockNum: a última altura do bloco – por exemplo. 4522.
8.
isjobs: um sinalizador booleano.
Estrutura de dados do protobuf:
mensagem Testemunha{
endereço de bytes = 1;
int64 contagem de votos = 2;
bytes pubKey = 3;
string url=4;
int64 totalProduzido = 5;
int64 totalPerdidos = 6;
int64 últimoBlockNum = 7;
bool isJobs = 8;
}
- Desenvolvimento de DApps 10.1 APIs
A rede TRON oferece uma ampla seleção de mais de 60 gateways de API HTTP para interagir com o rede via Full e Solidity Nodes. Além disso, TronWeb é uma biblioteca JavaScript abrangente contendo funções de API que permitem aos desenvolvedores implantar smart contracts, altere o blockchain estado, consulta blockchain e informações de contrato, negociação no DEX e muito mais. Estas APIs os gateways podem ser direcionados para uma rede privada local, a rede de teste Shasta ou a rede principal TRON.
10.2 Redes
TRON possui uma rede de teste Shasta e também uma rede principal. Os desenvolvedores podem se conectar às redes por
implantando nós, interagindo via TronStudio ou usando APIs por meio do serviço TronGrid. O TronGrid
O serviço consiste em clusters de nós com balanceamento de carga hospedados em servidores AWS em todo o mundo. Como DApp
o desenvolvimento aumenta e os volumes de chamadas de API aumentam, o TronGrid responde com sucesso ao aumento em
Tráfego de API.
10.3 Ferramentas
TRON oferece um conjunto de ferramentas de desenvolvimento para permitir que os desenvolvedores criem DApps inovadores.
TronBox é uma estrutura que permite aos desenvolvedores testar e implantar smart contracts através do TronWeb
API. TronGrid é um serviço de API hospedado e com balanceamento de carga que permite aos desenvolvedores acessar o
TRON rede sem precisar executar seu próprio nó. TronGrid oferece acesso tanto ao Shasta
testnet, bem como a rede principal TRON. TronStudio é um desenvolvimento integrado abrangente
Ambiente (IDE) que permite aos desenvolvedores compilar, implantar e depurar seu Solidity smart
contratos. TronStudio contém um nó completo interno que cria um ambiente local privado para
smart contract testes antes da implantação. A biblioteca API TronWeb conecta desenvolvedores ao
rede por meio de uma ampla seleção de chamadas de API HTTP agrupadas em JavaScript.
10.4 Recursos
O TRON Developer Hub é um site abrangente de documentação de API adaptado para 12 desenvolvedores que desejam desenvolver na rede TRON. O Developer Hub fornece um alto nível compreensão conceitual de TRON e orienta os usuários nos detalhes da interação com o 12 Centro do desenvolvedor: https://developers.tron.network/
rede. Os guias orientam os desenvolvedores na configuração, implantação e interação do nó com aplicativos inteligentes
contratos, interação e implementação de API, construção de DApps de amostra e uso de cada um dos
ferramentas para desenvolvedores. Além disso, os canais da comunidade de desenvolvedores estão disponíveis através do Discord.
13
13Discordância: https://discordapp.com/invite/GsRgsTD
- Conclusão
TRON é uma solução blockchain escalável que empregou métodos inovadores para lidar com desafios enfrentados pelas redes blockchain legadas. Tendo alcançado mais de 2 milhões de transações por dia, com mais de 700 mil contas TRX e ultrapassando 2.000 TPS, TRON permitiu à comunidade em criando uma rede descentralizada e democratizada.