- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
错误:
2016-07-27 13:53:24.004 DataManipulationApp[1379:56100] *** Terminating app due to uncaught exception 'NSRangeException', reason: '*** -[__NSArrayM objectAtIndex:]: index 2 beyond bounds [0 .. 1]'
*** First throw call stack:
(
0 CoreFoundation 0x000000010ecc5d85 __exceptionPreprocess + 165
1 libobjc.A.dylib 0x000000010f16cdeb objc_exception_throw + 48
2 CoreFoundation 0x000000010eba3804 -[__NSArrayM objectAtIndex:] + 212
3 DataManipulationApp 0x000000010d06f36d _TFC19DataManipulationApp14ViewController16btn_Edit_ClickedfCSo8UIButtonT_ + 861
4 DataManipulationApp 0x000000010d06f9ea _TToFC19DataManipulationApp14ViewController16btn_Edit_ClickedfCSo8UIButtonT_ + 58
5 UIKit 0x000000010d603a8d -[UIApplication sendAction:to:from:forEvent:] + 92
6 UIKit 0x000000010d776e67 -[UIControl sendAction:to:forEvent:] + 67
7 UIKit 0x000000010d777143 -[UIControl _sendActionsForEvents:withEvent:] + 327
8 UIKit 0x000000010d776263 -[UIControl touchesEnded:withEvent:] + 601
9 UIKit 0x000000010d67699f -[UIWindow _sendTouchesForEvent:] + 835
10 UIKit 0x000000010d6776d4 -[UIWindow sendEvent:] + 865
11 UIKit 0x000000010d622dc6 -[UIApplication sendEvent:] + 263
12 UIKit 0x000000010d5fc553 _UIApplicationHandleEventQueue + 6660
13 CoreFoundation 0x000000010ebeb301 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17
14 CoreFoundation 0x000000010ebe122c __CFRunLoopDoSources0 + 556
15 CoreFoundation 0x000000010ebe06e3 __CFRunLoopRun + 867
16 CoreFoundation 0x000000010ebe00f8 CFRunLoopRunSpecific + 488
17 GraphicsServices 0x000000011191bad2 GSEventRunModal + 161
18 UIKit 0x000000010d601f09 UIApplicationMain + 171
19 DataManipulationApp 0x000000010d0743e2 main + 114
20 libdyld.dylib 0x000000010fc3792d start + 1
21 ??? 0x0000000000000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
(lldb)
代码:
发布的代码出现错误,我需要帮助解决
import UIKit
class HomeCellView: UITableViewCell
{
@IBOutlet weak var btnDelete: UIButton!
@IBOutlet weak var btnEdit: UIButton!
@IBOutlet weak var lbl_Email: UILabel!
}
class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate
{
@IBOutlet weak var HomeTableView: UITableView!
var databasepath:String!
var arrayStudInfo:NSMutableArray!
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
arrayStudInfo = NSMutableArray()
let filemgr = NSFileManager.defaultManager()
let dirpath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)
let docdir = dirpath[0] as String
databasepath = docdir.stringByAppendingString("StudentDataManipulation.sqlite");
if filemgr.fileExistsAtPath(databasepath as String)
{
let contactDB = FMDatabase(path: databasepath as String)
if contactDB == nil
{
print("Error: \(contactDB.lastErrorMessage())")
}
if contactDB.open()
{
let sql_stmt = "CREATE TABLE IF NOT EXISTS StudentData (Name TEXT, Phone TEXT, Email TEXT PRIMARY KEY NOT NULL, Comment TEXT)"
if !contactDB.executeStatements(sql_stmt)
{
print("Error: \(contactDB.lastErrorMessage())")
}
contactDB.close()
}
else
{
print("Error: \(contactDB.lastErrorMessage())")
}
}
}
override func viewWillAppear(animated: Bool)
{
super.viewWillAppear(true)
listAllData()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
// UITableViewDataSource Methods
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int
{
return arrayStudInfo.count
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell
{
let cell = tableView.dequeueReusableCellWithIdentifier("cellhome") as! HomeCellView
cell.lbl_Email.text = arrayStudInfo[indexPath.row]["Email"] as? String
cell.btnEdit.tag = indexPath.row
cell.btnDelete.tag = indexPath.row
// cell.btnDelete.addTarget(self, action: Selector("btn_Delete_Clicked"), forControlEvents: UIControlEvents.TouchUpInside )
// cell.btnEdit.addTarget(self, action: Selector("btn_Edit_Clicked"), forControlEvents: UIControlEvents.TouchUpInside)
cell.btnEdit.addTarget(self, action: #selector(ViewController.btn_Delete_Clicked (_:)), forControlEvents: UIControlEvents.TouchUpInside)
cell.btnEdit.addTarget(self, action: #selector(ViewController.btn_Edit_Clicked(_:)), forControlEvents: UIControlEvents.TouchUpInside)
return cell
}
// Edit Button Clicked
@IBAction func btn_Edit_Clicked(sender: UIButton)
{
let updateView = self.storyboard?.instantiateViewControllerWithIdentifier("UpdateScreen") as! UpdateScreen
print("Sender.Tag = \(sender.tag)")
updateView.strEmail = arrayStudInfo[sender.tag]["Email"] as? String
updateView.dictRecord = (arrayStudInfo[sender.tag] as! NSDictionary)
self.navigationController?.pushViewController(updateView, animated: true)
}
//Delete Button Clicked
@IBAction func btn_Delete_Clicked(sender: UIButton)
{
let contactDB = FMDatabase(path: databasepath as String)
let strDelete = arrayStudInfo[sender.tag]["Email"] as? String
if contactDB.open()
{
let deleteSQL = "DELETE FROM StudentData WHERE Email='\(strDelete!)'"
let result = contactDB.executeUpdate(deleteSQL, withArgumentsInArray: nil)
if !result
{
print("Error: \(contactDB.lastErrorMessage())")
}
else
{
print("Deleted Record.")
listAllData()
}
}
else
{
print("Error: \(contactDB.lastErrorMessage())")
}
contactDB.close()
}
func listAllData()
{
arrayStudInfo.removeAllObjects();
let contactDB = FMDatabase(path: databasepath as String)
if contactDB.open()
{
let filemgr = NSFileManager.defaultManager()
let dirpath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)
let docdir = dirpath[0] as String
databasepath = docdir.stringByAppendingString("StudentDataManipulation.sqlite");
if filemgr.fileExistsAtPath(databasepath as String)
{
let contactDB = FMDatabase(path: databasepath as String)
if contactDB == nil
{
print("Error: \(contactDB.lastErrorMessage())")
}
if contactDB.open()
{
let sql_stmt = "CREATE TABLE IF NOT EXISTS StudentData (Name TEXT, Phone TEXT, Email TEXT PRIMARY KEY NOT NULL, Comment TEXT)"
if !contactDB.executeStatements(sql_stmt)
{
print("Error: \(contactDB.lastErrorMessage())")
}
let SelectQuery = "SELECT * FROM StudentData"
if let results:FMResultSet? = contactDB.executeQuery(SelectQuery, withArgumentsInArray: nil)
{
while results?.next() == true
{
let dictRecord = results?.resultDictionary()
arrayStudInfo.insertObject(dictRecord!, atIndex: arrayStudInfo.count)
print("\nRESULT : \(results?.resultDictionary())")
}
HomeTableView.reloadData()
}
else
{
print("Recored not found");
}
contactDB.close()
}
else
{
print("Error: \(contactDB.lastErrorMessage())")
}
}
contactDB.close()
}
else
{
print("Error: \(contactDB.lastErrorMessage())")
}
}
/*
func listAllData()
{
arrayStudInfo.removeAllObjects();
let contactDB = FMDatabase(path: databasepath as String)
if contactDB.open()
{
let SelectQuery = "SELECT * FROM StudentData"
if let results:FMResultSet? = contactDB.executeQuery(SelectQuery, withArgumentsInArray: nil)
{
while results?.next() == true
{
let dictRecord = results?.resultDictionary()
arrayStudInfo.insertObject(dictRecord!, atIndex: arrayStudInfo.count)
print("\nRESULT : \(results?.resultDictionary())")
}
HomeTableView.reloadData()
}
else
{
print("Recored not found");
}
contactDB.close()
}
else
{
print("Error: \(contactDB.lastErrorMessage())")
}
}
*/
}
最佳答案
用这两行:
cell.btnEdit.addTarget(self, action: #selector(ViewController.btn_Delete_Clicked (_:)), forControlEvents: UIControlEvents.TouchUpInside)
cell.btnEdit.addTarget(self, action: #selector(ViewController.btn_Edit_Clicked(_:)), forControlEvents: UIControlEvents.TouchUpInside)
您正在将两个操作绑定(bind)到 cell.btnEdit
。当您点击 btnEdit
时,首先,ViewController.btn_Delete_Clicked(_:)
被执行,并且您的数据条目被删除,然后 ViewController.btn_Edit_Clicked(_ :)
被执行。那时,arrayStudInfo[sender.tag]
不可用,如您所见,已被删除。
考虑到每个单元格都可能被重复使用,上面的两行需要像这样:
cell.btnDelete.removeTarget(nil, action: nil, forControlEvents: .TouchUpInside)
cell.btnDelete.addTarget(self, action: #selector(ViewController.btn_Delete_Clicked (_:)), forControlEvents: .TouchUpInside)
cell.btnEdit.removeTarget(nil, action: nil, forControlEvents: .TouchUpInside)
cell.btnEdit.addTarget(self, action: #selector(ViewController.btn_Edit_Clicked(_:)), forControlEvents: .TouchUpInside)
请尝试。
关于ios - 由于未捕获的异常 'NSRangeException' 而终止应用程序,原因 : '*** -[__NSArrayM objectAtIndex:]: index 2 beyond bounds [0 .. 1]' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38607829/
我正在编写一个基于核心数据的 iPhone 应用程序,而且我是 Objective-C 的新手。 我有一个正在努力解决的错误。 iPhone 模拟器不断崩溃并显示以下错误消息: 2010-03-21
当我尝试将属性应用于子字符串时,有时在以下代码中崩溃: // Dummy strings let originalString = "Some example string" let searchSu
我试图在按下主页按钮时保存数据。这是我的相关代码。 - (NSString *) saveFilePath { NSArray *path = NSSearchPathForDi
我有一个应用程序,用户报告该应用程序随机崩溃。所有崩溃都有相同的堆栈 0 CoreFoundation TAGPBIvarClearUInt32 (in SPONTAN) + 11 1 l
我在下面的方法中得到 substringWithRange:range 的异常。 我有禁用编辑的 TextView 。 我仅将文本字段用于文本选择。当我第一次选择文本时没有异常(exception),
Application Specific Information: *** Terminating app due to uncaught exception 'NSRangeException',
大家好,我是 swift 的新手,我的程序面临一个问题。我已在“let defaultStudentId = NSUserDefaults.standardUserDefaults()”中保存一些数据
我试图在从 JSON 解析对象后填充 TableView 。我想将行数设置为已解析对象的计数。 这是我的 viewDidLoad 代码: - (void)viewDidLoad { [supe
我的应用在 _storeArray 中随机崩溃。 在 viewDidLoad 中,有一个方法 [self loadUrl] 解析 xml 文件,然后添加字典 [_storeArray addObjec
我仍在边做边学,所以如果这听起来像是一个菜鸟问题,那可能就是这样。 我正在尝试遍历 NSDictionary(消息)并获取某个键的值。 当我运行这段代码时,出现以下错误“* 由于未捕获的异常‘NSRa
我有一个我无法解决的问题。我正在使用 Core Data 框架创建一个 iOS 应用程序。在我得到 NSRangeException 之前,一切都很顺利。这个异常是我在检查应用程序数据是否需要更新的函
你好我是 iPhone 编程的新手,我正在使用 EGOPhotViewer 并想通过使用此代码显示图像, for ( recipeImages in recipeImages.imgArray) {
我无法 repo 这个问题。我明白 NSRangeException 代表什么,但我不明白为什么它会在创建 nib 文件时出现。这是我从 Crashlytics 收到的崩溃报告: Fatal Exce
我尝试将 360 全景图加载到 UIViewController 的 UIWebView 中,该全景图采用 html 格式并内置于 krpano 中。当全景图打开时,一切正常。虽然过了一段时间后,我得
我正在尝试从相机捕捉图像和录制视频,但每当我用相机关闭 View 时,我都会收到此错误: Terminating app due to uncaught exception 'NSRangeExcep
应用程序在 iOS 11 更新之前运行良好。在 iOS 11 推出后,一些用户遇到了以下崩溃,但我无法在模拟器 iOS 11 中重现此问题。基于 fabric.io,并非所有 iOS 11 都经历过此
在向我的应用程序添加新的 Core Data 模型版本后,我执行了轻量级迁移,显然是成功的。迁移的文件加载正常,但在第一次尝试通过特定关系访问属性时,应用程序崩溃并显示 NSRangeExceptio
在我的应用程序中,更新表格内容后,我尝试将 UITableView 滚动到顶部一次。然而,在某些情况下,我的 table 是空的。所以我得到了以下异常: Terminating app due to
我有一个 NSRangeException 错误,该错误并不总是发生(尤其是在调试时)。它是随机出现的,我无法弄清楚它来自哪里。我有很多数组操作,因此很难以这种方式消除它。 我的问题是我是否可以从调试
我正在做教程并收到以下错误。 我的代码: #import int main (int argc, const char * argv[]) { //NSAutoreleasePool *p
我是一名优秀的程序员,十分优秀!