Inversion of control là gì

  -  

1. Nguyên tắc Inversion of Control là gì?

Trước lúc đến với có mang Inversion of Control là gì? các bạn hãy thuộc tôi có tác dụng vài cốc tsoát đá nói điêu tí. Trong ghế nhà trường chắc hẳn rằng ai cũng hại độc nhất môn Triết học vì chưng mấy lý do, cực nhọc hiểu (trìu tượng), những quan niệm đề xuất học tập nằm trong. Thế cơ mà Triết học lại là kỹ thuật của rất nhiều công nghệ bởi nó trìu tượng ở 1 tầng cao nhất. Bản thân tôi cũng đã quên toàn cục các gì học tập được (nói chính xác là nằm trong đc) trong Triết học tập ngay lập tức sau khoản thời gian thi ngừng môn này, mặc dù thế sau 1 thời điểm hơi nhiều năm bề bộn toan lo cùng với câu hỏi làm and cuộc sống thường ngày, các quan niệm, quy lý lẽ xa xưa nằm trong trong Triết học tự nhiên cứ đọng lẩn vẩn trong đầu và rồi ngẫm lại, đúng thật! Điểm lại chút về 2 lý lẽ, 3 quy lao lý and 6 cặp phạm trù trong Triết học, hoàn toàn có thể vào phạm vi phát âm biết của mình & các hưởng thụ cho ngày này nó đã cũng trở nên toàn cục những gì vẫn reviews bao bọc ta. Ssinh sống dĩ viết vài ba câu chuyện pthảng hoặc tại đây hầu cthị trấn chúng ta bởi vì mọi khái niệm mà các bạn trao đổi trong nội dung bài viết này khá là trìu tượng, nó cũng tương tự triết học là phương pháp của không ít qui định. Một trong những quy phương tiện cơ mà tôi giỏi chiêm nghiệm đặc biệt là quy lý lẽ lượng chất:

Các chỉnh sửa đối kháng thuần về lượng, mang lại một mức độ bình ổn, vẫn gửi hóa thành các sự khác biệt về chất lượng.

Bạn đang xem: Inversion of control là gì

Bài Viết: Inversion of control là gì

Friedrich Engels

quý khách hàng học tập một thiết bị gì đấy, hoặc làm cho một thiết bị gì đó có thể không hiểu ngay nhưng lại cho đến lúc đựng một lượng kỹ năng, kinh nghiệm tay nghề bất biến, các bạn sẽ bất thần thấu hiểu nó. Do vậy, giả dụ hầu như định nghĩa về Inversion of Control dưới trên đây thừa trìu tượng, cực nhọc hiểu bạn cũng chớ thừa quan tâm, cho một ngày nào kia khi bạn xây dựng đủ 100 dự án, tất cả 10 năm “giờ đồng hồ bay” vào lập trình… tự nhiên vẫn đọc. Cthị trấn pthi thoảng vậy thôi, tiếng chúng ta cùng vào phần chính của nội dung bài viết nhé. Định nghĩa nguyên tắc Inversion of Control

Inversion of Control (IoC) là một cách thức thi công trong công nghệ ứng dụng cùng với gần như đoạn code Lúc gửi vào trong 1 framework vẫn nhấn được luồng tinh chỉnh tự framework giỏi nói một cách thức khác là đc framework điều khiển và tinh chỉnh. Kiến trúc vận dụng cùng với xây cất này sẽ đảo ngược quyền tinh chỉnh so với lập trình sẵn phía giấy tờ thủ tục cổ điển. Trong lập trình truyền thống đông đảo đoạn code sản xuất sẽ hotline các thư viện tuy vậy với IoC, framework đang Hotline phần nhiều mã thêm vào.

Martin Fowler

Nói thiệt, tôi cũng cố gắng nỗ lực đặt ra định nghĩa này về ngữ điệu con fan hoàn toàn có thể hiểu đc dẫu vậy nó vẫn quá trìu tượng hoặc vì tôi chưa đủ “giờ đồng hồ bay” đề nghị cũng chỉ tạm ngưng tại một khái niệm như vậy. Tôi đã và đang test thăm dò rất nhiều quan niệm không giống trên Intetuy vậy cũng chỉ thừa nhận được một câu: “Cực cực tốt bạn nên quên nó đi”. Lại nói về phương thức dìm thức một vấn đề, theo cách nhìn phép duy đồ vật biện chứng, hoạt động dìm thức của nhỏ bạn đi trường đoản cú trực quphúc lợi an sinh rượu cồn mang đến tứ duy trừu tượng, và từ tư duy trừu tượng mang lại thực tế. Nói Kết luận nếu như các bạn bước vào cái định nghĩa chết tiệt này ngay thì là 1 trong sai lầm vào cách thức dò xét về một vấn đề.

