堅牢性-文字列

Solidityは、二重引用符( ")と一重引用符( ')の両方を使用する文字列リテラルをサポートします。文字列型の変数を宣言するためのデータ型として文字列を提供します。

pragma solidity ^0.5.0;

contract SolidityTest {
   string data = "test";
}

上記の例では、「test」は文字列リテラルであり、dataは文字列変数です。文字列操作はバイト操作に比べてより多くのガスを必要とするため、より好ましい方法は文字列の代わりにバイトタイプを使用することです。Solidityは、バイトから文字列への、またはその逆の変換を組み込みで提供します。Solidityでは、文字列リテラルをbyte32型変数に簡単に割り当てることができます。Solidityはそれをbyte32リテラルと見なします。

pragma solidity ^0.5.0;

contract SolidityTest {
   bytes32 data = "test";
}

エスケープ文字

シニア番号 キャラクターと説明
1

\n

新しい行を開始します。

2

\\

バックスラッシュ

3

\'

一重引用

4

\"

二重引用符

5

\b

バックスペース

6

\f

フォームフィード

7

\r

キャリッジリターン

8

\t

タブ

9

\v

垂直タブ

10

\xNN

16進値を表し、適切なバイトを挿入します。

11

\uNNNN

Unicode値を表し、UTF-8シーケンスを挿入します。

バイトから文字列への変換

バイトは、string()コンストラクターを使用してStringに変換できます。

bytes memory bstr = new bytes(10);
string message = string(bstr);

次のコードを試して、Solidityで文字列がどのように機能するかを理解してください。

pragma solidity ^0.5.0;

contract SolidityTest {   
   constructor() public{       
   }
   function getResult() public view returns(string memory){
      uint a = 1; 
      uint b = 2;
      uint result = a + b;
      return integerToString(result); 
   }
   function integerToString(uint _i) internal pure 
      returns (string memory) {
      
      if (_i == 0) {
         return "0";
      }
      uint j = _i;
      uint len;
      
      while (j != 0) {
         len++;
         j /= 10;
      }
      bytes memory bstr = new bytes(len);
      uint k = len - 1;
      
      while (_i != 0) {
         bstr[k--] = byte(uint8(48 + _i % 10));
         _i /= 10;
      }
      return string(bstr);
   }
}

Solidity First Applicationの章に記載されている手順を使用して、上記のプログラムを実行します。

出力

0: string: 3