Skip to main content

Giới thiệu công cụ FLEX để debug mọi thông tin ngay trên simulator hoặc thiết bị iOS

Chào các bạn hôm nay mình xin giới thiệu đến các bạn 1 tool dùng để debug mọi thông tin như cấu trúc, vị trí, thuộc tính của những đối tượng trong 1 màn hình, có thể xem system logs, network, caches, file browser... trực tiếp ngay trên simulator / thiết bị iOS, mà không cần dùng XCode. Khi bạn thiết lập tool này, bạn có thể biết được mọi hành vi mà người lập trình đang làm trên ứng dụng này mà không cần phải coi code.

Công cụ này có tên là FLEX ( là từ viết tắt của Flipboard Explorer). Công cụ này rất dễ cài đặt và sử dụng, bạn chỉ nên sử dụng tool này cho chế độ Debug thôi. Mình sẽ giới thiệu sơ qua những chức năng chính của tool này như sau:

1. Có thể thay đổi vị trí của đối tượng:

Hình bên dưới đây minh họa cách công cụ này có thể tương tác những đối tượng trên màn hình như chọn và thay đổi vị trí của đối tượng trên màn hình. Bạn bạn chạy simulator thì nhấn phím "f" để mở thanh công cụ hoặc có thể tạo 1 button là "FLEX" để hiển thị thanh công cụ lên (code hiển thị sẽ đề cập bên dưới) và thao tác như sau:

2. Xem thuộc tính và những biến ivar của đối tượng:

Bạn vào màn hình chính của FLEX, và chọn chức năng như UICatalog Classes, AppDelegate, UINavigationController, [UIApplication keyWindow]:

3. Thay đổi thuộc tính và biến ivar của đối tượng:

Ví dụ mình có thể thay đổi nội dung font, color của label.

4. Quản lý lịch sử khi sử dụng network:

Bạn dùng chức năng này để xem ứng dụng này đã tải về những file nào và dùng bao nhiêu dung lượng rồi.

5. Xem nội dung đã được in ra bằng NSLog:

6. Xem được những files trong thư mục của ứng dụng:

7. Xem dữ liệu caches:

8. Xem những đối tượng trong bộ nhớ Heap:

9. Xem những giá trị trong NSUserDefault:

10. Xem những thư viện trong system:


Ngoài ra còn nhiều chức năng khác nữa các bạn có thể sử dụng và khám phá thêm.

Cách cài đặt thư viện:

Bạn cài đặt FLEX chỉ thiết lập cho chế độ Debug và thông qua cocoapods như sau:
pod 'FLEX', '~> 2.0', :configurations => ['Debug']
FLEX bắt buộc iOS từ 7.0 trở lên.

Sau khi cài thư viện thành công, bạn vào phần build settings của project và nhấn nút "Add User-Defined Setting" để thêm đoạn config:
bạn thêm key "EXCLUDED_SOURCE_FILE_NAMES" với giá trị ở chế độ Release như "FLEX*":
Các bước thiết lập trên để khi build bản Release nó sẽ bỏ qua những file trong framework FLEX.

Cách sử dụng thư viện FLEX:

Nếu bạn muốn mở tool này trên device thì bắt buộc phải thiết lập 1 button để mở tool FLEX lên như những ví dụ ở trên thì để ở màn hình Home, nếu ứng dụng của bạn có màn hình setting thì có thể để trong đó cũng được.
Code gọi tool FLEX lên khá đơn giản như sau:
[[FLEXManager sharedManager] showExplorer];

Và khi viết code bạn nên để nó trong Macro của Debug như sau:
#if DEBUG
#import "FLEXManager.h"
#endif

...

- (void)handleSixFingerQuadrupleTap:(UITapGestureRecognizer *)tapRecognizer
{
#if DEBUG
if (tapRecognizer.state == UIGestureRecognizerStateRecognized) {
// This could also live in a handler for a keyboard shortcut, debug menu item, etc.
[[FLEXManager sharedManager] showExplorer];
}
#endif
}
Nếu ứng dụng của bạn viết bằng ngôn ngữ Swift thì phải vào màn hình build setting và tìm từ khóa "Swift Compiler", thêm giá trị "-D DEBUG" vào phần Debug như sau:
Nguồn tham khảo tại đây.