Chém nhẹm gió thôi nhé, Triết học ngày xưa bản thân thi lại đến lần thiết bị 3 bắt đầu qua :).

2. Trực quan sinh rượu cồn về IoC

Inversion of Control là một trong sự “thi phường” vào bài toán mở rộng một framework, một đặc tính trong những framework. Các chúng ta thuộc xem một ví dụ dễ chơi về công tác nhập thông tin người tiêu dùng theo kiểu thủ tục cổ điển:

khi chạy phần mềm này vào màn hình hiển thị loại lệnh, phần nhiều chiếc code của các bạn đang có quyền điều hành và kiểm soát, nó quyết định đc dịp như thế nào đặt thắc mắc, thời gian như thế nào đọc dữ liệu người sử dụng nhập khẩu and cơ hội như thế nào giải pháp xử lý hầu hết hiệu quả này.


*

Tiếp tục, chúng ta viết lại phần mềm bắt buộc thực hiện framework Laravel sinh hoạt dạng giao diện hình ảnh. Sự biệt lập to tuyệt nhất thân nhị phần mềm đây là luồng điều khiển và tinh chỉnh (flow of control). Trong lịch trình mẫu lệnh, chúng ta kiểm soát đc cơ hội như thế nào đông đảo cách thức đc hotline, tuy nhiên trong vào công tác dạng đồ họa thì không. Framework đã kiểm soát bài toán kia bởi một vòng lặp liên tục check xem gồm dữ liệu làm sao được nhập vào không? cũng có thể chúng ta nhập nghề nghiệp và công việc trước khi nhập thương hiệu. Như cầm cố, vào ứng dụng lắp thêm nhị quyền tinh chỉnh đã bị đảo ngược, quyền kiểm soát vẫn được về framework.


*

Đó đó là một ví dụ trực quan về nguyên tắc Inversion of Control, phương pháp này làm fan ta hệ trọng mang lại một nguyên tắc lúc thao tác trong Hollywood “Đừng Gọi mang lại Cửa Hàng chúng tôi, công ty chúng tôi đang điện thoại tư vấn mang đến bạn”. quý khách hàng vẫn phát âm được IoC là gì? mà lại tôi thì chưa, thiệt sự nó vẫn …éo thể đọc đc. Tạm thời gác qua Việc đó, các bạn yêu cầu thêm “lượng” để cho với bước khiêu vũ vọt về “chất” sinh sống cuối bài xích.


Một quan trọng đặc biệt đặc biệt của framework là đều phương thức được tư tưởng vì chưng người tiêu dùng đôi khi được call từ bỏ vào bản thân framework chđọng không phải tự code ứng dụng của người tiêu dùng. Framework vào vai trò của chương trình bao gồm vào câu hỏi điều hướng và sắp xếp chuyển động phần mềm. Sự đảo ngược quyền kiểm soát điều hành này tạo nên đến framework sức mạnh trải qua bài toán mở rộng. Những cách thức được viết do người tiêu dùng quan niệm rất nhiều thuật toán trong framework cho một tính tân oán cụ thể. Inversion of Control đến cảm nhận thấy sự biệt lập giữa một framework and một thỏng viện.

Một thư viện chỉ cần tập vừa lòng phần nhiều công suất mà lại chúng ta có thể bắt buộc sử dụng, nó đc tổ chđọng thành các class. Sau mỗi lần hotline một phương pháp, tlỗi viện đang làm cho một số câu hỏi và kế tiếp trả quyền tinh chỉnh về cho những người thực hiện.

Framework là một tín hiệu của xây dựng trìu tượng với khá nhiều hành động được thành lập và hoạt động sẵn phía bên trong, để đề nghị áp dụng nó bạn phải cnhát số đông hành vi của người sử dụng vào đa số vị trí khác biệt vào framework bằng hầu như class hoặc plugin. Code của framework sẽ điện thoại tư vấn mang đến code của bạn trên các điểm cần thiết.

Có những phương pháp để các bạn đưa thêm mã vào framework, trong ví dụ bên trên chúng ta nên áp dụng một textbox, bất kể thời điểm như thế nào, textbox phát hiện sự kiện người tiêu dùng nhập liệu, nó sẽ bị Hotline đến những code vào một “bao đóng”. Một cách thức không giống để triển khai điều đấy là nhằm framework quan niệm hầu như sự kiện and code fan đang đăng ký vào các event này. Trong Laravel, bạn có thể tạo ra một event Khi thao tác làm việc với một quãng code của tôi & framework có qui định điều hành và kiểm soát phần lớn sự kiện kia, giỏi nói phương pháp không giống bạn đã ủy quyền lại cho framework.

