Hướng dẫn binary to integer javascript - javascript nhị phân sang số nguyên

Một giải pháp tôi sẽ đi với điều đó tốt cho 32 bit, là mã kết thúc của câu trả lời này, từ nhà phát triển.mozilla.org [MDN], nhưng với một số dòng được thêm vào] Số là trong phạm vi.

Nội dung chính ShowShow

  • Ví dụ 1: Chuyển đổi thập phân thành nhị phân
  • Ví dụ 2: Chuyển đổi thập phân sang nhị phân bằng cách sử dụng toString []
  • Giá trị nhị phân được tính bằng:
  • Ví dụ 2: Chuyển đổi thập phân sang nhị phân bằng cách sử dụng toString []
  • Giá trị nhị phân được tính bằng:
  • Phương thức tích hợp JavaScript function createBinaryString[nMask] { // nMask must be between -2147483648 and 2147483647 if [nMask > 2**31-1] throw "number too large. number shouldn't be > 2**31-1"; //added if [nMask < -1*[2**31]] throw "number too far negative, number shouldn't be < 2**31" //added for [var nFlag = 0, nShifted = nMask, sMask = ''; nFlag < 32; nFlag++, sMask += String[nShifted >>> 31], nShifted 31], nShifted

Ví dụ 2: Chuyển đổi thập phân sang nhị phân bằng cách sử dụng phương thức parseInt [] được sử dụng để chuyển đổi giá trị chuỗi thành số nguyên. Phương thức tích hợp JavaScript ToString [[Radix]] trả về giá trị chuỗi trong một radix được chỉ định [cơ sở]. Ở đây, toString [2] chuyển đổi số thập phân thành số nhị phân.

Một số đề xuất

function createBinaryString[nMask] {
  // nMask must be between -2147483648 and 2147483647
  if [nMask > 2**31-1] 
     throw "number too large. number shouldn't be > 2**31-1"; //added
  if [nMask < -1*[2**31]]
     throw "number too far negative, number shouldn't be < 2**31" //added
  for [var nFlag = 0, nShifted = nMask, sMask = ''; nFlag < 32;
       nFlag++, sMask += String[nShifted >>> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted  31], nShifted 
  • Ví dụ 2: Chuyển đổi thập phân sang nhị phân bằng cách sử dụng phương thức parseInt [] được sử dụng để chuyển đổi giá trị chuỗi thành số nguyên. Phương thức tích hợp JavaScript ToString [[Radix]] trả về giá trị chuỗi trong một radix được chỉ định [cơ sở]. Ở đây, toString [2] chuyển đổi số thập phân thành số nhị phân.
  • Phương thức tích hợp JavaScript function createBinaryString[nMask] { // nMask must be between -2147483648 and 2147483647 if [nMask > 2**31-1] throw "number too large. number shouldn't be > 2**31-1"; //added if [nMask < -1*[2**31]] throw "number too far negative, number shouldn't be < 2**31" //added for [var nFlag = 0, nShifted = nMask, sMask = ''; nFlag < 32; nFlag++, sMask += String[nShifted >>> 31], nShifted 31], nShifted
  • JavaScript có sử dụng mã nhị phân không?

    JavaScript sử dụng 32 bit BitWise Toán tử JavaScript Các số lưu trữ là 64 bit số điểm nổi, nhưng tất cả các hoạt động bitwise được thực hiện trên 32 bit số nhị phân. Trước khi hoạt động bitwise được thực hiện, JavaScript đã chuyển đổi số thành 32 bit số nguyên đã ký.

    Làm thế nào để bạn chuyển đổi một số thành một số nguyên trong JavaScript?

    Một giải pháp có thể liên quan đến việc chi tiêu 0 cho các số dương, điều mà tôi đã làm trong một bản sửa đổi trước đó của câu trả lời này. Và đôi khi người ta có thể chấp nhận có số 33 bit hoặc người ta có thể đảm bảo rằng số để chuyển đổi nằm trong phạm vi -[2^31]

    Câu trả lời và mã của Patrick dài và dường như hoạt động cho 64 bit, nhưng có một lỗi mà một người bình luận đã tìm thấy, và người bình luận đã sửa lỗi của Patrick, nhưng Patrick có một số "số ma thuật" trong mã của anh ta mà anh ta không bình luận và đã quên mất và Patrick không còn hiểu đầy đủ về mã của chính mình / tại sao nó hoạt động.

    Annan có một số thuật ngữ không chính xác và không rõ ràng nhưng đã đề cập đến một giải pháp của nhà phát triển.mozilla.org

    Lưu ý- Liên kết cũ //developer.mozilla.org/en-us/docs/web/javascript Archive.org Lấy các trang !, Có sẵn tại đây //web.archive.org/web/20150315015832///developer.mozilla.org/en-us/docs/web/javascript

    Giải pháp ở đó hoạt động cho các số 32 bit.

    Mã này khá nhỏ gọn, một chức năng của ba dòng.

    Nhưng tôi đã thêm một regex để định dạng đầu ra theo nhóm 8 bit. Dựa trên cách in một số với dấu phẩy dưới dạng hàng ngàn máy phân tách trong JavaScript [tôi vừa sửa đổi nó từ việc nhóm nó trong 3 giây sang trái và thêm dấu phẩy, để nhóm trong 8 giây sang trái và thêm không gian]

    Và, trong khi Mozilla đưa ra một nhận xét về kích thước của NMASK [số được cho ăn vào] .. rằng nó phải nằm trong phạm vi, họ đã không kiểm tra hoặc ném lỗi khi số nằm ngoài phạm vi, vì vậy tôi Thêm vào đó.

    Tôi không chắc tại sao họ đặt tên cho tham số của họ 'NMASK' nhưng tôi sẽ để lại như vậy.

    //web.archive.org/web/20150315015832///developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators

    function createBinaryString[nMask] {
      // nMask must be between -2147483648 and 2147483647
      if [nMask > 2**31-1] 
         throw "number too large. number shouldn't be > 2**31-1"; //added
      if [nMask < -1*[2**31]]
         throw "number too far negative, number shouldn't be < 2**31" //added
      for [var nFlag = 0, nShifted = nMask, sMask = ''; nFlag < 32;
           nFlag++, sMask += String[nShifted >>> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted >> 31], nShifted  31], nShifted 

    JavaScript Có Sử Dụng MÃ NHâ Phân Không? Chia số đã cho nhiều lần cho đến khi chúng tôi nhận được 0 làm thương số.Sau đó, chúng tôi viết phần còn lại theo thứ tự ngược lại để có được giá trị nhị phân của số thập phân đã cho.dividing the given number repeatedly by 2 until we get 0 as the quotient. Then, we write the remainders in the reverse order to get the binary value of the given decimal number.

    Bài Viết Liên Quan

    Chủ Đề