【Cocoa and Object-c : Up and Running 笔记】03 Simple C for Object-c

简介: 一、基本概念       1、变量:变量是存放一块数据的容器。变量有类型,用于描述变量所包含的数据的种类。c中的变量内置基本类型有int、unsigned int、float、char、double和long。

一、基本概念

      1、变量:变量是存放一块数据的容器。变量有类型,用于描述变量所包含的数据的种类。c中的变量内置基本类型有int、unsigned int、float、char、double和long。

      2、常量:一旦赋值后就不能改变的量。c中用const关键字声明。

      3、枚举类型enum、类型定义typedef 。

      4、函数:声明函数、返回值、参数、调用函数。

      5、静态变量static、全局变量、局部变量。

      6、条件语句、循环语句。

      7、数组、多维数组、字符数组。

      8、指针、函数与指针、const指针、动态存储。

      9、结构体struct 、头文件


二、实例

     

#include <stdio.h>
#include <stdlib.h>
#include "MathFunctions.h"
#include "Song.h"

// global variables
int  yearCount = 12;
int* allYears;

// utility functions
void setupYears();
int randomSongYear();


main ( int inputCount, char* inputValues[] ) {
  
  // we don't want to count the program itself as a song name
  int songCount = (inputCount - 1);
  
  // tell the user how many song names they entered
  if ( songCount > 0 ) {
    printf ( "You entered %i song names \n", songCount );
    
  } else {
    printf ( "Didn't enter any song names. \n" );
    exit(1);
  }
  
  // fill in the global 'allYears' array
  setupYears();
  
  // seed the random number generator,
  // and get a random number
  sranddev();
  int randomNumber = rand() % 500;
  
  // create an "easy" dynamic array of all of the songs,
  // and a separate array of just the song lengths
  Song allSongs[ songCount ];
  int songLengths[ songCount ];

  int i;
  for (i = 0; i < songCount; i++) {
    
    // choose a random length in seconds (up to 500)
    // and a random song year
    int length = rand() % 500;
    int year = randomSongYear();
    
    // get the song name
    char* songName = inputValues[i+1];
    
    // create the Song instance using all of the other values
    allSongs[i] = createSong ( songName, length, year );
    
    // finally, copy the length to the 'songLengths' array
    songLengths[i] = length;
  }
  
  // display the total length of all songs
  int combinedLength  = sum (songLengths, songCount);
  printf ("The total length of all songs is %i seconds\n", combinedLength);
  
  // loop through the songs again and make an array of float values
  float songLengthsAsFloats[ songCount ];
  
  for (i = 0; i < songCount; i++) {
    songLengthsAsFloats[i] = songLengths[i];
  }
  
  // calculate the average length
  float averageLength = average (songLengthsAsFloats, songCount);
  printf ("The average length is: %.2f seconds\n", averageLength);
  
  // clean up the memory we malloc'd
  free ( allYears );
}

void setupYears () {
  
  // reserve memory for all of the year values. we can't use
  // the "easy" dynamic array because 'years' is a global variable
  allYears = malloc ( sizeof(int) * yearCount );
  
  // choose the starting year
  int oneYear = 2000;
  
  // loop through and fill in each value
  int i;
  for ( i = 0; i < yearCount; i++ ) {
    
    oneYear++;
    allYears[i] = oneYear;
  }
}

int randomSongYear () {
  
  // get a random value between 0 and (yearCount-1)
  int yearIndex = rand() % (yearCount-1);
  
  // now use the index to get a year out of the 'allYears' array
  int year = allYears[ yearIndex ];
  
  return year;
}

三、小结


相关文章
|
2月前
|
机器学习/深度学习 Web App开发 编解码
论文精度笔记(四):《Sparse R-CNN: End-to-End Object Detection with Learnable Proposals》
Sparse R-CNN是一种端到端的目标检测方法,它通过使用一组可学习的稀疏提议框来避免传统目标检测中的密集候选框设计和多对一标签分配问题,同时省去了NMS后处理步骤,提高了检测效率。
46 0
论文精度笔记(四):《Sparse R-CNN: End-to-End Object Detection with Learnable Proposals》
|
2月前
|
机器学习/深度学习 人工智能 编解码
论文精度笔记(一):《ZERO-SHOT DETECTION WITH TRANSFERABLE OBJECT PROPOSAL MECHANISM》
本论文提出了一种零样本检测方法,通过引入可转移的对象候选机制来关联类别间的共现关系,并使用所有类的置信度分布进行对象置信度预测,以提高对未见类别物体的检测性能。
35 3
论文精度笔记(一):《ZERO-SHOT DETECTION WITH TRANSFERABLE OBJECT PROPOSAL MECHANISM》
|
2月前
|
编解码 人工智能 文件存储
轻量级网络论文精度笔记(二):《YOLOv7: Trainable bag-of-freebies sets new state-of-the-art for real-time object ..》
YOLOv7是一种新的实时目标检测器,通过引入可训练的免费技术包和优化的网络架构,显著提高了检测精度,同时减少了参数和计算量。该研究还提出了新的模型重参数化和标签分配策略,有效提升了模型性能。实验结果显示,YOLOv7在速度和准确性上超越了其他目标检测器。
53 0
轻量级网络论文精度笔记(二):《YOLOv7: Trainable bag-of-freebies sets new state-of-the-art for real-time object ..》
|
7月前
|
JavaScript 前端开发 Java
编程笔记 html5&css&js 073 JavaScript Object数据类型
编程笔记 html5&css&js 073 JavaScript Object数据类型
|
前端开发
前端学习笔记202306学习笔记第四十天-Es6-object.assign的使用2
前端学习笔记202306学习笔记第四十天-Es6-object.assign的使用2
49 0
|
前端开发
前端学习笔记202306学习笔记第四十天-Es6-object.assign的使用4深度拷贝
前端学习笔记202306学习笔记第四十天-Es6-object.assign的使用4深度拷贝
41 0
|
前端开发
前端学习笔记202306学习笔记第四十天-Es6-object.assign的使用3
前端学习笔记202306学习笔记第四十天-Es6-object.assign的使用3
38 0
|
1月前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
89 4
|
2月前
|
Java
Java Object 类详解
在 Java 中,`Object` 类是所有类的根类,每个 Java 类都直接或间接继承自 `Object`。作为所有类的超类,`Object` 定义了若干基本方法,如 `equals`、`hashCode`、`toString` 等,这些方法在所有对象中均可使用。通过重写这些方法,可以实现基于内容的比较、生成有意义的字符串表示以及确保哈希码的一致性。此外,`Object` 还提供了 `clone`、`getClass`、`notify`、`notifyAll` 和 `wait` 等方法,支持对象克隆、反射机制及线程同步。理解和重写这些方法有助于提升 Java 代码的可读性和可维护性。
89 20
|
4月前
|
Java
【Java基础面试二十】、介绍一下Object类中的方法
这篇文章介绍了Java中Object类的常用方法,包括`getClass()`、`equals()`、`hashCode()`、`toString()`、`wait()`、`notify()`、`notifyAll()`和`clone()`,并提到了不推荐使用的`finalize()`方法。
【Java基础面试二十】、介绍一下Object类中的方法