Những giải pháp tiếp cận là tốt nhất có thể, nhưng mà thường thì bạn muốn kết hợp nhiều lời Hotline phương pháp vào một đơn vị mở rộng, framework nên có mang một interface nhằm client code yêu cầu xúc tiến nó mang đến hầu hết lời điện thoại tư vấn phương pháp tác động. Đây đấy là chế độ đóng msinh hoạt vào cách thức SOLID cho thi công hướng đối tượng người dùng người tiêu dùng.

Thực sự các bạn làm sao đọc đc đến đoạn này tôi đề nghị khôn xiết cảm phục vị sự kiên trì của chúng ta, tuy vậy một đợt tiếp nhữa cặp phạm trù nguim nhân và kết quả rất đáng nhằm để chúng ta yêu cầu nỗ lực. Nguyên ổn nhân: các bạn kiên nhẫn tống vào đầu mớ lý thuyết trìu tượng này, kết quả: mang đến cuối bài xích các bạn hiểu được “Inversion of Control là gì?”.

Trong cái trực quan lại tất cả cái trực quan tiền hơn, vậy tìm mẫu đơn giản nhất để phát âm trước rồi đọc chiếc khó khăn sau. Nếu bạn đã thăm dò sơ lược về IoC bên trên mạng, bạn sẽ cảm thấy bao gồm cả một rừng số đông thuật ngữ tác động như Dependency Inversion Principle (DIP), Dependency Injection Pattern (DI), IoC Container. Khá là khó để nhận ra hầu như khái niệm này, chúng ta đề xuất một khẩu quyết tiềm ẩn cả một tàng tlỗi.

DI is about wiring, IoC is about direction, cùng DIPhường. is about shape.


IoC là phía đi và DIPhường là định hình chi tiết của phía đi còn DI là 1 trong thực hiện chi tiết.

Xem thêm: 7 Bí Quyết Gửi Tiền Tiết Kiệm Hàng Tháng Cho Người Có Thu Nhập Trung Bình

Khẩu quyết này tạm bợ vẽ thành quyết hình ảnh mang lại dễ lưu giữ.


*

Đến trên đây vững chắc bạn đang hài lòng với tôi: “Inversion of Control là hiệ tượng của không ít nguim tắc”.

3. Inversion of Control được hiện ra điều đó nào?

Thỉnh phảng phất chúng ta tự hỏi, đầy đủ vẻ ngoài nhỏng IoC, SOLID… được ra đời điều đó nào? Tại sao tín đồ ta có thể nghĩ về ra chúng? Quay trở lại cùng với lập trình sẵn phía đối tượng người dùng người dùng là một phương pháp giải quyết đều vụ việc theo bốn duy hướng đối tượng người dùng người tiêu dùng. Phương thơm thức thức này tế bào phỏng tựa như thế gới không tính đời, do thế hầu như bề ngoài thiết kế vào cuộc sống thật đầy đủ rất có thể gửi vào vào thiết kế. Tiếp theo chính là một ví dụ tôi phát âm đc từ bỏ cuốn Dependency Injection in .NET, một cuốn sách phân tích và lý giải tương đối xuất xắc về phần đa có mang IoC, DI, DIP…

Trong cách thức cuối cùng Dependency Inversion của SOLID chúng ta tất cả nói đến một ví dụ về một mẫu đèn để bàn có dây năng lượng điện được đấu nối trực tiếp vào ổ năng lượng điện vào tường nhưng mà ko qua ổ cắn and phích gặm, còn trong ví dụ này các bạn nuốm nó bởi cái máy sấy tóc. Tình huống này đến cảm nhận thấy vấn đề khôn cùng to Lúc số đông đối tượng người sử dụng người tiêu dùng dựa dẫm chặt chẽ cùng nhau trong xây dựng.


*

Trong một đợt đi motel thuộc bạn gái (giả tưởng thôi nhé), tôi đã đơ bản thân khi nhìn cảm nhận thấy hình hình họa chiếc máy sấy đc nối trực tiếp vào trong ổ năng lượng điện cơ mà không trải qua ổ cắn & phích cắn. Mục đích thì đã rõ, những kẻ ham mê táy sản phẩm vẫn “tắt điện” khi quan sát cảm thấy chình ảnh này. Nhưng cthị trấn gì đang xảy ra lúc chiếc máy sấy này hỏng, dù nó tất cả là sản phẩm Nhật xịn cơ mà cũng có phần nhiều lúc hỏng chứ đọng.


