A, about@property
Let’s think about a couple of things
delegateWhy attributes are usedweak? Why are xib/ Storybard connected objects usedweak? Why strings are usedcopy?BlockWhy usecopy?Copy the code
1.A: the delegateweakThe modifier is to avoid circular references2.A: Because control his "dad" view. Superview hasstrongReference, your viewController just needsweakThe reference3.A: Because it is usually usedcopyThe way. Although usingstrongThere are no problems, but in fact they are all used in developmentcopy. Why do you do that? Because with strings, we want a copy of the content, and external changes won't affect our original values, andNSStringThe class has complied with theNSCopying.NSMutableCopying.NSSecureCodingThe agreement.4.A: Blocks are initially placed on the stack, onlycopyAnd then you put it on the heapCopy the code
@property is a syntax for declaring properties, which makes it quick and easy to create accessors for instance variables, and allows us to use accessors via point syntax.
- Accessors: Methods used to get and set instance variables. The accessors used to get the value of an instance variable are getters, and the accessors used to set the value of an instance variable are setters.
- At sign property is the same thing as declaring the get/set method of instance variables in a.h file, and at sign synthesize is the same thing as implementing the get/set method of instance variables in a.m file. It’s easier to create an accessor using @Property and synthesize than to declare two access methods (getters and setters) manually. Moreover, we can assign or value attributes using point syntax, which is simpler and more object-oriented programming.
- @property also has some keywords that have special functions, such as nonatomic, strong in the code above. I’ve divided them into three categories: atomicity, accessor control, and memory management.
atomic
Atomic (default) : Atomic means that the operation is atomic, meaning that only one thread accesses the instance variable. Atomic is thread-safe, at least on the current accessor.
Nonatomic: Nonatomic is the opposite of atomic. Represents non-atomic and can be accessed by multiple threads. It’s faster than atomic. However, it is not guaranteed to be safe in multi-threaded environments, and is widely used in single-thread and explicitly only one-thread access situations.
Accessor control
Readwrite (default) : Readwrite is the default, indicating that this property has both a setter and a getter. Readonly: Readonly indicates only getters but not setters.
Memory management
Assign (default) : Assign is used for value types such as int, float, double, and NSInteger. CGFloat, for example, represents pure copy. It also includes objects that do not have ownership, such as the common delegate. Retain: In setter methods, a reference count increment of one is required on the passed object. In simple terms, you have ownership of an object that is passed in, and as long as you have ownership of that object, it will not be released. (rarely used now because it’s all ARC)
- (void)setName:(NSString *)_name
{
// First check if it is consistent with the old object, if not, assign.
// Because if is an object, the code inside if would result in an extreme case: when the retain of the name is 1, the set operation would release the instance name prematurely and fail to achieve the assignment purpose.
if ( name! =_name){
[name release];
name = [_nameretain]; }}Copy the code
Strong: Strong is a keyword that was introduced when ARC was introduced in iOS and is an optional alternative to Retain. Indicates that the instance variable has ownership of the passed object, that is, a strong reference.
Weak: In setter methods, you do not need to increment the reference count of the passed object by one. In simple terms, there is no ownership of the object passed in. When the object reference count is 0, that is, after the object is released, the instance variable declared with weak points to nil, that is, the value of the instance variable is 0. Copy: Similar to strong, but the instance variable has ownership of a copy of the passed object, not the object itself.
Second, the RunTime
1. RunTime refers to the mechanisms used by the system during operation, of which the message mechanism is the most important. 2. For C language, function calls will determine which function to call at compile time, and execute directly after compile, without any ambiguity. 3. The OC function call becomes message sending. Is a dynamic call procedure. It is not determined at compile time which function is actually called. (As it turns out, OC can call any function at compile time, even if the function is not implemented, as long as it is declared without error. C generates an error at compile time. 4, only in the real run time will be based on the name of the function to find the corresponding function to call.
- Commonly used in our code
* Dynamically add object member variables and methods* Dynamically swap implementations of the two methods* Intercept and replace methods* Add extra functionality to methods* NSCoding automatic archiving and filing* Realize automatic conversion of dictionary to modelCopy the code
This piece is too big for your reference:
Runtime introduction and application details
Third, RunLoop
- What is a RunLoop? Our mobile application is an event-driven architecture, so if our application is always alive, if nothing is going on, if something wakes it up, then it allocates and executes events, and then exits when it dies. A RunLoop is an infrastructure part of a thread, and each thread has a corresponding RunLoop object. It is used to accept events in the loop and schedule the thread to work, and to put the thread to sleep when there is no work.
The role of the RunLoop
1, keep the program running and accepting user input2Decide when the program should handle those events.3, call decoupling (Message Queue) ---- Caller and caller, how is Message Queue arranged4, save CPU time ---- nothing when idleCopy the code
Mode type of RunLoop
NSDefaultRunLoopMode :By default, no sliding, idle, and the program will be switched to this mode when it startsUITrackingRunLoopMode :When you slideUIInitializationRunLoopMode:Private, traceable, the app starts in this mode and returns to the first mode after the first page loadsNSRunLoopCommonModes:The default includes the first and the second, in which case both can be executedCopy the code
For details, please see Sun Yuan @sunnyxx video RunLoop introduction YYKit author in-depth understanding RunLoop
NSThread, NSOperation, GCD
- IOS has three kinds of multithreaded programming technologies, which are from top to bottom and the level of abstraction is from low to high. The higher the abstraction is, the easier it is to use, which is also the most recommended by Apple.
- Nsthreads: NsThreads are lightweight and relatively simple, but require manual management of all thread activities, such as life cycle, thread synchronization, and sleep
- NSOperation: has its own thread cycle management, operation can pay more attention to its own logic, but the object-oriented abstract class, can only implement it or use its defined two subclasses: NSInvocationOperation and NSBlockOperation.
- GCD: Most efficient, avoids the concurrency trap. Therefore, it is generally simple and safe to choose NSOperation to achieve multithreading. While processing a large number of concurrent data, and the pursuit of performance and efficiency of the choice of GCD. Thread creation Thread Safety Thread Communication Thread status GCD(1) GCD(2)
Block, Delegate, Notification
- Delegate: one-to-one. An object can only have one Delegate for the same protocol, so a singleton object cannot use a Delegate.
- Notification: “one to many”. In the APP, many controllers need to know an event and should use Notification. But notifications need to be removed in time.
- Block: More succinct, blocks focus on the transmission of results: for example, for an event, you just want to know whether it succeeded or failed, not how much or extra information went into it. Blocks need to be careful to prevent circular references. Use of proxy Use of notification broadcast Use of Block (1) Use of Block (2)
UDP, TCP, Socket, HTTP, POST, GET
Here’s a graph to see the differences between TCP and UDP:
- TCP is the transmission control layer protocol, for connection-oriented, reliable, point-to-point communication;
- UDP is a user datagram protocol, unconnected and unreliable point-to-multipoint communication.
- TCP focuses on reliable transmission, while UDP focuses on fast transmission.
Three-way handshake for TCP connection* First handshake: The client sends a SYN packet (SYN = J) to the server and enters the SYN_SEND state.* Second handshake: After receiving a SYN packet, the server must acknowledge the client's SYN (ACK = J +1) and send a SYN packet (ACK = J +1). In this case, the server enters the SYN+RECV state.* Third handshake: After receiving the SYN+ACK packet from the server, the client sends an ACK packet (ACK = K +1) to the server. After this packet is sent, the client and the server enter the ESTABLISHED state.Copy the code
The difference between a Scoket connection and an HTTP connection:
HTTP is an application layer protocol based on TCP connections. It mainly deals with how to package data. The Socket is the encapsulation of TCP/IP. The Socket itself is not a protocol, but an API. Through the Socket, we can use TCP/IP.
HTTP connection: A short connection. The client sends a request to the server. The server responds and the connection is disconnected, saving resources. The server cannot actively respond to the client (unless using HTTP long connection technology), and the iPhone mainly uses the class NSURLConnection.
Socket connection: long connection, the client and server directly use Socket connection, there is no provision for the connection after the disconnect, so the client and server maintain the connection channel, both sides can actively send data, generally used for games. The default connection timeout period of the Socket is 30 seconds, and the default size is 8K (understood as a packet size).
GET and POST
- HTTP: hypertext transfer protocol (HTTP) is a short connection in which the client sends a request and the server responds. After the server responds, the connection is disconnected. HTTP is an object – oriented protocol at the application layer. HTTP has two types of packets: request packets and response packets.
- HTTP request packet: an HTTP request packet consists of four parts: request line, request header, blank line, and request data.
-
An HTTP response packet consists of a status line, a message header, and a response body.
-
GET:GET request: Parameters are concatenated after the address, no request data, unsafe (because all parameters are concatenated after the address), not suitable for transferring large amounts of data (limited length, 1024 bytes). GET submits and requests data that is appended to the URL, placing the data in the HTTP header.
-
POST: POST request: The parameters are placed in the request data area, which is more secure than GET requests, and the data size is unlimited. Put the submitted data in the body of the HTTP package.
* GETThe submitted data will be displayed in the address bar, and the address bar will not change for POST submissions. *GETRequests can be cached; POST requests cannot be cached. *GETRequests are saved in the browser's browsing history, POST requests are not saved in the browser's browsing history *GETWhen submitting, the data transmitted will be limited by the URL length. Since the POST is not transmitted through the URL, the book is theoretically not limited. * POST is more secure thanGETHigh security;Copy the code
HTTPS: Secure Hypertext Transfer Protocol (Secure Hypertext Transfer Protocol) is a Secure communication channel developed based on HTTP for the exchange of information between client computers and servers using Secure Word Layer (SSI), the Secure version of HTTP. See Ruan yifeng’s weblog for details
Seven, brief memory partition situation
* Code area: store function binary code* Data area: the memory is applied for and initialized when the system is running, and released by the system when the system exits, storing global variables, static variables and constants* Heap area: through malloc and other functions or operators such as new dynamic application to obtain, programmers need to manually apply and release* Stack area: function module application, function at the end of the system automatically released, storage of local variables, function parametersCopy the code
Ps: The difference between stack and heap
Space on the stack is allocated/freed automatically by the operating system and space on the heap is allocated/freed manually. Stack space is limited and heap is a large free storage area. In CmallocThe memory allocated by a function is on the heap, which in C++ corresponds tonewOperators. The program allocates memory for variables and functions on the stack at compile time, and the parameters of function calls are passed on the stack during program execution.Copy the code
Distinguish between the following Pointers
const char *p;
char const *p;
char * const p;
const char * const p;Copy the code
* const char*p defines a character pointer to an immutable string.const char* is the type and p is the variable. *char const*p is the same as the last one. *char * constP defines a pointer to a string whose value cannot be changed, that is, the pointer cannot be changed. So look:char* is the type,constP is the modifier variable p, that is, p is a constant *const char * constP defines a character pointer to an immutable string, and the pointer is immutable. This one is easy to see. twoconstModified separately and therefore immutable.Copy the code