Nếu bạn chạy trên Simulator thì có những phím tắt để bạn có thể mở thanh công cụ lên một cách nhanh chóng như:
- Nhấn phím "?" để mở màn hình hướng dẫn các phím tắt.
- Nhấn phím "f" để mở/tắt thanh công cụ.
- Nhấn phím "g" để mở màn hình globals.
- Nhấn phím "m" để thực hiện hành động di chuyển đối tượng.
- Nhấn phím "n" để vào màn hình xem lịch sử network.
.... Các bạn có thể xem thêm tại màn hình shortcuts.
Bạn có thể tải ví dụ demo tại đây.

Comments

Popular posts from this blog

So sánh những framework hỗ trợ viết ứng dụng trên SmartPhone

Khi lập trình trên SmartPhone bạn không nhất thiết phải học những ngôn ngữ đặc thù trên từng loại hệ điều hành thì mới có thể lập trình được. Ví dụ như muốn lập trình trên iOS thì phải học ngôn ngữ Objective-C hay Swift, muốn lập trình được trên Android thì học ngôn ngữ Java, muốn lập trình trên WinPhone thì học ngôn ngữ C#. Hiện nay có rất nhiều những framework giúp đỡ cho các bạn rất nhiều khi các bạn muốn viết trên nhiều nền tảng smartphone bằng ngôn ngữ mà bạn yêu thích. Theo mình thấy thì hiện nay có 3 loại như: Native App, Hybrid Mobile App, Native Cross-Platform App. 1. Native App: là những ứng dụng sử dụng những framework và ngôn ngữ lập trình của hệ thống cung cấp sẵn. Ví dụ như bạn muốn lập trình iOS thì phải cài XCode, học ngôn ngữ Objective-C hay Swift, lập trình Android thì cài Android Studio và học ngôn ngữ Java. - Ưu điểm: Hiệu năng thực thi ứng dụng trên nền tảng nhanh và hiệu quả. Không bị phụ thuộc vào bên thứ 3. Khi phát hành ứng dụng trên những Mobile Store cũng dễ...

Hướng dẫn dùng Serverless sử dụng Lambda AWS

1. Lambda function là gì? AWS Lambda cho phép bạn chạy mã mà không cần cung cấp hay quản lý máy chủ. Bạn chỉ phải trả tiền cho thời gian xử lý thông tin đã sử dụng. Với Lambda, bạn có thể chạy mã cho gần như toàn bộ các loại ứng dụng hay dịch vụ backend – tất cả đều không cần quản trị. Chỉ cần tải đoạn mã của bạn lên và Lambda sẽ lo hết những gì cần làm để chạy và mở rộng mã của bạn với mức độ có sẵn cao. Bạn có thể thiết lập mã của bạn tự động kích hoạt từ các dịch vụ AWS khác, hoặc gọi trực tiếp từ bất cứ ứng dụng web hay di động nào. Chi phí chạy trên lambda function rẻ so với chi phí bạn mua 1 con server, duy trì và quản trị nó ( ví dụ như bạn phải xử lý bất đồng bộ những request, khi lượng user bạn tăng đột biến bạn phải có cơ chế auto scale, chứ không thì server bị sẽ bị treo, khi server bị treo bạn phải tự động khởi động lại sẽ mất thời gian,... ).

(Kinh nghiệm) Về static library và static framework trên iOS

Trước XCode 6 ra đời thì đa số mọi người muốn viết những code chung trong static library để có thể dùng cho nhiều project. Có những người tạo project là static library nhưng khi build thì tạo folder có đuôi là .framework để add những file header và static library vào. Nhưng thực chất nó cũng chỉ là static library. Vì khi bạn muốn tích hợp những static library khác vào project static library mà bạn đang làm thì sẽ gặp nhiều vấn đề xảy ra. Vì thế khi bạn làm project framework mà có tích hợp những static library khác vào thì nên khởi tạo project theo dạng framework (Cocoa Touch Framework) như sau: Bạn có thể xem hướng dẫn từng bước tạo framework và tích hợp framework đó vào project tại đây . PS: Nếu bạn không muốn viết kiểu này thì chỉ có thể tích hợp nhiều static library trong application project. Hoặc có thể viết static library tích hợp vào cocoapods để tích hợp và update cho thuận tiện, có thể tham khảo cách làm tại đây .