*

Để thay thế sửa chữa là khá khó khăn, trước tiên chúng ta cần ngắt át-tô-non, tiếp đến msinh sống chiếc tủ biến thế ra và cố cái máy sấy new vào. Ông thợ làm sao ko cẩn thận có thể không bật điện lên nhằm kiểm tra xem chiếc máy bắt đầu cụ có hoạt động ko. Trong lập trình cũng thế, trường hợp hầu như module dựa dẫm chặt chẽ vào với nhau (thường thực hiện thuật ngữ tightly coupled) thì lúc 1 module gồm vụ việc, cả khối hệ thống đang rối tung, cực nặng nề nhằm bảo trì & trở nên tân tiến.


Thỉnh thoảng, chẳng ai chạy dây đầy đủ cơ chế điện thẳng trực tiếp vào hệ thống điện, nuốm vào này là phải áp dụng một phích cắm & ổ gặm. Một ổ gặm là một trong interface với chuẩn chỉnh cắn đề nghị cân xứng cùng với dáng dấp phích cắn. Như nạm, thứ sấy tóc với ổ cắm & phích cắm đã hình thành một kết nối không phụ thuộc (loosely coupled). cũng có thể có rất nhiều phương thức phối hợp số đông biện pháp điện này với nhau để ra một khối hệ thống. Trong xây dựng việc phối hợp này rất có thể đối chiếu cùng với thiết kế pattern and hầu hết cách thức thiết kế.

Máy sấy tóc sẽ đã không còn gì khác ràng buộc cùng với hệ thống điện, trường hợp các bạn cần ổ điện mang đến laptop, dễ chơi là rút đồ vật sấy ra và cắn máy tính xách tay vào ổ cắm. Những công ty kiến thiết ổ cắm ko âu yếm đến qui định năng lượng điện nlỗi máy tính xách tay, Smartphone, tivi… cơ mà hầu như luật pháp này vẫn chuyển động cực tốt khi cắn vào. Những chế độ khác nhau hoàn toàn có thể gặm vào ổ cắn nhưng mà ko liên quan gì cũng tương tự nhỏng phép tắc thay thế sửa chữa Liskov trong kiến thiết vận dụng. Trong Dependency Inject, cơ chế Liskov là một trong những trong các bề ngoài đặc trưng, nó được phép vừa lòng các mong ước sau này thậm chí còn các bạn chưa biết đến gì về nó vào hiện nay. Tương từ bỏ nhỏng vào trong thực tiễn, trường hợp 10 năm nữa cất một giải pháp năng lượng điện mới thì nó vẫn cắn vào chiếc ổ gặm này cơ mà không nhất thiết phải chỉnh sửa bên trong.


Lúc pin máy tính đầy, các bạn sẽ rút ít phích cắn của sản phẩm máy tính ra và chuyển sang áp dụng pin. Trong lập trình, các bạn luôn nhu cầu một service/module/class làm sao này là đang sống, giả dụ nguyên tố này đã đc gỡ quăng quật, các bạn sẽ chạm chán lỗi NullReferenceException, với ngôi trường hòa hợp này những bạn sẽ tạo ra một interface nhưng mà nó không làm những gì. Đó chính là một thiết kế pattern đc biết đến với thương hiệu là Null Object, nó ưng ý vấn đề rút ít phích cắm ra khỏi tường.


Mọi điều hoàn toàn có thể xẩy ra, nếu như khối hệ thống năng lượng điện của tất cả khu sẽ gặp mặt vụ việc, các bạn sẽ đề nghị mang đến một cỗ giữ điện UPS nhằm vẫn vận động được thêm một thời gian. Máy máy vi tính & bộ giữ năng lượng điện có các nhiệm vụ khác nhau, phía trên đây là nguyên tắc đối kháng tác dụng (single responsibility) trong xây đắp ứng dụng. Cả UPS & laptop gần như được chế tạo vị phần đông nhà máy sản xuất không giống nhau, được tải sinh sống những thời hạn khác biệt tuy vậy có thể buộc phải thực hiện kết hợp đc với nhau, thậm chí còn chúng ta cũng có thể gặm cả vật dụng sấy tóc khi máy tính không gặm vào cỗ giữ năng lượng điện.


Một thực tế là các kinh nghiệm luôn luôn sửa đổi, đầy đủ hệ thống luôn luôn không ngừng mở rộng & đề nghị thêm công suất, câu hỏi mở rộng nhiều lúc chỉ là phương thức thêm ghép đầy đủ nhân tố cùng với nhau theo các cách thức khác biệt. Decorator pattern là mẫu mã xây dựng cứu thêm công năng cho 1 class nhưng mà ko cần viết lại hoặc sửa đổi hầu như code bao gồm sẵn. Một cách thức không giống nhằm thêm công năng mới vào một code có sẵn là tổng hợp phần lớn implement hiện nay bao gồm cửa ngõ một interface bắt buộc thực hiện Composite pattern. Với bài toán yêu cầu thực hiện ổ cắn nhiều năm, các bạn cũng có thể cung cấp hoặc tiết kiệm hơn phần lớn luật pháp điện đề xuất chạy. Với thuộc phương pháp này Composite pattern dễ dàng thêm giảm công suất bằng phương pháp chỉnh sửa tập đều interface.


Thỉnh phảng phất các bạn cất một cách thức được download ở quốc tế với chuẩn chỉnh đầu gặm khác cùng với ổ cắn đang có, các bạn đề nghị một cỗ convert. Adapter pattern cũng triển khai cùng một trách nhiệm cùng với hầu như bộ convert. Chỉ với cùng một ví dụ thực tế về hệ thống điện dễ chơi, các bạn đã cảm nhận thấy có rất nhiều rất nhiều phát minh vẫn được xúc tiến ngơi nghỉ trong cố kỉnh gới phía đối tượng người dùng người dùng vào xây dựng.


4. Tại sao sử dụng Inversion of Control

Cthị trấn phiếm, ba hoa dĩ nhiên bao nhiêu cốc tkiểm tra đá rồi cơ mà vẫn không còn gọi được đã nói về vật dụng gì? Hic…

Ngay bao gồm trong tư tưởng Inversion of Control đang nói yêu cầu mục đích thiết yếu của hiệ tượng này này là tính mở rộng của một hệ thống. Quay lại với mẩu truyện về đồ vật sấy tóc, đa số xây dựng ngơi nghỉ không tính đời cứu giúp đến việc không ngừng mở rộng một khối hệ thống là vượt dễ chơi. Trong lập trình sẵn cũng vậy, nhờ vào triển khai những định hình chi tiết từ bỏ gần như cách thức, một khối hệ thống phần mềm sẽ có tính không ngừng mở rộng. Nhưng nhằm đạt được tính mở rộng mang đến một phần mềm thì đầu tiên ứng dụng này đề xuất đào thải sự nương tựa giữa một đối tượng người tiêu dùng người dùng này với 1 đối tượng người sử dụng người dùng khác.

Tính mở rộng hoàn toàn có thể mở rộng ra không chỉ có thế sống khía cạnh gia hạn và cách tân và phát triển phần mềm. Một hệ thống có thiết kế đơn giản đang dễ không ngừng mở rộng rộng một khối hệ thống khó khăn. Ngoài ra đầy đủ khối hệ thống bắt buộc áp dụng lý lẽ Inversion of Control đang dễ dãi vào kiểm thử phần mềm vị phần đa thành phần gồm sự tự do định hình.

Xem thêm: Bản Đồ Quy Hoạch Tây Hồ Tây, Thông Tin Quy Hoạch Tại Tây Hồ

5. Quán mang lại giờ tạm ngưng hoạt động, hết trà soát đá!

“Em ơi! Anh thêm ly nữa đê…”, ko một giờ đồng hồ đáp lại, mồm thô đắng, giọng gằn lên “Chủ quán…”, mịa nó chứ vẫn lạng lẽ như tờ, khom xuống định vớ đại nhỏ Chaco 81 lỗ quăng vào… Úi thừa nửa đêm roài, bé mưa liên quan bão cũng đã tạnh, chỉ từ chút gió vi vu… “Quán đến giờ đồng hồ tạm dừng chuyển động, hết trà đá!” tiếng nói lanh lảnh cất lên từ một khuôn phương diện bây bi con bà nhà cửa hàng.

Mải khoác lác, giờ đồng hồ new lưu giữ ra, bắt đầu đc nửa đoạn đường từ trực quan đến bốn duy trìu tượng. Thế còn trường đoản cú tứ duy trìu tượng mang đến thực tiễn, thôi hứa hẹn bữa không giống mạn đàm tiếp…

Thể Loại: Share Kiến Thức Cộng Đồng
Bài Viết: Inversion Of Control Là Gì, Inversion Of Control, Di Là Gì

Thể Loại: LÀ GÌ

Nguồn Blog là gì: https://timhome.vn Inversion Of Control Là Gì, Inversion Of Control, Di Là Gì